OpenFPGA/openfpga/src/fpga_spice/spice_submodule.cpp

52 lines
1.8 KiB
C++
Raw Normal View History

2020-07-05 13:10:12 -05:00
/*********************************************************************
* This file includes top-level function to generate Spice primitive modules
* and print them to files
********************************************************************/
/* Headers from vtrutil library */
#include "vtr_assert.h"
#include "vtr_log.h"
2020-07-05 15:50:29 -05:00
/* Headers from openfpgashell library */
#include "command_exit_codes.h"
2020-07-05 13:10:12 -05:00
#include "spice_essential_gates.h"
#include "spice_constants.h"
#include "spice_submodule.h"
/* begin namespace openfpga */
namespace openfpga {
/*********************************************************************
* Top-level function to generate primitive modules:
* 1. Transistor wrapper
* 2. TODO: Logic gates: AND/OR, inverter, buffer and transmission-gate/pass-transistor
* 3. TODO: Routing multiplexers
* 4. TODO: Local encoders for routing multiplexers
* 5. TODO: Wires
* 6. TODO: Configuration memory blocks
********************************************************************/
2020-07-05 15:50:29 -05:00
int print_spice_submodule(NetlistManager& netlist_manager,
const ModuleManager& module_manager,
const Arch& openfpga_arch,
2020-07-05 15:50:29 -05:00
const std::string& submodule_dir) {
int status = CMD_EXEC_SUCCESS;
status = print_spice_transistor_wrapper(netlist_manager,
openfpga_arch.tech_lib,
2020-07-05 15:50:29 -05:00
submodule_dir);
2020-07-05 13:10:12 -05:00
status = print_spice_essential_gates(netlist_manager,
module_manager,
openfpga_arch.circuit_lib,
openfpga_arch.tech_lib,
openfpga_arch.circuit_tech_binding,
submodule_dir);
2020-07-05 15:50:29 -05:00
return status;
2020-07-05 13:10:12 -05:00
}
} /* end namespace openfpga */