A design-driven partitioning algorithm for distributed verilog simulation

L Li, C Tropper - 21st International Workshop on Principles of …, 2007 - ieeexplore.ieee.org
L Li, C Tropper
21st International Workshop on Principles of Advanced and …, 2007ieeexplore.ieee.org
Many partitioning algorithms have been proposed for distributed VLSI simulation. Typically,
they make use of a gate level netlist, and attempt to achieve a minimal cut size subject to a
load balance constraint. The algorithm executes on a hypergraph which represents the
netlist. In this paper we propose a design-driven iterative partitioning algorithm for Verilog
based on module instances instead of gates. We do this in order to take advantage of the
design hierarchy information contained in the modules and their instances. A Verilog …
Many partitioning algorithms have been proposed for distributed VLSI simulation. Typically, they make use of a gate level netlist, and attempt to achieve a minimal cut size subject to a load balance constraint. The algorithm executes on a hypergraph which represents the netlist. In this paper we propose a design-driven iterative partitioning algorithm for Verilog based on module instances instead of gates. We do this in order to take advantage of the design hierarchy information contained in the modules and their instances. A Verilog instance represents one vertex in the circuit hypergraph. The vertex can be flattened into multiple vertices in the event that a load balance is not achieved by instance based partitioning. In this case the algorithm flattens the largest instance and moves gates between the partitions in order to improve the load balance. Our experiments show that this partitioning algorithm produces a smaller cutsize than is produced by hmetis on a gate-level netlist. It produces better speedup for the simulation because it takes advantage of the design hierarchy.
ieeexplore.ieee.org