Saturday, July 20, 2024

Kicad 8--Importing Designs From Eagle

 


The "ditch Eagle for Kicad" post is turning into one of my most viewed.  

In that post (here) I briefly described importing files from Eagle format to Kicad. 

Kicad Version 7 could ingest most Eagle data into a Kicad Project but not all of it. 

Nevertheless, importing a subset of my Eagle data into a new Kicad project was easier and less time consuming than recreating the entire project from scratch.  

Good news! With Kicad 8 all the data needed for a new Kicad project can be imported from Eagle. This is hugely beneficial for anyone ditching Eagle for Kicad.

Since adopting Kicad I have imported frequently....I felt the steps deserved their own post to help me work efficiently. If this post is useful for you as well, even better! However, if you have no need to import Eagle data into Kicad your time is arguably better spent watching these guys--have at it.

GETTING STARTED

For this example I am importing a simple Eagle project with 4x Thonkiconn jacks and a few wirepads.

First up: I needed a name for the new Kicad project. 

I made up a name. It could have been anything: Big Fun With Small Jacks, Bored with Inserting, etc. 

But instead I got pedantic: "mono 4x1 mixer Euro Jacks".

With the new project name in hand I made copies of the .sch and .brd files I needed to import from Eagle; I left the original Eagle files as-is.

I created a new directory in my Kicad root folder called "Mono 4x1 mixer source files from Eagle".  

Then, I pasted the copies of the Eagle .sch and .brd source files into this new directory and renamed the Eagle .sch to .brd files to filenames I want to use for the new Kicad project. 

Copy the .brd and .sch files from Kicad to an newly created empty "source" directory. 


LET'S IMPORT!

In Kicad 8:

I created a new project for Kicad named "mono 4x 1 mixer Euro Jacks"

Next I opened its empty schematic (*.kicad_sch) file. 

file > import non-Kicad Project... > Eagle Project...

I navigated to the original Eagle .sch file and imported.

Viola, a Kicad schematic! I found some cleanup was needed, but, this was usable.
 
Footprint assignments--needed to match the schematic's symbols to the PCB's footprints--were auto-populated by this import:


To create the PCB, I clicked on the PCB icon at the top of Kicad, then file > import non-Kicad board file and picked the Eagle PCB that matched the schematic.

I was asked if I wanted to auto-match layers. I had no idea how layer matching worked, so I just said "auto-match layers" and "OK".  Good enough.


A "pretty" (footprint) and "sym" (symbol) file were created; Kicad creates a new library of the devices brought in from Eagle:

These objects could be opened, edited, and imported into a custom libraries, details in the post here

Easy right? After following these steps, I had all the files needed for the Kicad Project:

For your Kicad_pcb fabrication needs please check out PCBWAY, this blog's sponsor


 

COOKING WITH OIL....

From here I had everything I needed to get working. 

So, really, this was all easy!

New sch file--just like what I had for Eagle!


New footprint file!



EDITING SYMBOLS AND FOOTPRINTS 

Kicad's stock footprints and symbols are completely different than Eagle's. But we are importing footprints and symbols--called "Devices" in Eagle, into Kicad.

As mentioned above, Kicad's developers solved this problem by creating a custom library of symbols and footprints for each imported Eagle project. 

This is clever, and works, but, unedited the footprints and to a lesser degree symbols imported from Eagle into Kicad often threw errors and warnings during the Inspection/DRC process when I used Kicad DRC with default constraints.  

Therefore I usually DRC'd the imported sch and brd Kicad Kicad then edited the imported parts:
  • Creating Courtyards.  Footprints imported from Eagle didn't have them but Kicad wants 'em as a best practice. Courtyards for imported footprints have to be created by hand, so what the heck, I edited the imported footprints and added them. Not technically necessary I figure, but, if I started moving things around I figured courtyards were a good thing to have.
  • Making Eagle fonts Kicad friendly.  Kicad wants footprint fonts to be .8mm or larger.  Imported fonts from Eagle can be smaller. 
  • Easy fix: I edited the footprint with the offending text, selected the text causing DRC issues, hit the magic e key, and changed the font width and height to .8mm or greater.
  • I saved the footprint.  
  • Then, I reimported the updated footprint from its library into the PCB.
  • Silkscreen madness: Eagle allows overlaps of silks and other silkscreening oddities that its default DRC doesn't catch but Kicad's does. 
  • To ameliorate: I edited the footprint, getting rid of or relocating silkscreen artwork that was causing Kicad's DRC to throw errors and warnings. I saved the updated footprint to my custom Kicad footprint library then reimported the updated part into my design. 
  • Pin name Changes: this now seems obvious but I missed it at first. 
  • For my own edification: I should never expect pin assignments from Eagle to match much of anything in Kicad. 
  • Using imported footprints and symbols in a single new imported project worked, but as soon as I used the part in a different project things occasionally broke. 
  • Meaning: traces to cathodes went to anodes, traces to transistor emitters went to collectors, traces to a pot wiper went to something other than a wiper--all bad news.
  • Modifying symbols and devices from Eagle to work universally in Kicad required a bit of forethought and elbow grease. Diodes in Kicad needed pin 2 for anodes and pin 1 for cathodes, for example, as this seems semi-standard for Kicad. 
  • I found I needed to carefully examine imported footprints and symbols, then edit them to make them work for a given future design. No easy fix for this, I had to do this extra work or not use an imported Eagle footprint beyond its initial project.
  • (BTW: for me--everything I think might be useful for future projects goes in my github custom footprint and symbol repos--e.g., my footprint custom library can be found on Github--here)
Following these steps created an added benefit: my Eagle "devices" folder has 20+ years of useful footprints and symbols, some I imported, others I modified and/or created, with a teeth gnashingly frustrating degree of difficulty

Since the Eagle > Kicad import process brings over these custom devices I could further modify them, then save them to my Kicad libraries--steps to import footprint data into a custom Kicad library are here; github of my Kicad Symbol and Footprint libraries are here and here.

This meant: all my custom devices in Eagle could be preserved without too much difficulty. Whew! 

SCHEMATIC- AND BOARD-ONLY IMPORTS

I was not just limited to importing an entire Eagle schematic and board as already described.  

If I created a new KICAD 8 project and opened the new/blank Kicad_sch file I could file > import only an Eagle .sch schematic.  

The associated symbol library came over, but the process ignored the .brd (board) data. 

From there I could assign existing Kicad footprints and create a new PCB layout as with any other Kicad project.

I could import only a BRD file in the same manner but I am not sure how helpful that would be--I'd next need to create a new schematic with its associations from scratch, which I figured might prove difficult.  

However, I then import footprints from the associated .pretty folder created from the Eagle board-only import.
 

OUTTRO

With a bit of patience and attention to detail the Eagle > Kicad import process works--GREAT.  

Kudos to the Kicad development team, they must have spent hours and hours getting this import process to work; their time and hard work has already saved me hours and hours doing schematic capture and layout "from scratch."

And this is a guess but: I figure the documentation for Eagle's API sucked, since most Eagle documentation sucks. 

I would wager the Kicad coders implementing the Eagle > Kicad import algorithms had to wade through endless reams of crap documentation and employ a fair degree of trial and error to get the imports to work....since in my experience anything touching Eagle means figuratively embracing the collective works of Kafka.  

They figured it out!  

The best things in life really are free--the exception is vintage Roland. Kicad RULES!


No comments:

Post a Comment

Crimping JST-XH connectors--a Quick How-To

 It's a beautiful Spring day, instead of going out and enjoying it, I am teaching myself how to crimp and create JST-XH connectors. I b...