summaryrefslogtreecommitdiffstats
path: root/_site/log/mosfet-switches/index.html
diff options
context:
space:
mode:
Diffstat (limited to '_site/log/mosfet-switches/index.html')
-rw-r--r--_site/log/mosfet-switches/index.html134
1 files changed, 53 insertions, 81 deletions
diff --git a/_site/log/mosfet-switches/index.html b/_site/log/mosfet-switches/index.html
index 3b8f83b..97bba07 100644
--- a/_site/log/mosfet-switches/index.html
+++ b/_site/log/mosfet-switches/index.html
@@ -2,12 +2,12 @@
<html>
<head>
<meta charset="utf-8">
- <title>On the use of MOSFETs as electronic switches</title>
+ <title>High-side MOSFET switching</title>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
- <title>On the use of MOSFETs as electronic switches</title>
+ <title>High-side MOSFET switching</title>
<link rel="stylesheet" href="/assets/css/main.css">
<link rel="stylesheet" href="/assets/css/skeleton.css">
</head>
@@ -41,104 +41,76 @@
<main>
<div class="container">
<div class="container-2">
- <h2 class="center" id="title">ON THE USE OF MOSFETS AS ELECTRONIC SWITCHES</h2>
+ <h2 class="center" id="title">HIGH-SIDE MOSFET SWITCHING</h2>
<h6 class="center">22 JUNE 2025</h5>
<br>
- <div class="twocol justify"><p>Recently, I needed a low-power circuit for one of my battery-operated projects.
-Much of the system’s power savings depended on its ability to electronically
-switch off components, such as servos, that draw high levels of quiescent
-currents. My search for a solution led me to MOSFETs, transistors capable of
-controlling circuits operating at voltages far above their own.</p>
-
-<h2 id="acknowledgments">Acknowledgments</h2>
-
-<p>This article is a summary of what I learnt about using MOSFETs as switches.
-I’m not an electronics engineer, and this is not an authoritative guide. The
-circuits in this post must be considered within the narrow context in which
-I’ve used them. All credits for the schematics belong to <a href="https://electronics.stackexchange.com/users/292884/simon-fitch" class="external" target="_blank" rel="noopener noreferrer">Simon Fitch</a>.</p>
-
-<h2 id="preamble">Preamble</h2>
-
-<p>For a typical MOSFET-based switch, we can connect a GPIO pin of a
-microcontroller to the gate of a logic-level N-channel MOSFET placed on the low
-side of the load and tie the gate and the drain pins of the MOSFET with a
-pull-down resistor. This would work as long as the power supplies of the
-microcontroller and the load don’t share a common ground. Things become more
-complicated when they do (e.g., controlling power to a component driven by the
-same microcontroller).</p>
-
-<p>In that scenario, the source potential visible to the load is the difference
-between the gate and the threshold potentials of the MOSFET. For example, when
-the gate and the threshold potentials are 3.3 V and 1.5 V, the potential the
-load sees is 1.8 V. So, to use a low-side N-channel MOSFET, we need the gate
-potential to be higher than the source potential, which may not always be
-practical. The alternative would be a hide-side switch.</p>
+ <div class="twocol justify"><p>Needed low-power switching for the <a href="../fpm-door-lock-lp/">fingerprint door
+lock</a>. Servo and FPM draw high quiescent current–had to
+cut power electronically during sleep. MOSFETs can do this.</p>
-<h2 id="p-channel-high-side-switch">P-channel high-side switch</h2>
+<p>Schematics belong to <a href="https://electronics.stackexchange.com/users/292884/simon-fitch" class="external" target="_blank" rel="noopener noreferrer">Simon Fitch</a>.</p>
+
+<h2 id="problem-with-simple-low-side-switching">Problem with simple low-side switching</h2>
+
+<p>Typical approach: GPIO → gate of N-channel MOSFET on low side, pull-down
+resistor between gate and drain. Works if MCU and load don’t share common
+ground. Doesn’t work when they do (like controlling a component powered by the
+same MCU).</p>
-<p>The following schematic shows how a high-side P-channel MOSFET (M1) could
-switch power to a 6 V servo driven by a 3.3 V MCU.</p>
+<p>Issue: source potential = gate potential - threshold voltage. Example: 3.3V
+gate - 1.5V threshold → 1.8V at load–not nearly enough for a servo. Raising
+the gate potential above source is not always practical. Solution: high-side
+switch.</p>
+
+<h2 id="p-channel-high-side-switch">P-channel high-side switch</h2>
<p><img src="p_high_side.png" alt="P-channel high-side switching circuit" /></p>
-<p>When the microcontroller outputs low, the M2 N-channel MOSFET stops conducting.
-The R1 resistor pulls the gate of the M1 P-channel MOSFET up to +6 V, switching
-the servo off. When the microcontroller outputs high on the GPIO pin, M2’s
-source-drain connection starts conducting, causing M1’s gate potential to drop
-to 0 V, which switches on power to the servo.</p>
+<p>M1 is P-channel (high-side), M2 is N-channel (level converter). MCU output low
+→ M2 off → R1 pulls M1 gate to +6V → servo off. MCU output high → M2 conducts →
+M1 gate drops to 0V → servo on.</p>
-<h2 id="n-channel-high-side-switch">N-channel high-side switch</h2>
+<p>Note: IRF9540 in the schematic doesn’t work. V<sub>GS</sub> (-10V) for
+RDS<sub>on</sub> too much for 3.3V ATmega328P to drive. NDP6020P is the only
+suitable through-hole MOSFET I could find.</p>
-<p>The P-channel high-side switch would be the typical architecture for our use
-case. However, if we have access to a potential high enough to safely raise the
-gate potential above the threshold such that their difference outputs the source
-potential required to drive the load, we can switch on the high side using an
-N-channel MOSFET:</p>
+<h2 id="n-channel-high-side-switch">N-channel high-side switch</h2>
<p><img src="n_high_side.png" alt="N-channel high-side switching circuit" /></p>
-<p>In the schematic, both M1 and M2 are N-channel MOSFETs. When the
-microcontroller output is low, M2 stops conducting. This causes the M1’s gate
-potential to rise above the threshold, turning the servo on. Conversely, a high
-output on the GPIO line switches M2 on, which lowers M1’s gate potential. This
-switches the servo off. The R2 pull-up resistor prevents the high impedance of
-the output pins at power-up from switching the servo on.</p>
+<p>Less common but works if you have voltage high enough to drive the gate. Both
+M1 and M2 are N-channel. MCU low → M2 off → M1 gate rises above threshold →
+servo on. MCU high → M2 on → M1 gate drops → servo off. R2 prevents
+high-impedance power-up from switching servo on.</p>
-<p>Both topologies require M2 to act as a level converter between circuits
-containing the microcontroller and the servo, converting between 0 V and +6 V
-or +9 V. M2 is a low-power signal converter carrying less than a milliamp of
-current. The gate-source threshold voltage of M2 must be lower than the MCU’s
-supply voltage. 2N7000, 2N7002, and BSS138 are popular choices for M2.</p>
+<p>M2 needed in both topologies for level conversion (0V ↔ +6V or +9V). Carries
+&lt;1mA. Gate-source threshold must be lower than MCU supply. Common choices:
+2N7000, 2N7002, BSS138.</p>
-<p>The D1 flyback diodes used in the two topologies safeguard the MOSFET from
-voltage spikes caused by inductive loads such as servos.</p>
+<p>Note: D1 flyback diodes protect MOSFETs from voltage spikes caused by inductive
+loads (servos, relays).</p>
<h2 id="a-bjt-alternative">A BJT alternative</h2>
-<p>A Bipolar Junction Transistor (BJT) is a simpler, cheaper, and more widely
-available type of transistor that can be used as a switch.</p>
-
<p><img src="bjt.png" alt="BJT architecture" /></p>
-<p>In the schematic, when the MCU outputs high, Q2 starts conducting. Q2 amplifies
-Q1’s base current. Unlike MOSFETs, which are voltage-driven, BJTs are driven by
-base current. Resistors R3 and R4 must be chosen carefully to output the
-desired base currents. <a href="https://teachmetomake.wordpress.com/how-to-use-a-transistor-as-a-switch/" class="external" target="_blank" rel="noopener noreferrer">“How to choose a
-transistor as a switch”</a> is an excellent guide on using BJTs as electronic
-switches.</p>
+<p>Simpler, cheaper, more available. Q2 conducts when MCU outputs high. Q2
+amplifies Q1’s base current. Unlike MOSFETs (voltage-driven), BJTs are
+current-driven. R3 and R4 must be calculated for desired base currents. <a href="https://teachmetomake.wordpress.com/how-to-use-a-transistor-as-a-switch/" class="external" target="_blank" rel="noopener noreferrer">Guide on BJT
+switches</a>.</p>
+
+<h2 id="which-topology">Which topology?</h2>
-<h2 id="which-topology-to-choose">Which topology to choose?</h2>
+<p>MOSFETs preferred in professional work—more efficient when on. Harder to drive
+at 3.3V due to V<sub>GS</sub> requirements for full saturation (low
+R<sub>DS(on)</sub>).</p>
-<p>The professional community appears to prefer MOSFETs over BJTs. MOSFETs are
-more efficient when the switch is on. However, they are more challenging to
-drive, especially with a 3.3 V MCU, due to the V<sub>GS</sub> potentials
-required to achieve specified R<sub>DS(on)</sub> values (i.e., to turn them on
-fully).</p>
+<p>N-channel: Lower on-resistance, cheaper, more efficient than P-channel. Harder
+to drive high-side (gate must be above source—requires extra circuitry like
+MOSFET drivers).</p>
-<p>N-channel MOSFETs have lower on-resistance values, making them more efficient
-than P-channel ones. They are also cheaper. However, they are harder to drive
-on the high side as their gate potential must be higher than the source
-potential. This often requires extra circuitry such as MOSFET drivers.</p>
+<p>Used P-channel high-side for the door lock redesign. Simpler to drive from 3.3V
+MCU, no driver needed.</p>
<h2 id="further-reading">Further reading</h2>
@@ -147,11 +119,11 @@ potential. This often requires extra circuitry such as MOSFET drivers.</p>
topologies</a></li>
<li><a href="https://www.embeddedrelated.com/showarticle/809.php" class="external" target="_blank" rel="noopener noreferrer">How to read
MOSFET datasheets</a></li>
- <li><a src="https://teachmetomake.wordpress.com/how-to-use-a-transistor-as-a-switch/" class="external" target="_blank" rel="noopener noreferrer">How to use a
+ <li><a href="https://teachmetomake.wordpress.com/how-to-use-a-transistor-as-a-switch/" class="external" target="_blank" rel="noopener noreferrer">How to use a
transistor as a switch</a></li>
- <li><a src="https://forum.digikey.com/t/guide-to-selecting-and-controlling-a-mosfet-for-3-3-vdc-logic-applications/42606" class="external" target="_blank" rel="noopener noreferrer">Guide to
+ <li><a href="https://forum.digikey.com/t/guide-to-selecting-and-controlling-a-mosfet-for-3-3-vdc-logic-applications/42606" class="external" target="_blank" rel="noopener noreferrer">Guide to
selecting and controlling a MOSFET for 3.3 VDC logic applications</a></li>
- <li><a src="https://forum.digikey.com/t/driving-a-large-relay-from-a-3-3-vdc-microcontroller-using-an-npn-darlington-transistor/41751" class="external" target="_blank" rel="noopener noreferrer">Driving a large
+ <li><a href="https://forum.digikey.com/t/driving-a-large-relay-from-a-3-3-vdc-microcontroller-using-an-npn-darlington-transistor/41751" class="external" target="_blank" rel="noopener noreferrer">Driving a large
relay from a 3.3 VDC microcontroller using an NPN Darlington transistor</a></li>
</ul>
</div>