capture
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
capture [2017/09/07 05:06] – mcmaster | capture [2025/03/26 20:02] (current) – mcmaster | ||
---|---|---|---|
Line 27: | Line 27: | ||
Tools that rely on standard cells or other regular layout | Tools that rely on standard cells or other regular layout | ||
+ | |||
+ | [[https:// | ||
===== ARES ===== | ===== ARES ===== | ||
By Olivier Thomas / Texplained | By Olivier Thomas / Texplained | ||
+ | |||
+ | {{: | ||
[[https:// | [[https:// | ||
Line 62: | Line 66: | ||
===== Degate ===== | ===== Degate ===== | ||
- | {{: | + | [[https:// |
- | [[http://www.degate.org/screenshots/degate-port_colors.png|Source]] | + | ==== The project ==== |
+ | |||
+ | [[https://github.com/DegateCommunity/Degate|Degate]] is a multi-platform software for semi-automatic VLSI reverse engineering of digital logic in chips. It is the highest profile FOSS tool, with tutorials and other stuff available. | ||
+ | |||
+ | ==== Little history ==== | ||
+ | |||
+ | Degate was actively developed by Martin Schobert, during his thesis, from 2008 to 2011. For now, the project is inactive and only get some small fixes since 2011. The project is composed of a library (libGate) and a GUI interface (Degate). | ||
+ | |||
+ | In 2016 it was said here: | ||
+ | |||
+ | "'' | ||
+ | |||
+ | Degate has definitely a great potential, mainly because it is the only free and open-source software for hardware reverse engineering of chips, but never knew how to impose itself in the community. One possible reason for that is because Degate was known to be unstable and have impacting bugs in a first place. | ||
+ | |||
+ | You can visit the initial project website to learn more: | ||
[[http:// | [[http:// | ||
- | The highest profile FOSS tool. | + | ==== Current status ==== |
+ | |||
+ | In 2019, I ([[https:// | ||
+ | |||
+ | The stability was the main problem of the old Degate and the main reason why the community hadn't already united around it. Regarding that, we want to have fewer bugs as possible, even if some functionality needs to be dropped (for the moment). | ||
+ | |||
+ | A lot of bugs were fixed in this newer version, | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | \\ | ||
+ | |||
+ | [[https:// | ||
+ | |||
+ | [[https:// | ||
+ | |||
+ | [[https:// | ||
+ | |||
+ | |||
+ | ===== Deroute ===== | ||
+ | |||
+ | https:// | ||
+ | |||
+ | IIRC there was a Degate rewrite. Is this is? | ||
+ | |||
+ | |||
+ | ====== bsim ====== | ||
+ | |||
+ | [[https:// | ||
- | Users have noted significant stability issues. I (JM) tried tool again in 2016 and noted considerable stability improvements, but still had it crash on me before I was able to get any results. | + | Implements the following paper algos. Provides aggregation |
Line 80: | Line 126: | ||
===== pr0nsweeper ===== | ===== pr0nsweeper ===== | ||
- | An experimental semi-automated polygon capture tool for chips using lambda rules (grid layout) | + | {{pr0ntools: |
+ | An experimental crowdsourced semi-automated polygon capture tool for chips using lambda rules (grid layout) | ||
+ | |||
+ | [[https:// | ||
+ | |||
+ | Above: Playstation 1 CPU top metal test using confocal microscope | ||
===== psxdev ===== | ===== psxdev ===== | ||
+ | |||
+ | {{: | ||
[[https:// | [[https:// | ||
Line 93: | Line 146: | ||
For the most part people use Inkscape, gimp, or photoshop with it mostly being personal preference which tool you use | For the most part people use Inkscape, gimp, or photoshop with it mostly being personal preference which tool you use | ||
+ | |||
+ | ===== Automated methods ===== | ||
+ | |||
+ | A number of people have tried but IMHO nobody has beat manual methods yet: | ||
+ | * Robert B: experimented with using neural networks to capture 7400 series chips. Promising, but last I saw needs more testing | ||
+ | * John M: misc tests. Main result was that active layer should be feasible if delayered | ||
+ | * Ken S: tried some things, but think didn't get far | ||
+ | * Visual 6502: don't recall details except that they claimed although they could get some automated, it took more time to fix mistakes than it would to do from scratch | ||
+ | * [[https:// | ||
+ | |||
===== Inkscape ===== | ===== Inkscape ===== | ||
Line 140: | Line 203: | ||
- | ===== Automated methods | + | ===== Visual 6502 tool ===== |
- | A number of people have tried but IMHO nobody has beat manual methods yet: | + | {{:v6502:capture:visual6502_editor.png?400|}} |
- | * Robert B: experimented with using neural networks to capture | + | |
- | * John M: misc tests. Main result was that active layer should be feasible if delayered | + | |
- | * Ken S: tried some things, but think didn't get far | + | |
- | * Visual 6502: don't recall details except that they claimed although they could get some automated, it took more time to fix mistakes than it would to do from scratch | + | |
- | + | {{: | |
- | ===== Visual 6502 ===== | + | |
Internal python tool to help draw polygons. | Internal python tool to help draw polygons. | ||
- | They also explored automation | + | ====== Netlist extraction ====== |
+ | |||
+ | A lot of people roll their own for this and that | ||
+ | |||
+ | ===== dietools ===== | ||
+ | |||
+ | https:// | ||
+ | |||
+ | " | ||
+ | |||
+ | A few people use this one, so its arguably the most popular | ||
+ | |||
+ | ===== polychip ===== | ||
+ | |||
+ | https:// | ||
+ | |||
+ | " | ||
+ | |||
+ | ===== magic ===== | ||
+ | |||
+ | Magic VLSI, along with many other semi tools, should have something of this sort | ||
+ | |||
+ | |||
+ | ====== References ====== | ||
+ | * Reverse Engineering Digital Circuits Using Functional Analysis (Pramod Subramanyan): | ||
capture.1504760775.txt.gz · Last modified: 2017/09/07 05:06 by mcmaster