This document is Copyright © 2021-2023 by its contributors as listed below. You may distribute it and/or modify it under the terms of either the GNU General Public License (, version 3 or later, or the Creative Commons Attribution License (, version 3.0 or later.

All trademarks within this guide belong to their legitimate owners.


Jon Evans, Graham Keeth


The KiCad project welcomes feedback, bug reports, and suggestions related to the software or its documentation. For more information on how to sumbit feedback or report an issue, please see the instructions at

Publication date



KiCad is a free and open-source electronics design automation (EDA) suite. It features schematic capture, integrated circuit simulation, printed circuit board (PCB) layout, 3D rendering, and plotting/data export to numerous formats. KiCad also includes a high-quality component library featuring thousands of symbols, footprints, and 3D models. KiCad has minimal system requirements and runs on Linux, Windows, and macOS.

KiCad 7.0 is the most recent major release. It includes hundreds of new features and bug fixes. Some of the most notable new features include:

  • A Properties Panel in the PCB Editor, which lets you quickly view and edit properties of selected objects. This works even when multiple different types of objects are selected at once.

  • Database libraries, which allow connecting KiCad to a component database that stores symbol and footprint mappings as well as other component metadata. This database can be shared with other users, applications, and systems.

  • A command-line interface for automating many KiCad functions, including schematic exports (BOMs, netlists, PDF/SVG plots), PCB exports (fabrication files, mechanical STEP models, PDF/SVG plots), and symbol and footprint library exports.

  • A new search panel in the PCB Editor, which lets you type a query to display a filtered list of footprints, nets, zones, and PCB text. Clicking on a search result selects the item in the editing canvas, and double-clicking on a search result opens the item’s Properties dialog.

  • Many new and improved DRC checks and features, including mechanical clearance rules (as opposed to electrical clearance), custom rule severities, custom constraints for pad-to-zone connections, and footprint board-vs.-library consistency checks.

  • Improved initial footprint placement, and a new "Pack and Move Footprints" tool that enables convenient footprint grabbing based on a schematic selection. There’s also a new "Move Individually" tool for convenient one-after-another movement of multiple selected footprints.

  • New routing convenience tools: "Unroute Selected" to quickly remove copper traces connected to the selected object, "Attempt Finish" to attempt to automatically finish routing the current trace, and "Attempt Finish Selected" to attempt to automatically route the connections to/from the selected pads, one at a time. The automatic routing tools work based on the ratsnet, attempting to route to the closest ratsnest connection.

  • Improved text support in several areas. Most notably, system fonts can be used in schematics and PCBs. Additionally, PCB text can be displayed in a subtracted "knockout" mode, text can be turned into a hyperlink, and there is a new textbox tool.

  • Improved wire dragging in the Schematic Editor, which keeps wires attached to pins while also maintaining right-angled wire corners and junctions.

  • A GUI editor for simulation model parameters, including built-in models (voltage sources, behavioral passives, transistors, etc.) and external models (integrated circuit models from a vendor, for example).

  • First-class support for "Do Not Populate" components. Components marked as DNP are displayed in the Schematic Editor as greyed out with a cross through them. _ Improved pin editing for multi-unit symbols using the Symbol Editor’s Pin Table.

  • Background images that can be displayed in the PCB Editor for reference or reverse engineering purposes.

  • Optional automatic zone filling in the PCB Editor, which can be used instead of manually refilling zones, if desired.

  • Automatic updates for packages from the Plugin and Content Manager.

  • 3Dconnexion SpaceMouse support, which is currently only available on Windows and macOS).

A full listing of new features and changes in KiCad 7.0 can be found here.

Installing and Upgrading KiCad

KiCad maintains compatibility and support with the maintained versions of Microsoft Windows, Apple macOS, and a number of Linux distributions. Some platforms have specific installation or upgrade instructions. Always check for the latest release information and instructions for your platform.

KiCad may compile and run on platforms that are not officially supported. The KiCad development team makes no guarantees that KiCad will continue to work on these platforms in the future. See for more details on supported platforms and hardware requirements.

KiCad uses a "major.minor.point" release version format. Major releases bring new features and other significant changes to the code. Minor releases are relatively rare and typically bring bug fixes that are too complicated for a point release. Point releases contain only bugfixes. Users are encouraged to update to the latest point release for their current major.minor version promptly, as these releases will not break file compatibility. Major releases almost always come with changes to file formats. KiCad is in general always backwards compatible with files created by older versions, but not forwards compatible: Once files are edited and saved by a new major version, these files will not be openable by the previous major version.

Migrating from Previous Versions

In general, to migrate a design to a new version of KiCad, simply open the project with the new version, then open the schematic and PCB and save each file. More details about specific issues that may come up when migrating designs is covered in the Schematic Editor and PCB Editor chapters of the manual.

Make sure to save a backup of your design before opening it with a new version of KiCad.

The symbol library format changed in KiCad 6.0. To continue editing symbol libraries made with a previous version of KiCad, these libraries need to be migrated to the new format. For details on this process, see the Schematic Editor chapter of the manual. Symbol libraries that have not been migrated can still be opened and used in read-only mode.

KiCad Workflow

This section presents a high-level overview of the typical KiCad workflow. Note that KiCad is a flexible software system, and there are other ways of working that are not described here. For more information about each of the steps described in this section, please see the later chapters in this manual.

A number of tutorials and guided lessons in using KiCad have been created by community members. These resources can be a good way to learn KiCad for some new users. See the Further Reading section at the end of this chapter for more information.

Basic Terminology

KiCad uses a number of terms that are fairly standard in the area of electronics design automation (EDA) software, and some that are more specific to KiCad. This section lists some of the most common terms used throughout KiCad’s documentation and user interface. Other terms that are more specific to a certain part of the KiCad workflow are defined later in this manual.

A schematic is a collection of one or more pages (sheets) of circuit schematic drawings. Each KiCad schematic file represents a single sheet.

A hierarchical schematic is a schematic consisting of multiple pages nested inside each other. KiCad supports hierarchical schematics, but there must be a single root sheet at the top of the hierarchy. Sheets within a hierarchy (other than the root sheet) may be used more than once, for example to create repeated copies of a subcircuit.

A symbol is a circuit element that can be placed on a schematic. Symbols can represent physical electrical components, such as a resistor or microcontroller, or non-physical concepts such as a power or ground rail. Symbols have pins which serve as the connection points that can be wired to each other in a schematic. For physical components, each pin corresponds to a distinct physical connection on the component (for example, a resistor symbol will have two pins, one for each terminal of the resistor). Symbols are stored in symbol libraries so they can be used in many schematics.

A netlist is a representation of a schematic that is used to convey information to another program. There are many netlist formats used by various EDA programs, and KiCad has its own netlist format that is used internally to pass information back and forth between the schematic and PCB editors. The netlist contains (among other things) all the information about which pins connect to each other, and what name should be given to each net, or set of connected pins. Netlists can be written to a netlist file, but in modern versions of KiCad, this is not necessary as part of the normal workflow.

A printed circuit board, or PCB, is a design document that represents the physical implementation of a schematic (or technically, a netlist). Each KiCad board file refers to a single PCB design. There is no official support for creating arrays or panels of PCBs within KiCad, although some community-created add-ons provide this functionality.

A footprint is a circuit element that can be placed on a PCB. Footprints often represent physical electrical components, but can also be used as a library of design elements (silkscreen logos, copper antennas and coils, etc.). Footprints can have pads which represent copper areas that are electrically-connected. The netlist will associate symbol pins with footprint pads.

A worksheet is a drawing template, typically containing a title block and frame, that is used as the template for schematic sheets and PCB drawings.

Plotting is the process of creating manufacturing outputs from a design. These outputs may include machine-readable formats such as Gerber files or pick-and-place listings, as well as human-readable formats such as PDF drawings.

Ngspice is a mixed-signal circuit simulator, originally based on Berkeley SPICE, that is integrated into KiCad’s schematic editor. By using symbols with attached SPICE models, you can run circuit simulations on KiCad schematics and plot the results graphically.

KiCad Components

KiCad consists of a number of different software components, some of which are integrated together to facilitate the PCB design workflow, and some of which are standalone. In early versions of KiCad, there was very little integration between the software components. For example, the schematic editor (historically called Eeschema) and PCB editor (historically called PcbNew) were separate applications that had no direct link, and to create a PCB based on a schematic, users had to generate a netlist file in Eeschema and then read this netlist file in PcbNew. In modern versions of KiCad, the schematic and PCB editor are integrated into the KiCad project manager, and using netlist files is no longer required. Many tutorials still exist that refer to the old KiCad workflow of separate applications and netlist files, so be sure to check the version being used when looking at tutorials and other documentation.

The main KiCad components are usually started from the launcher buttons in the KiCad project manager window. These components include:

Component name Description

Schematic Editor

Create and edit schematics; simulate circuits with SPICE; generate BOM files

Symbol Editor

Create and edit schematic symbols and manage symbol libraries

PCB Editor

Create and edit PCBs; export 2D and 3D files; generate fabrication output files

Footprint Editor

Create and edit PCB component footprints and manage footprint libraries


Gerber and drill file viewer


Convert bitmap images to symbols or footprints

PCB Calculator

Calculator for components, track width, electrical spacing, color codes, etc.

Page Layout Editor

Create and edit worksheet files

User Interface

KiCad has a number of user interface behaviors that are common to all the different editor windows. Some of these behaviors are described in more detail in later chapters of this manual.

Objects can be selected by clicking on them or by dragging a selection window around them. Dragging from left to right will result in a selection of any items that are completely within the window. Dragging from right to left will result in a selection of any items that touch the window. Pressing certain modifier keys while clicking or dragging will change the selection behavior. These keys are platform-specific and are described in the Editing Options section of the Preferences dialog.

KiCad editors have the concept of a tool which can be thought of as a mode that the editor is in. The default tool is the selection tool, which means that clicking will select objects under the mouse cursor as described above. There are also tools for placing new objects, inspecting existing objects, etc. The active tool is highlighted in the toolbar, and the name of the active tool is shown in the bottom right of the editor in the status bar. Pressing Esc always means "cancel" in KiCad: if a tool is in the middle of some action (for example, routing tracks), the first press of Esc will cancel that action. The next press of Esc will exit the tool complely, returning to the default selection tool. With the selection tool active, pressing kbd:Esc] will clear the current selection, if one exists.

KiCad Projects and Files

This section of the KiCad documentation has not yet been written. We appreciate your patience as our small team of volunteer documentation writers work to update and expand the documentation.
  • File types and project structure

  • Project workflow

  • Schematic <> PCB workflow

  • Standalone vs. project mode for schematic and PCB editors

Symbol and Footprint Libraries

This section of the KiCad documentation has not yet been written. We appreciate your patience as our small team of volunteer documentation writers work to update and expand the documentation.
  • Relationship between libraries and design files

  • Global vs project libraries

  • The KiCad library project (built-in global libraries)

Accessory Tools

This section of the KiCad documentation has not yet been written. We appreciate your patience as our small team of volunteer documentation writers work to update and expand the documentation.
  • GerbView

  • PCB Calculator

  • Bitmap2Component

  • Worksheet Editor (pl_editor)

Further Reading

The latest version of this manual can be found in multiple languages at Manuals for previous versions of KiCad can also be found at that website.

The KiCad user community includes a number of forums and chat platforms that are operated independently from the KiCad development team but are fully endorsed as a great way to find help with problems, learn tips and tricks, and share examples of KiCad projects. A listing of community resources is available under the Community heading at

Users interested in compiling KiCad from source and/or contributing to KiCad development should visit our developer documentation site at for instructions, policies and guidelines, and technical information about the KiCad codebase.