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.
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.
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 mask layers - 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 Features
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. See Step 4 - Route Components for more details.
Vias - holes that go all or partway through a pcb, and which are plated in copper. These allow for signals to travel between copper layers.
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).
Copper Pours - wide areas of copper that belong to a single net, so called because it looks like someone “poured” copper over part of the board. These are often used in areas of high current, or when many adjacent components share a common net.
If you’re interested in learning 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
In the following demonstration, 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 includes fully open-source schematics, which can be found here. Below is my adaptation of these schematics for use in our vehicle. My only notable changes 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 being programmed. The USB micro connector was also swapped for USB-C in my design, and an additional LED was added to indicate that the 3.3V net 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 change your design in the middle of routing a board.
You’ve addressed all the concerns from design review - double check that you’ve thoroughly responded to and implemented all feedback in your schematic’s review document.
All un-reviewed 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. At the very least, all components should be marked as “ready to review,” and should be handed off to the head of your system or the chief EE (Walter Stadolnik (Unlicensed) ) for review.
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 PCB file, 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 Stack-up
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! Note that all changes to the stack manager occur symmetrically: Adding a copper layer above the core will add a second layer below the core.
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
The weight of a copper layer is synonymous with thickness. Typically this is left at 1oz, but doubling it to 2oz means that you can force twice the current through every trace, which is useful for keeping trace widths small on high current boards.
Since my board uses USB, which requires controlled impedance, I’ll use a 4-layer stack-up with planes as the inner layers (see the next section). Since the board is entirely low current, I’ll stick to 1oz copper layers.
Note that manufacturers almost always require an even number of copper layers. Even if you only need 3 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.
Determining Controlled Impedance
Don’t skip this step, even if you’re not using differential pairs!
If planning on ordering the board for JLCPCB (includes most boards), refer to this page for impedance profile information: https://jlcpcb.com/impedance
Scroll down to the section that applies to the layer count of your board, and use the stack-up data for the first controlled impedance option which appears under “No Requirement Stackup”. I’m planning on doing 4-layers for the RPi debug board, so I’ll follow the JLC04161H-7628 spec. For 6-layer boards, follow the JLC06161H-3313 spec.
Be sure to select the proper thickness and copper weight settings! You can leave the default thickness setting, but set the copper weights to match your board stack-up.
Go back to the Layer Stack Manager in Altium, and enter the appropriate thicknesses for each layer. If it displays in units of mils instead of mm, press “q” while in the .PcbDoc to switch units.
Click on the icon with 3 dots in the “Material” cell for the top dielectric layer. Scroll down the material list until you see a number in the “constructions” column that matches the last 4 digits of the impedance spec (in my case 7628). Then, select the material with that construction number which most closely matches the upper dielectric layer in thickness (in my case this is PP-022, with a thickness of 0.20828mm).
Switch to the Impedance tab (bottom left corner of the window). Click the “+ Add” button at the top left of the window. Open the properties panel if not already open (panels → properties). Verify that the Impedance profile says type Single, 50 for target impedance, and 10% for target tolerance. Note that the desired single-ended impedance varies in different contexts, but that 50 ohms is a good baseline.
To the right of the layer stack, it should now show impedance characteristics of the top and bottom signal layers. Verify that the impedance is close to 50 ohms. If you plan to use differential pairs, copy the value in the width column (in my case 0.35831mm).
If your board does not use differential pairs, move on to Importing Design Rules. If it does, then Click the “+ Add” button at the top left of the window. By default, this will add a new single-ended impedance constraint. Open properties, and change Type to Differential, and impedance to the target impedance of the differential pair you’re using. For USB, the target is 90 ohms. Leave the default tolerance of 10%. USB can tolerate an impedance range from 75 to 105 ohms.
In the differential impedance characteristics to the right of the layer stack, update the Width field with the width copied from the single ended impedance characteristics. This will likely cause the Impedance to deviate from your target. To fix this, guess and check values for the Trace Gap field until you restore your target impedance (within ~1%).
If your board includes differential pairs, it’s good practice to make sure that the inner copper layer nearest to the most sensitive differential pairs is assigned to GND
Importing the NER Design Rules File
Blah
Step 3 - Placing Components
Whew, done with the boring part. Time for the fun stuff!
Importing the Components + Netlist
blah
It might look daunting when you first import the components, and they’re all jumbled in a corner. Don’t worry - It looks worse than it is!
Organizing the Components
Before even thinking about where things go, the first step I like to do is to organize my components.
Typically I begin by identifying “focal points” - components that a lot of other stuff is next to. This could be a connector, a microcontroller, or a smaller IC (integrated circuit)
Often, connectors will be surrounded by circuit protection elements, like fuses and TVS diodes.
ICs will often be surrounded by discrete passive elements, like decoupling capacitors, resistors, and inductors
Drag each “focal point” component to a different area in space, and start sorting the smaller components by which “focal point” they belong near.
Reviewing
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
SAVE WHENEVER YOU CAN - get into the habit of doing CTRL+S after literally everything you do. If/when Altium crashes, this will ensure that the progress you’ve made will be saved locally to your computer.
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:
DU, Design Update → Do this while in your schematic to synchronize the PCB with schematic changes
TGA
TDR, Run Design Rules Check → Do this to generate a new report showing Design Rule Violations