OpenFPGA/libs/libarchopenfpga/src/circuit_library.h

758 lines
38 KiB
C++

/* IMPORTANT:
* The following preprocessing flags are added to
* avoid compilation error when this headers are included in more than 1 times
*/
#ifndef CIRCUIT_LIBRARY_H
#define CIRCUIT_LIBRARY_H
/*
* Notes in include header files in a head file
* Only include the neccessary header files
* that is required by the data types in the function/class declarations!
*/
/* Header files should be included in a sequence */
/* Standard header files required go first */
#include <string>
#include "circuit_library_fwd.h"
#include "circuit_types.h"
#include "vtr_geometry.h"
#include "vtr_range.h"
#include "vtr_vector.h"
/************************************************************************
* The class CircuitLibrary is a critical data structure for OpenFPGA
* It stores all the circuit-level details from XML architecture file
*
* Typical usage:
* --------------
* // Create an empty circuit library
* CircuitLibrary circuit_lib;
* // call your builder for circuit library
* // Build the internal links for the circuit library
* circuit_lib.build_model_links();
* // Build the timing graph inside the circuit library
* circuit_lib.build_timing_graphs();
*
* It includes the following data:
*
* Fundamental Information
* -----------------------
* 1. model_ids_ : unique identifier to find a circuit model
* Use a strong id for search, to avoid illegal type
*casting
* 2. model_types_: types of the circuit model, see details in the definition of
*enum e_circuit_model_type
* 3. model_names_: unique names for each circuit models.
* It should be the same as user-defined Verilog
*modules, if it is not auto-generated
* 4. model_prefix_: the prefix of a circuit model when it is instanciated
* 5. verilog_netlist_: specified path and file name of Verilog netlist if a
*circuit model is not auto-generated
* 6. spice_netlist_: specified path and file name of CIRCUIT netlist if a
*circuit model is not auto-generated
* 7. is_default_: indicate if the circuit model is the default one among all
*those in the same type
* 8. sub_models_: the sub circuit models included by a circuit model. It is a
*collection of unique circuit model ids found in the CircuitModelId of
*pass-gate/buffers/port-related circuit models.
*
* ------ Fast look-ups-----
* 1. model_lookup_: A multi-dimension vector to provide fast look-up on
*circuit models for users It classifies CircuitModelIds by their type and set
*the default model in the first element for each type.
* 2. model_port_lookup_: A multi-dimension vector to provide fast look-up on
*ports of circuit models for users It classifies Ports by their types
*
* ------ Verilog generation options -----
* 1. dump_structural_verilog_: if Verilog generator will output structural
*Verilog syntax for the circuit model
* 2. dump_explicit_port_map_: if Verilog generator will use explicit port
*mapping when instanciate the circuit model
*
* ------ Design technology information -----
* 1. design_tech_types_: the design technology [cmos|rram] for each circuit
*model
* 2. is_power_gated_: specify if the circuit model is power-gated (contain a
*input to turn on/off VDD and GND)
*
* ------ Buffer existence -----
* Use vectors to simplify the defition of buffer existence:
* index (low=0 to high) represents INPUT, OUTPUT, LUT_INPUT_BUF,
*LUT_INPUT_INV, LUT_INTER_BUFFER
* 1. buffer_existence_: specify if this circuit model has an buffer
* 2. buffer_model_name_: specify the name of circuit model for the buffer
* 3. buffer_model_id_: specify the id of circuit model for the buffer
*
* ------ Pass-gate-related parameters ------
* 1. pass_gate_logic_model_name_: specify the name of circuit model for the
*pass gate logic
* 2. pass_gate_logic_model_id_: specify the id of circuit model for the pass
*gate logic
*
* ------ Port information ------
* - port_ids_: unique id of ports belonging to a circuit model
* - port_model_ids_: unique id of the parent circuit model for the port
* - port_types_: types of ports belonging to a circuit model
* - port_sizes_: width of ports belonging to a circuit model
* - port_prefix_: prefix of a port when instance of a circuit model
* - port_lib_names_: port name in the standard cell library, only used when
*explicit_port_mapping is enabled
* - port_inv_prefix_: the prefix to be added for the inverted port. This is
*mainly used by SRAM ports, which have an coupled inverterd port
* - port_is_mode_select: specify if this port is used to select operating modes
*of the circuit model
* - port_is_io: specify if this port is an io port
* - port_is_data_io: specify if this port is an io port that can be mapped to a
*signal from netlist
* - port_is_global: specify if this port is a global signal shared by other
*circuit model
* - port_is_reset: specify if this port is a reset signal which needs special
*pulse widths in testbenches
* - port_is_set: specify if this port is a set signal which needs special pulse
*widths in testbenches
* - port_is_config_enable: specify if this port is a config_enable signal which
*needs special pulse widths in testbenches
* - port_is_prog: specify if this port is for FPGA programming use which needs
*special pulse widths in testbenches
* - port_tri_state_model_name: the name of circuit model linked to tri-state
*the port
* - port_tri_state_model_ids_: the Id of circuit model linked to tri-state the
*port
* - port_inv_model_names_: the name of inverter circuit model linked to the
*port
* - port_inv_model_ids_: the Id of inverter circuit model linked to the port
* - port_tri_state_map_: only applicable to inputs of LUTs, the tri-state map
*applied to each pin of this port
* - port_lut_frac_level_: only applicable to outputs of LUTs, indicate which
*level of outputs inside LUT multiplexing structure will be used
* - port_lut_output_mask_: only applicable to outputs of LUTs, indicate which
*output at an internal level of LUT multiplexing structure will be used
* - port_sram_orgz_: only applicable to SRAM ports, indicate how the SRAMs will
*be organized, either memory decoders or scan-chains
*
* ------ Delay information ------
* 1. delay_types_: type of pin-to-pin delay, either rising_edge of falling_edge
* 2. delay_in_port_names_: name of input ports that the pin-to-pin delay is
*linked to
* 3. delay_in_port_names_: name of output ports that the pin-to-pin delay is
*linked to
* 4. delay_values_: delay values of the pin-to-pin delay
*
* ------ Timing graph information: TODO: consider using tatum? ------
* Timing graph is allocated when delay information is made
* 1. edge_ids_ : ids of edges in the timing graph
* 2. port_in_edge_ids_: ids of input edges for each pin of a circuit port
* 3. port_out_edge_ids_: ids of output edges for each pin of a circuit port
* 4. edge_src_port_ids_: ids of source ports that each edge is connected to
* 5. edge_src_pin_ids_: ids of source pin that each edge is connected to
* 6. edge_sink_port_ids_: ids of sink ports that each edge is connected to
* 7. edge_sink_pin_ids_: ids of sink pin that each edge is connected to
* 8. edge_trise_: rising delay of the edge
* 9. edge_tfall_: falling delay of the edge
*
* ------ Buffer/Inverter-related parameters ------
* Note: only applicable to circuit models whose type is buffer or inverter
* 1. buffer_types_: type of the buffer, either buffer or inverter
* 2. buffer_location_maps_: location of the buffer, only applicable to LUTs
* 3. buffer_sizes_: size of buffer (transistor size for the first stage)
* 4. buffer_is_tapered_: specify if this buffer has multiple stages
* 5. buffer_num_levels: specify the number of levels of this buffer (if this
*is defined as multi-level buffer)
* 6. buffer_f_per_stage: specify the driving strength of the buffer by stage
*
* ------ Pass-gate-logic-related parameters ------
* Note: only applicable to circuit models whose type is pass-gate-logic
* 1. pass_gate_logic_types_: types of the pass-gate-logic, either
*transmission-gate or pass-transistor
* 2. pass_gate_logic_nmos_sizes_: size of NMOS transistor in the
*pass-gate-logic
* 3. pass_gate_logic_pmos_sizes_: size of PMOS transistor in the
*pass-gate-logic, only applicable for transmission-gates
*
* ------ Multiplexer-related parameters ------
* Note: only applicable to circuit models whose type is MUX
* 1. mux_structure_: specify the structure of a multiplexer, one-level,
*multi-level or tree-like
* 2. mux_num_levels_: specify the number of levels for a multiplexer
* 3. mux_add_const_input_: specify if this multiplexer has a constant input
* 4. mux_const_input_values_: specify the value of the constant input for this
*multiplexer (valid only when mux_add_const_input is true)
* 5. mux_use_local_encoder_: specify if the mux as a local encoder between
*SRAMs and multiplexing structure
* 6. mux_advanced_rram_design_: specify if the multiplexer will use advanced
*RRAM circuit design topology
*
* ------ LUT-related parameters ------
* Note: only applicable to circuit models whose type is LUT
* 1. lut_is_fracturable_: specify if this LUT is built with fracturable
*structure
*
* ------ RRAM-related parameters ------
* Note: only applicable to circuit models whose design technology is RRAM
* 1. rlrs: RRAM resistance in Low-Resistance State (LRS)
* 2. rhrs: RRAM resistance in High-Resistance State (HRS)
* The following transistor sizes are applicable for 4T1R programming
*structures
* 3. wprog_set_nmos: size of n-type programming transistor used to set a RRAM
* 4. wprog_set_pmos: size of p-type programming transistor used to set a RRAM
* 5. wprog_reset_nmos: size of n-type programming transistor used to reset a
*RRAM
* 6. wprog_reset_pmos: size of p-type programming transistor used to reset a
*RRAM
*
* ------ Metal wire-related parameters ------
* Note: only applicable to circuit models whose type is wires or channel wires
* 1. wire_types_: types of the metal wire for the model
* 2. wire_res_val_: resistance value of the metal wire for the circuit model
* 3. wire_cap_val_: capacitance value of the metal wire for the circuit model
* 4. wire_num_levels_: number of levels of the metal wire model for the circuit
*model
***********************************************************************/
class CircuitLibrary {
public: /* Types */
typedef vtr::vector<CircuitModelId, CircuitModelId>::const_iterator
circuit_model_iterator;
typedef vtr::vector<CircuitModelId, std::string>::const_iterator
circuit_model_string_iterator;
typedef vtr::vector<CircuitPortId, CircuitPortId>::const_iterator
circuit_port_iterator;
typedef vtr::vector<CircuitEdgeId, CircuitEdgeId>::const_iterator
circuit_edge_iterator;
/* Create range */
typedef vtr::Range<circuit_model_iterator> circuit_model_range;
typedef vtr::Range<circuit_port_iterator> circuit_port_range;
typedef vtr::Range<circuit_edge_iterator> circuit_edge_range;
/* local enumeration for buffer existence */
enum e_buffer_type : unsigned char {
INPUT = 0,
OUTPUT,
LUT_INPUT_BUFFER,
LUT_INPUT_INVERTER,
LUT_INTER_BUFFER,
NUM_BUFFER_TYPE /* Last one is a counter */
};
public: /* Constructors */
CircuitLibrary();
public: /* Accessors: aggregates */
circuit_model_range models() const;
circuit_port_range ports() const;
std::vector<CircuitModelId> models_by_type(
const enum e_circuit_model_type& type) const;
public: /* Public Accessors: Basic data query on Circuit Models*/
size_t num_models() const;
enum e_circuit_model_type model_type(const CircuitModelId& model_id) const;
std::string model_name(const CircuitModelId& model_id) const;
std::string model_prefix(const CircuitModelId& model_id) const;
std::string model_verilog_netlist(const CircuitModelId& model_id) const;
std::string model_spice_netlist(const CircuitModelId& model_id) const;
bool model_is_default(const CircuitModelId& model_id) const;
bool dump_structural_verilog(const CircuitModelId& model_id) const;
bool dump_explicit_port_map(const CircuitModelId& model_id) const;
/* Design technology information */
enum e_circuit_model_design_tech design_tech_type(
const CircuitModelId& model_id) const;
bool is_power_gated(const CircuitModelId& model_id) const;
/* Device technology information */
std::string device_model_name(const CircuitModelId& model_id) const;
/* General buffer information */
bool is_input_buffered(const CircuitModelId& model_id) const;
bool is_output_buffered(const CircuitModelId& model_id) const;
/* LUT-related information */
bool is_lut_intermediate_buffered(const CircuitModelId& model_id) const;
bool is_lut_fracturable(const CircuitModelId& model_id) const;
CircuitModelId lut_input_buffer_model(const CircuitModelId& model_id) const;
CircuitModelId lut_input_inverter_model(const CircuitModelId& model_id) const;
CircuitModelId lut_intermediate_buffer_model(
const CircuitModelId& model_id) const;
std::string lut_intermediate_buffer_location_map(
const CircuitModelId& model_id) const;
/* Pass-gate-logic information */
CircuitModelId pass_gate_logic_model(const CircuitModelId& model_id) const;
std::string pass_gate_logic_model_name(const CircuitModelId& model_id) const;
enum e_circuit_model_pass_gate_logic_type pass_gate_logic_type(
const CircuitModelId& model_id) const;
float pass_gate_logic_pmos_size(const CircuitModelId& model_id) const;
float pass_gate_logic_nmos_size(const CircuitModelId& model_id) const;
/* Multiplexer information */
enum e_circuit_model_structure mux_structure(
const CircuitModelId& model_id) const;
size_t mux_num_levels(const CircuitModelId& model_id) const;
bool mux_add_const_input(const CircuitModelId& model_id) const;
size_t mux_const_input_value(const CircuitModelId& model_id) const;
bool mux_use_local_encoder(const CircuitModelId& model_id) const;
bool mux_use_advanced_rram_design(const CircuitModelId& model_id) const;
/* Gate information */
enum e_circuit_model_gate_type gate_type(
const CircuitModelId& model_id) const;
/* Buffer information */
enum e_circuit_model_buffer_type buffer_type(
const CircuitModelId& model_id) const;
size_t buffer_size(const CircuitModelId& model_id) const;
size_t buffer_num_levels(const CircuitModelId& model_id) const;
size_t buffer_f_per_stage(const CircuitModelId& model_id) const;
CircuitModelId input_buffer_model(const CircuitModelId& model_id) const;
CircuitModelId output_buffer_model(const CircuitModelId& model_id) const;
/* Delay information */
size_t num_delay_info(const CircuitModelId& model_id) const;
/* Wire parameters */
e_wire_model_type wire_type(const CircuitModelId& model_id) const;
float wire_r(const CircuitModelId& model_id) const;
float wire_c(const CircuitModelId& model_id) const;
size_t wire_num_level(const CircuitModelId& model_id) const;
/* RRAM information */
float rram_rlrs(const CircuitModelId& model_id) const;
float rram_rhrs(const CircuitModelId& model_id) const;
float rram_wprog_set_pmos(const CircuitModelId& model_id) const;
float rram_wprog_set_nmos(const CircuitModelId& model_id) const;
float rram_wprog_reset_pmos(const CircuitModelId& model_id) const;
float rram_wprog_reset_nmos(const CircuitModelId& model_id) const;
public
: /* Public Accessors: Basic data query on cirucit models' Circuit Ports*/
CircuitPortId model_port(const CircuitModelId& model_id,
const std::string& name) const;
size_t num_model_ports(const CircuitModelId& model_id) const;
size_t num_model_ports_by_type(
const CircuitModelId& model_id,
const enum e_circuit_model_port_type& port_type,
const bool& include_global_port) const;
std::vector<CircuitPortId> model_ports(const CircuitModelId& model_id) const;
std::vector<CircuitPortId> model_global_ports(const CircuitModelId& model_id,
const bool& recursive) const;
std::vector<CircuitPortId> model_global_ports_by_type(
const CircuitModelId& model_id, const enum e_circuit_model_port_type& type,
const bool& recursive,
const std::vector<enum e_circuit_model_type>& ignore_model_types) const;
std::vector<CircuitPortId> model_global_ports_by_type(
const CircuitModelId& model_id,
const std::vector<enum e_circuit_model_port_type>& type,
const bool& recursive, const bool& ignore_config_memories) const;
std::vector<CircuitPortId> model_global_ports_by_type(
const CircuitModelId& model_id, const enum e_circuit_model_port_type& type,
const bool& recursive, const bool& ignore_config_memories) const;
std::vector<CircuitPortId> model_ports_by_type(
const CircuitModelId& model_id,
const enum e_circuit_model_port_type& port_type) const;
std::vector<CircuitPortId> model_ports_by_type(
const CircuitModelId& model_id,
const enum e_circuit_model_port_type& port_type,
const bool& include_global_port) const;
std::vector<CircuitPortId> model_input_ports(
const CircuitModelId& model_id) const;
std::vector<CircuitPortId> model_output_ports(
const CircuitModelId& model_id) const;
std::vector<size_t> pins(const CircuitPortId& circuit_port_id) const;
public: /* Public Accessors: Basic data query on Circuit Ports*/
bool is_input_port(const CircuitPortId& circuit_port_id) const;
bool is_output_port(const CircuitPortId& circuit_port_id) const;
enum e_circuit_model_port_type port_type(
const CircuitPortId& circuit_port_id) const;
size_t port_size(const CircuitPortId& circuit_port_id) const;
std::string port_prefix(const CircuitPortId& circuit_port_id) const;
std::string port_lib_name(const CircuitPortId& circuit_port_id) const;
std::string port_inv_prefix(const CircuitPortId& circuit_port_id) const;
size_t port_default_value(const CircuitPortId& circuit_port_id) const;
bool port_is_io(const CircuitPortId& circuit_port_id) const;
bool port_is_data_io(const CircuitPortId& circuit_port_id) const;
bool port_is_mode_select(const CircuitPortId& circuit_port_id) const;
bool port_is_global(const CircuitPortId& circuit_port_id) const;
bool port_is_reset(const CircuitPortId& circuit_port_id) const;
bool port_is_set(const CircuitPortId& circuit_port_id) const;
bool port_is_config_enable(const CircuitPortId& circuit_port_id) const;
bool port_is_prog(const CircuitPortId& circuit_port_id) const;
bool port_is_shift_register(const CircuitPortId& circuit_port_id) const;
size_t port_lut_frac_level(const CircuitPortId& circuit_port_id) const;
bool port_is_harden_lut_port(const CircuitPortId& circuit_port_id) const;
std::vector<size_t> port_lut_output_mask(
const CircuitPortId& circuit_port_id) const;
std::string port_tri_state_map(const CircuitPortId& circuit_port_id) const;
CircuitModelId port_tri_state_model(
const CircuitPortId& circuit_port_id) const;
std::string port_tri_state_model_name(
const CircuitPortId& circuit_port_id) const;
CircuitModelId port_parent_model(const CircuitPortId& circuit_port_id) const;
std::string model_name(const CircuitPortId& port_id) const;
std::string port_inv_model_name(const CircuitPortId& circuit_port_id) const;
public: /* Public Accessors: Timing graph */
/* Get source/sink nodes and delay of edges */
std::vector<CircuitEdgeId> timing_edges_by_model(
const CircuitModelId& model_id) const;
CircuitPortId timing_edge_src_port(const CircuitEdgeId& edge) const;
size_t timing_edge_src_pin(const CircuitEdgeId& edge) const;
CircuitPortId timing_edge_sink_port(const CircuitEdgeId& edge) const;
size_t timing_edge_sink_pin(const CircuitEdgeId& edge) const;
float timing_edge_delay(
const CircuitEdgeId& edge,
const enum e_circuit_model_delay_type& delay_type) const;
public: /* Public Accessors: Methods to find circuit model */
CircuitModelId model(const char* name) const;
CircuitModelId model(const std::string& name) const;
CircuitModelId default_model(const enum e_circuit_model_type& type) const;
public: /* Public Accessors: Timing graph */
CircuitEdgeId edge(const CircuitPortId& from_port, const size_t from_pin,
const CircuitPortId& to_port, const size_t to_pin);
public: /* Public Mutators */
CircuitModelId add_model(const enum e_circuit_model_type& type);
/* Fundamental information */
void set_model_name(const CircuitModelId& model_id, const std::string& name);
void set_model_prefix(const CircuitModelId& model_id,
const std::string& prefix);
void set_model_verilog_netlist(const CircuitModelId& model_id,
const std::string& verilog_netlist);
void set_model_spice_netlist(const CircuitModelId& model_id,
const std::string& spice_netlist);
void set_model_is_default(const CircuitModelId& model_id,
const bool& is_default);
/* Verilog generator options */
void set_model_dump_structural_verilog(const CircuitModelId& model_id,
const bool& dump_structural_verilog);
void set_model_dump_explicit_port_map(const CircuitModelId& model_id,
const bool& dump_explicit_port_map);
/* Design technology information */
void set_model_design_tech_type(
const CircuitModelId& model_id,
const enum e_circuit_model_design_tech& design_tech_type);
void set_model_is_power_gated(const CircuitModelId& model_id,
const bool& is_power_gated);
/* Design technology information */
void set_device_model_name(const CircuitModelId& model_id,
const std::string& name);
/* Buffer existence */
void set_model_input_buffer(const CircuitModelId& model_id,
const bool& existence,
const std::string& model_name);
void set_model_output_buffer(const CircuitModelId& model_id,
const bool& existence,
const std::string& model_name);
void set_model_lut_input_buffer(const CircuitModelId& model_id,
const bool& existence,
const std::string& model_name);
void set_model_lut_input_inverter(const CircuitModelId& model_id,
const bool& existence,
const std::string& model_name);
void set_model_lut_intermediate_buffer(const CircuitModelId& model_id,
const bool& existence,
const std::string& model_name);
void set_model_lut_intermediate_buffer_location_map(
const CircuitModelId& model_id, const std::string& location_map);
/* Pass-gate-related parameters */
void set_model_pass_gate_logic(const CircuitModelId& model_id,
const std::string& model_name);
/* Port information */
CircuitPortId add_model_port(const CircuitModelId& model_id,
const enum e_circuit_model_port_type& port_type);
void set_port_size(const CircuitPortId& circuit_port_id,
const size_t& port_size);
void set_port_prefix(const CircuitPortId& circuit_port_id,
const std::string& port_prefix);
void set_port_lib_name(const CircuitPortId& circuit_port_id,
const std::string& lib_name);
void set_port_inv_prefix(const CircuitPortId& circuit_port_id,
const std::string& inv_prefix);
void set_port_default_value(const CircuitPortId& circuit_port_id,
const size_t& default_val);
void set_port_is_io(const CircuitPortId& circuit_port_id, const bool& is_io);
void set_port_is_data_io(const CircuitPortId& circuit_port_id,
const bool& is_data_io);
void set_port_is_mode_select(const CircuitPortId& circuit_port_id,
const bool& is_mode_select);
void set_port_is_global(const CircuitPortId& circuit_port_id,
const bool& is_global);
void set_port_is_reset(const CircuitPortId& circuit_port_id,
const bool& is_reset);
void set_port_is_set(const CircuitPortId& circuit_port_id,
const bool& is_set);
void set_port_is_config_enable(const CircuitPortId& circuit_port_id,
const bool& is_config_enable);
void set_port_is_prog(const CircuitPortId& circuit_port_id,
const bool& is_prog);
void set_port_is_shift_register(const CircuitPortId& circuit_port_id,
const bool& is_shift_register);
void set_port_tri_state_model_name(const CircuitPortId& circuit_port_id,
const std::string& model_name);
void set_port_tri_state_model_id(const CircuitPortId& circuit_port_id,
const CircuitModelId& port_model_id);
void set_port_inv_model_name(const CircuitPortId& circuit_port_id,
const std::string& inv_model_name);
void set_port_inv_model_id(const CircuitPortId& circuit_port_id,
const CircuitModelId& inv_model_id);
void set_port_tri_state_map(const CircuitPortId& circuit_port_id,
const std::string& tri_state_map);
void set_port_lut_frac_level(const CircuitPortId& circuit_port_id,
const size_t& lut_frac_level);
void set_port_is_harden_lut_port(const CircuitPortId& circuit_port_id,
const bool& is_harden_lut_port);
void set_port_lut_output_mask(const CircuitPortId& circuit_port_id,
const std::vector<size_t>& lut_output_masks);
void set_port_sram_orgz(const CircuitPortId& circuit_port_id,
const enum e_config_protocol_type& sram_orgz);
/* Delay information */
void add_delay_info(const CircuitModelId& model_id,
const enum e_circuit_model_delay_type& delay_type);
void set_delay_in_port_names(
const CircuitModelId& model_id,
const enum e_circuit_model_delay_type& delay_type,
const std::string& in_port_names);
void set_delay_out_port_names(
const CircuitModelId& model_id,
const enum e_circuit_model_delay_type& delay_type,
const std::string& out_port_names);
void set_delay_values(const CircuitModelId& model_id,
const enum e_circuit_model_delay_type& delay_type,
const std::string& delay_values);
/* Buffer/Inverter-related parameters */
void set_buffer_type(const CircuitModelId& model_id,
const enum e_circuit_model_buffer_type& buffer_type);
void set_buffer_size(const CircuitModelId& model_id,
const float& buffer_size);
void set_buffer_num_levels(const CircuitModelId& model_id,
const size_t& num_levels);
void set_buffer_f_per_stage(const CircuitModelId& model_id,
const size_t& f_per_stage);
/* Pass-gate-related parameters */
void set_pass_gate_logic_type(
const CircuitModelId& model_id,
const enum e_circuit_model_pass_gate_logic_type& pass_gate_logic_type);
void set_pass_gate_logic_nmos_size(const CircuitModelId& model_id,
const float& nmos_size);
void set_pass_gate_logic_pmos_size(const CircuitModelId& model_id,
const float& pmos_size);
/* Multiplexer-related parameters */
void set_mux_structure(const CircuitModelId& model_id,
const enum e_circuit_model_structure& mux_structure);
void set_mux_num_levels(const CircuitModelId& model_id,
const size_t& num_levels);
void set_mux_const_input_value(const CircuitModelId& model_id,
const size_t& const_input_value);
void set_mux_use_local_encoder(const CircuitModelId& model_id,
const bool& use_local_encoder);
void set_mux_use_advanced_rram_design(const CircuitModelId& model_id,
const bool& use_advanced_rram_design);
/* LUT-related parameters */
void set_lut_is_fracturable(const CircuitModelId& model_id,
const bool& is_fracturable);
/* Gate-related parameters */
void set_gate_type(const CircuitModelId& model_id,
const enum e_circuit_model_gate_type& gate_type);
/* RRAM-related design technology information */
void set_rram_rlrs(const CircuitModelId& model_id, const float& rlrs);
void set_rram_rhrs(const CircuitModelId& model_id, const float& rhrs);
void set_rram_wprog_set_nmos(const CircuitModelId& model_id,
const float& wprog_set_nmos);
void set_rram_wprog_set_pmos(const CircuitModelId& model_id,
const float& wprog_set_pmos);
void set_rram_wprog_reset_nmos(const CircuitModelId& model_id,
const float& wprog_reset_nmos);
void set_rram_wprog_reset_pmos(const CircuitModelId& model_id,
const float& wprog_reset_pmos);
/* Wire parameters */
void set_wire_type(const CircuitModelId& model_id,
const enum e_wire_model_type& wire_type);
void set_wire_r(const CircuitModelId& model_id, const float& r_val);
void set_wire_c(const CircuitModelId& model_id, const float& c_val);
void set_wire_num_level(const CircuitModelId& model_id,
const size_t& num_level);
private: /* Private Mutators: builders */
void set_model_buffer(const CircuitModelId& model_id,
const enum e_buffer_type buffer_type,
const bool& existence, const std::string& model_name);
void link_port_tri_state_model();
void link_port_inv_model();
void link_buffer_model(const CircuitModelId& model_id);
void link_pass_gate_logic_model(const CircuitModelId& model_id);
bool is_unique_submodel(const CircuitModelId& model_id,
const CircuitModelId& submodel_id);
void build_model_timing_graph(const CircuitModelId& model_id);
void build_submodels();
public: /* Public Mutators: builders */
void build_model_links();
void build_timing_graphs();
/* Automatically identify the default models for each type,
* suggest to do this after circuit library is built
*/
void auto_detect_default_models();
public: /* Internal mutators: build timing graphs */
void add_edge(const CircuitModelId& model_id, const CircuitPortId& from_port,
const size_t& from_pin, const CircuitPortId& to_port,
const size_t& to_pin);
void set_edge_delay(const CircuitModelId& model_id,
const CircuitEdgeId& circuit_edge_id,
const enum e_circuit_model_delay_type& delay_type,
const float& delay_value);
/* validate the circuit_edge_id */
void set_timing_graph_delays(const CircuitModelId& model_id);
public: /* Internal mutators: build fast look-ups */
void build_model_lookup();
void build_model_port_lookup();
public: /* Public invalidators/validators */
bool valid_model_id(const CircuitModelId& model_id) const;
bool valid_circuit_port_id(const CircuitPortId& circuit_port_id) const;
bool valid_circuit_pin_id(const CircuitPortId& circuit_port_id,
const size_t& pin_id) const;
private: /* Internal invalidators/validators */
/* Validators */
bool valid_edge_id(const CircuitEdgeId& edge_id) const;
bool valid_delay_type(
const CircuitModelId& model_id,
const enum e_circuit_model_delay_type& delay_type) const;
bool valid_circuit_edge_id(const CircuitEdgeId& circuit_edge_id) const;
bool valid_mux_const_input_value(const size_t& const_input_value) const;
/* Invalidators */
void invalidate_model_lookup() const;
void invalidate_model_port_lookup() const;
void invalidate_model_timing_graph();
private: /* Internal data */
/* Fundamental information */
vtr::vector<CircuitModelId, CircuitModelId> model_ids_;
vtr::vector<CircuitModelId, enum e_circuit_model_type> model_types_;
vtr::vector<CircuitModelId, std::string> model_names_;
vtr::vector<CircuitModelId, std::string> model_prefix_;
vtr::vector<CircuitModelId, std::string> model_verilog_netlists_;
vtr::vector<CircuitModelId, std::string> model_spice_netlists_;
vtr::vector<CircuitModelId, bool> model_is_default_;
/* Submodules that a circuit model contains */
vtr::vector<CircuitModelId, std::vector<CircuitModelId>> sub_models_;
/* fast look-up for circuit models to categorize by types
* [type][num_ids]
* Important: we force the default circuit model in the first element for each
* type
*/
typedef std::vector<std::vector<CircuitModelId>> CircuitModelLookup;
mutable CircuitModelLookup model_lookup_; /* [model_type][model_ids] */
typedef vtr::vector<CircuitModelId, std::vector<std::vector<CircuitPortId>>>
CircuitModelPortLookup;
mutable CircuitModelPortLookup
model_port_lookup_; /* [model_id][port_type][port_ids] */
/* Verilog generator options */
vtr::vector<CircuitModelId, bool> dump_structural_verilog_;
vtr::vector<CircuitModelId, bool> dump_explicit_port_map_;
/* Design technology information */
vtr::vector<CircuitModelId, enum e_circuit_model_design_tech>
design_tech_types_;
vtr::vector<CircuitModelId, bool> is_power_gated_;
/* Device technology information */
vtr::vector<CircuitModelId, std::string> device_model_names_;
/* Buffer existence */
vtr::vector<CircuitModelId, std::vector<bool>> buffer_existence_;
vtr::vector<CircuitModelId, std::vector<std::string>> buffer_model_names_;
vtr::vector<CircuitModelId, std::vector<CircuitModelId>> buffer_model_ids_;
vtr::vector<CircuitModelId, std::vector<std::string>> buffer_location_maps_;
/* Pass-gate-related parameters */
vtr::vector<CircuitModelId, std::string> pass_gate_logic_model_names_;
vtr::vector<CircuitModelId, CircuitModelId> pass_gate_logic_model_ids_;
/* Port information */
vtr::vector<CircuitPortId, CircuitPortId> port_ids_;
vtr::vector<CircuitPortId, CircuitModelId> port_model_ids_;
vtr::vector<CircuitPortId, enum e_circuit_model_port_type> port_types_;
vtr::vector<CircuitPortId, size_t> port_sizes_;
vtr::vector<CircuitPortId, std::string> port_prefix_;
vtr::vector<CircuitPortId, std::string> port_lib_names_;
vtr::vector<CircuitPortId, std::string> port_inv_prefix_;
vtr::vector<CircuitPortId, size_t> port_default_values_;
vtr::vector<CircuitPortId, bool> port_is_io_;
vtr::vector<CircuitPortId, bool> port_is_data_io_;
vtr::vector<CircuitPortId, bool> port_is_mode_select_;
vtr::vector<CircuitPortId, bool> port_is_global_;
vtr::vector<CircuitPortId, bool> port_is_reset_;
vtr::vector<CircuitPortId, bool> port_is_set_;
vtr::vector<CircuitPortId, bool> port_is_config_enable_;
vtr::vector<CircuitPortId, bool> port_is_prog_;
vtr::vector<CircuitPortId, bool> port_is_shift_register_;
vtr::vector<CircuitPortId, std::string> port_tri_state_model_names_;
vtr::vector<CircuitPortId, CircuitModelId> port_tri_state_model_ids_;
vtr::vector<CircuitPortId, std::string> port_inv_model_names_;
vtr::vector<CircuitPortId, CircuitModelId> port_inv_model_ids_;
vtr::vector<CircuitPortId, std::string> port_tri_state_maps_;
vtr::vector<CircuitPortId, size_t> port_lut_frac_level_;
vtr::vector<CircuitPortId, bool> port_is_harden_lut_port_;
vtr::vector<CircuitPortId, std::vector<size_t>> port_lut_output_masks_;
vtr::vector<CircuitPortId, enum e_config_protocol_type> port_sram_orgz_;
/* Timing graphs */
vtr::vector<CircuitEdgeId, CircuitEdgeId> edge_ids_;
vtr::vector<CircuitEdgeId, CircuitModelId> edge_parent_model_ids_;
vtr::vector<CircuitPortId, vtr::vector<size_t, CircuitEdgeId>>
port_in_edge_ids_;
vtr::vector<CircuitPortId, vtr::vector<size_t, CircuitEdgeId>>
port_out_edge_ids_;
vtr::vector<CircuitEdgeId, CircuitPortId> edge_src_port_ids_;
vtr::vector<CircuitEdgeId, size_t> edge_src_pin_ids_;
vtr::vector<CircuitEdgeId, CircuitPortId> edge_sink_port_ids_;
vtr::vector<CircuitEdgeId, size_t> edge_sink_pin_ids_;
vtr::vector<CircuitEdgeId, std::vector<float>>
edge_timing_info_; /* x0 => trise, x1 => tfall */
/* Delay information */
vtr::vector<CircuitModelId, std::vector<enum e_circuit_model_delay_type>>
delay_types_;
vtr::vector<CircuitModelId, std::vector<std::string>> delay_in_port_names_;
vtr::vector<CircuitModelId, std::vector<std::string>> delay_out_port_names_;
vtr::vector<CircuitModelId, std::vector<std::string>> delay_values_;
/* Buffer/Inverter-related parameters */
vtr::vector<CircuitModelId, enum e_circuit_model_buffer_type> buffer_types_;
vtr::vector<CircuitModelId, float> buffer_sizes_;
vtr::vector<CircuitModelId, size_t> buffer_num_levels_;
vtr::vector<CircuitModelId, size_t> buffer_f_per_stage_;
/* Pass-gate-related parameters */
vtr::vector<CircuitModelId, enum e_circuit_model_pass_gate_logic_type>
pass_gate_logic_types_;
vtr::vector<CircuitModelId, vtr::Point<float>>
pass_gate_logic_sizes_; /* x=> nmos_size; y => pmos_size */
/* Multiplexer-related parameters */
vtr::vector<CircuitModelId, enum e_circuit_model_structure> mux_structure_;
vtr::vector<CircuitModelId, size_t> mux_num_levels_;
vtr::vector<CircuitModelId, size_t> mux_const_input_values_;
vtr::vector<CircuitModelId, bool> mux_use_local_encoder_;
vtr::vector<CircuitModelId, bool> mux_use_advanced_rram_design_;
/* LUT-related parameters */
vtr::vector<CircuitModelId, bool> lut_is_fracturable_;
/* Gate-related parameters */
vtr::vector<CircuitModelId, enum e_circuit_model_gate_type> gate_types_;
/* RRAM-related design technology information */
vtr::vector<CircuitModelId, vtr::Point<float>>
rram_res_; /* x => R_LRS, y => R_HRS */
vtr::vector<CircuitModelId, vtr::Point<float>>
wprog_set_; /* x => wprog_set_nmos, y=> wprog_set_pmos */
vtr::vector<CircuitModelId, vtr::Point<float>>
wprog_reset_; /* x => wprog_reset_nmos, y=> wprog_reset_pmos */
/* Wire parameters */
vtr::vector<CircuitModelId, enum e_wire_model_type> wire_types_;
vtr::vector<CircuitModelId, vtr::Point<float>>
wire_rc_; /* x => wire_res_val, y=> wire_cap_val */
vtr::vector<CircuitModelId, size_t> wire_num_levels_;
};
#endif