Table of Contents |
---|
Introduction
The purpose of this guide is to serve as a beginner-friendly walkthrough on how to create a PCB from a schematic using Altium Designer. You can find many such guides on the internet in both video and text form (Several good recommendations are made here!), but this guide has the benefit of being tailored to the specific standards and conventions used by Northeastern Electric Racing. This document was created by Walter Stadolnik (Unlicensed) , so feel free to poke him if anything seems outdated/incorrect.
Info |
---|
Throughout this guide, I’ve bolded most commands and menu paths. When applicable, I’ve underlined the letter of each command used as its default command shortcut, to reduce the hassle of locating each command in the menus. |
As a demo, I’ll be walking through step-by-step as I do the layout for a custom Raspberry Pi Debug Probe. Not to be confused with a Raspberry Pi computer, this probe uses a RPi 2040 microcontroller, and is used to convert between USB and UART or SWD when flashing a board. In our 2024 competition vehicle, we’ll be embedding two copies of this circuit into our /wiki/spaces/NER/pages/63275033 in order to wirelessly flash the microcontrollers and FPGA on the /wiki/spaces/NER/pages/63209494 and the /wiki/spaces/NER/pages/100925527.
The Raspberry Pi Debug probe provides fully open-source schematics, which can be found here. Below is my adaptation of these schematics for use in our vehicle. My only notable additions are the consolidation of the two output JST connectors into a single Molex PicoBlade connector, and the addition of a 3.3V output so that the probe can power the microcontroller or FPGA on the board being programmed. The USB micro connector was also swapped for USB-C in my design, and some additional LED was added to indicate the 3.3V rail is receiving power.
Anatomy of a PCB
Before we get started, lets review what a PCB is. PCB stands for Printed Circuit Board, which is a bit of a misnomer, as the layers of modern PCBs are produced through subtractive processes. Only the silkscreen layers are ever printed - more on that in a second. The term “printed” has its origins in the first PCBs, which were produced by drawing “wires” with conductive ink on an insulating substrate.
PCB Layers
Even the simplest PCBs are comprised of several layers:
copper layers - used to conduct electric currents. Confusingly, PCBs use ounces as units of thickness for copper layers. This is the thickness of copper achieved if you flatten out an ounce of copper over a square foot of area.
dielectric/prepreg layers- insulating layers which prevent shorts between the copper
solder masklayers - deposited on the top and bottom copper layers, this protects the copper from corrosion and environmental damage, and lends PCBs their color (typically green by default)
silkscreen layers(“silks”)- to call this a “layer” might seem odd, since this is just the text and decals printed on the top and bottom of the board, typically in white ink. Another anachronistic term, most PCB silkscreens are now produced with a direct printing or photoimaging process, rather than true screen printing.
Key PCB Elements
Traces (or Tracks)- “wires” etched into the copper layers. Because the copper
layers are a predetermined thickness, the width of copper traces is often increased for traces which carry more current
for more details.
Vias - holes that go all or partway through a pcb, and which are plated in copper.
Pads- If you’ve made it through the component creation guide, you’ll know that a pad is used to allow a component to be soldered onto the PCB. Pads may be surface mount (flat piece of copper) or through-hole (think an extra wide via).
If you’re interested in learning more about how PCBs are made, I highly recommend checking out this tour of the JLCPCB factory. Many of the boards on our car likely originated in that very factory!
About the demo board
As a demo, I’ll be walking through step-by-step as I do the layout for a custom Raspberry Pi Debug Probe. Not to be confused with a Raspberry Pi computer, this probe uses a RPi 2040 microcontroller, and is used to convert between USB and UART or SWD when flashing a board. In our 2024 competition vehicle, we’ll be embedding two copies of this circuit into our /wiki/spaces/NER/pages/63275033 in order to wirelessly flash the microcontrollers and FPGA on the /wiki/spaces/NER/pages/63209494 and the /wiki/spaces/NER/pages/100925527.
The Raspberry Pi Debug probe provides fully open-source schematics, which can be found here. Below is my adaptation of these schematics for use in our vehicle. My only notable additions are the consolidation of the two output JST connectors into a single Molex PicoBlade connector, and the addition of a 3.3V output so that the probe can power the microcontroller or FPGA on the board being programmed. The USB micro connector was also swapped for USB-C in my design, and some additional LED was added to indicate the 3.3V rail is receiving power.
Step 1 - Verify Schematics + Components
So, you’ve finished up a circuit schematic. Great! Now it’s time to turn it into a PCB.
~ But wait! ~
First, make sure that:
Your schematic has been reviewed - all schematics need to be reviewed before moving on to layout. Trust us - it’s no fun to have to change your design in the middle of routing a board.
You’ve addressed all the concerns from design review - make sure that you’ve thoroughly responded to and implemented all feedback in your schematic’s review document.
Make sure all your components are marked as “Ready to Review” - Ideally all components will be reviewed before layout - it’s better to catch stuff like incorrect land patterns before getting too deep in the weeds of routing. But at the very least, all components should be marked as “ready to review,” and your head or the chief EE should be notified before you begin.
Make sure to follow this Component Review Checklist!
Step 2 - Set up the Board
You’re schematics are good to go, and your components are reviewed. Now what?
Creating the PCB Doc
First, you’re gonna need a PCB document.
Open the Projects Panel (Panels → Projects), right click on the project title (CUSTOM_RPI_DEBUG.PrjPcb), and select “Add New To Project”. Select “PCB” from the dropdown.
This should open a new tab with a big, empty black box. This black box is the default 6” x 4” PCB outline. Before you make changes, go ahead and CTRL+S to save your design, and give it a fitting name. If in doubt, PROJECT_NAME.PcbDoc will do.
Setting up Component Layer Pairs
Next step is setting up component layer pairs, just as you would when making a footprint. Go to Panels → View Configuration to see the layers of the board. Right click on “Component Layer Pairs,” and select “Add Component Layer Pair”. Do this for each of the four required layer pairs (Assembly, Component Outline, Component Center, and Courtyard), as defined in the Vault Guidelines.
Defining the Layer Stackup
Open Design → Layer Stack Manager
A new tab should open as shown to the right. This tab shows all the layers which will make up the PCB, which is by default a 2-layer board (only copper layers count towards the PCB layer count. As is evident from this stackup, a total of 5 non-copper layers are present in a 2-layer board).
The outermost green layers are the overlay (silkscreen) layers, the inner green layers are solder mask layers, the two orange layers are the copper layers, and the brown layer is the dielectric (insulator). The material of the dielectric is set to FR-4 fiberglass, which is the standard dielectric used in PCB cores.
Depending on the complexity of your board, you may need more than two layers. To add copper layers, click on the cell labelled “Top Layer,” Click the “+ Add” button, and click OK with the default settings shown at right. Congratulations, you now have a 4-layer board!
Next, you’ll want to verify the layer Types and Weights of each copper layer. “Type” is either signal or plane - A signal layer is generally used for routing traces, while a plane layer is a giant sheet of copper that helps bring power or ground to different parts of the PCB
Info |
---|
Note that manufacturers almost always require an even number of copper layers. Even if you only need3 layers, it’ll probably cost you less to add that 4th layer. However, cost can increase dramatically with layer count, so do be conservative with how many layers you use. |
Step 3 - Place Components
Step 4 - Route Components
Step 5 - DRC Errors and Layout Review
Step 6 - Generate Deliverables
Step 6 - Order the Board and Components
Summary
General Tips and Tricks
If this is your first board at NER, I highly recommend perusing the Altium vault and checking out our previous designs. You can learn a lot about layout technique by simply observing other people’s work
Don’t take this document too seriously! While I generally follow good practices, what counts as “good practice” varies massively depending on who you ask. While most of these tips are good for this club, you may find that your co-ops will tell you something entirely different. If anything seems outdated, or questionable, feel free to add a comment!
Shortcuts used in this tutorial: