OpenFPGA/abc/src/phys/place
tangxifan 4e3487b691 Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
..
Makefile Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
README Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
hpwl Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
libhmetis.h Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
module.make Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_base.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_base.h Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_bin.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_genqp.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_gordian.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_gordian.h Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_inc.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_io.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_legalize.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_pads.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_partition.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_qpsolver.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_qpsolver.h Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00
place_test.c Add latest abc and update ace dependence 2019-05-03 18:56:03 -06:00

README

/*===================================================================*/
//  
// GORDIAN-like placement package
//
//              Aaron P. Hurst (ahurst@eecs.berkeley.edu)
//              Addl code from Philip Chong (pchong@cadence.com)
//              hMetis partitioner (www.cs.umn.edu/~metis)
//
/*===================================================================*/

1. Requirements

An i386 Linux system (though others will certainly work with some tweaks).
A standard ANSI C development platform.  

The following are optional, but useful:

- hMetis partitioner.  This can be obtained from (www.cs.umn.edu/~metis)
    Place (links to) the files "libhmetis.a" and "libhtmetis.h" in this directory.
    Otherwise, #define NO_HMETIS in the file "place_gordian.h"
- Java SDK, if compiling BookshelfView is desired.
- Perl, if additional script utilities are desired.

2. Descriptions of contents:

place_base.h contains the basic data structures and "external" API.
place_gordian.h contains the "internal" API and configuration options.

There are also several utilities:

i) place_test 

Reads a netlist description in GSRC Bookshelf format, performs global placement,
and rewrites the placement file.  An example usage:

./place_test ac97_emap.nodes ac97_emap.nets ac97_emap.pl

ii) BookshelfView

A simple Java GUI to view the resulting placements.  It has been tested with
Java 5 and 6.  Usage:

java BookshelfView ac97_emap.nodes ac97_emap.pl

iii) hpwl

A perl script to print the half-perimeter wirelength of a placement.  Usage:

./hpwl ac97_emap.nets ac97_emal.pl