GithubHelp home page GithubHelp logo

isabella232 / proton Goto Github PK

View Code? Open in Web Editor NEW

This project forked from efabless/proton

0.0 0.0 0.0 42.49 MB

License: GNU Affero General Public License v3.0

Perl 80.90% Makefile 1.16% Tcl 0.02% Roff 1.30% Perl 6 0.70% Mask 0.02% C++ 6.07% Objective-C 1.50% Terra 2.16% C 5.37% PostScript 0.10% PLSQL 0.06% Turing 0.65%

proton's Introduction

  /--------------------------------------------------------------------------------------\
  |	                                                                               	|
  |     Proton is a full feature hierarchical ASIC place and route system          	|
  |			Copyright (C) 2014 - 2018  efabless corporation			|
  |	                                                                               	|
  |      This program is free software: you can redistribute it and/or modify      	|
  |          it under the terms of the GNU Affero General Public License           	|
  |        as published by the Free Software Foundation, Version 3.                	|
  |	                                                                               	|
  |       This program is distributed in the hope that it will be useful,          	|
  |       but WITHOUT ANY WARRANTY; without even the implied warranty of           	|
  |       MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the            	|
  |            GNU Affero General Public License for more details.                 	|
  |	                                                                               	|
  |    You should have received a copy of the GNU Affero General Public License    	|
  |     along with this program.  If not, see <https://www.gnu.org/licenses/>.     	|
  |	                                                                               	|
  |       <https://github.com/efabless/proton/blob/master/LICENSE.txt/>            	|
  |             <https://www.gnu.org/licenses/agpl-3.0.en.html/>                   	|
  |                                                                                	|
  \--------------------------------------------------------------------------------------/

Proton : ASIC Place and Route Suite

This is a framework for ASIC Place and Route. It uses other open source tools like Iverilog, Yosys, Gray Wolf and Qrouter as engines. Proton provides a platform to import and export chip data in standard formats ( LEF / DEF/ Verilog / GDS2 ). Proton is written in perl and uses many of the packages available on CPAN. The GUI is written in Perl-TK.

Getting Started

clone the latest code from this git repository. You will need to install Iverilog, Yosys, Graywolf and Qrouter separately on your system. Install the perl packages needed by proton from CPAN. set the following environment variables

export $PROTON_HOME=/<your-install-dir>/proton
cd $PROTON_HOME
./UTILS/make_tool

Proton can be invoked using the following commands export PATH=$PROTON_HOME:$PATH

: proton                    ===> launches proton in shell mode
: proton --nolog --win      ===> launches proton in GUI mode
: proton --help             ===> prints the launch help message
: proton -f run.tcl         ===> executes the commands in run.tcl and returns to shell prompt

By default, proton open in non-gui mode. To open GUI from shell mode type "win" or "gui"

Supported formats

Most of the popular backend ASIC file formats are supported. LEF, DEF, RTL ( Verilog 2005) , gate-level verilog, Spef etc are supported.

Features

Proton has the many of the features of commercial Place and Route tools. We are developing many more actively and ask for community help in giving us feedback and also pitchin to help develop new features Currently following features have been tested to work

import/read LEF(5.7) , DEF, gate level verilog ( hierarchical and flat), GDS2 export/write LEF, DEF, gate level verilog, GDS2

RTL Simulation
Gate level simulation
Synthesis
Interactive Floorplan
Hierarchical Floorplan and Partition Pin Assignment
Power Plan
Placement
Signal Routing

Use Model

Proton can be used in following modes

digital block implementation
Hierarchical partitining
digital block modelling for use in mixed signal designs 

Limitations

Proton has been used on many designs in tapeout mode but requires some understanding of the steps of the flow. It is not a push button tool yet. It offers complete flexibility to manage the design data and in some cases can allow users to delete objects/ instances and nets that can cause design logic to change. It also has limitation on the size of design it can handle , mostly limited by the placement and routing engines used inside the tool. It can be worked around by using proton in a hierarchical flow.

Pure Digital and Mixed Signal designs are handled well in proton. It is not geared to handle Multi Billion transistor SOCs flat. But with some ingenuity, a large design can be pushed through proton system using hierarchical implementation flow.

Contact GitHub API Training Shop Blog About © 2016 GitHub, Inc. Terms Privacy Security Status Help

proton's People

Contributors

collabchip avatar kassemmkk avatar mera-desh-mahan avatar mkkassem avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.