Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
start [2022/08/01 19:06] – [ACT language] rajitstart [2025/01/23 10:01] (current) – [Installation] rajit
Line 3: Line 3:
 Welcome to the Wiki for the ACT suite of VLSI design tools. ACT is an **A**synchronous **C**ircuit **T**oolkit which has been built from scratch to support the design and implementation of asynchronous logic. While that is the main goal, some of the tools we have developed have also been used for designing synchronous logic. These tools have been developed primarily by [[http://csl.yale.edu/~rajit/|Rajit Manohar]] and his [[http://avlsi.csl.yale.edu/|research group]], and have a long [[history:|history]]. Welcome to the Wiki for the ACT suite of VLSI design tools. ACT is an **A**synchronous **C**ircuit **T**oolkit which has been built from scratch to support the design and implementation of asynchronous logic. While that is the main goal, some of the tools we have developed have also been used for designing synchronous logic. These tools have been developed primarily by [[http://csl.yale.edu/~rajit/|Rajit Manohar]] and his [[http://avlsi.csl.yale.edu/|research group]], and have a long [[history:|history]].
  
 +When an existing open-source tool used by mainstream chip designers can be re-purposed for asynchronous design without major issues (in terms of functionality as well as error-prone behavior), we re-use it. Examples include layout editors (e.g. ''magic''), switch-level simulators (e.g. ''irsim''), and analog simulators (e.g. ''Xyce'').
 ===== Asynchronous design ===== ===== Asynchronous design =====
  
   * [[tutorial:|Tutorials and class materials]]   * [[tutorial:|Tutorials and class materials]]
 +  * [[asic:start|ACT ASIC flow]]
  
 +===== Installation =====
 +
 +If you are interested in building the tools from scratch:
 +
 +      * [[install_actflow|actflow]]: use this if you want the full set of tools.
 +      * [[install|ACT]]: use this if you only want the core language and some basic tools for custom circuit design. The [[install_actflow|actflow build]] installs this repository as well.
 +
 +We also have a [[summer2024:dockersetup|docker container]] that contains the tools, if you'd like to try them out without installing them on your system.
 ===== ACT language ===== ===== ACT language =====
  
-  * [[install|Installing and building ACT]]+The ACT language combined with a set of configuration files are used when designing circuits. The configuration files control some basic ACT behavior, and also include technology-specific information (e.g. what is the feature size, what are the transistor types available in the technology, etc.) 
 + 
   * [[language:|Language reference]], and a [[language:migrate|migration guide]] from the older version of ACT.   * [[language:|Language reference]], and a [[language:migrate|migration guide]] from the older version of ACT.
   * [[config:|ACT configuration files]] needed for a new technology.   * [[config:|ACT configuration files]] needed for a new technology.
 +  * [[config:runtime|ACT runtime configuration]], used to adjust the operation of the core ACT library and/or passes.
   * [[history:|Language history/lineage]]   * [[history:|Language history/lineage]]
  
-==== ACT library ====+===== ACT library ====
 + 
 +In addition to the core language, we also provide some standard ACT libraries that include common definitions/etc. for designing asynchronous circuits.
  
   * [[stdlib:|Standard library]]   * [[stdlib:|Standard library]]
-  * [[lib:|Using the ACT library]]+  * [[sim:|Simulation library]], installed together with [[tools:actsim|actsim]]; It provides tools for simulation and verification 
 + 
 +For those interested in writing tools, we have some documentation available for the core ACT library and data structures.
  
-==== Tools ====+  * [[http://avlsi.csl.yale.edu/act_docs/|Using the ACT library]] (work in progress!) 
 +  * [[guide:|Guide to using ACT data structures]] 
 +  * [[guide:makefile|Guide to using the standard Makefiles in ACT]] 
 +===== Tools =====
  
   * [[stdoptions:|Command-line options]] and environment variables that are common for all core ACT tools   * [[stdoptions:|Command-line options]] and environment variables that are common for all core ACT tools
   * [[tools:|Individual tools]]   * [[tools:|Individual tools]]
 +  * [[asic:start|ASIC flow]]