2020-01-15 21:28:04 -06:00
|
|
|
#ifndef OPENFPGA_ARCH_H
|
|
|
|
#define OPENFPGA_ARCH_H
|
2020-01-12 23:39:38 -06:00
|
|
|
|
2020-01-19 15:44:27 -06:00
|
|
|
#include <map>
|
2022-10-06 19:08:50 -05:00
|
|
|
#include <vector>
|
2020-01-19 15:44:27 -06:00
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
#include "arch_direct.h"
|
2020-01-12 23:39:38 -06:00
|
|
|
#include "circuit_library.h"
|
2020-01-18 22:19:20 -06:00
|
|
|
#include "config_protocol.h"
|
2020-01-25 22:19:08 -06:00
|
|
|
#include "pb_type_annotation.h"
|
2022-10-06 19:08:50 -05:00
|
|
|
#include "technology_library.h"
|
|
|
|
#include "tile_annotation.h"
|
2020-01-12 23:39:38 -06:00
|
|
|
|
2020-01-16 21:22:56 -06:00
|
|
|
/* namespace openfpga begins */
|
|
|
|
namespace openfpga {
|
|
|
|
|
2020-01-12 23:39:38 -06:00
|
|
|
/* A unified data structure to store circuit-level settings,
|
|
|
|
* including circuit library, technology library and simulation parameters
|
2020-01-19 15:44:27 -06:00
|
|
|
*
|
2022-10-06 19:08:50 -05:00
|
|
|
* Note:
|
2020-01-19 15:44:27 -06:00
|
|
|
* Once this struct is built by function read_xml_openfpga_arch()
|
|
|
|
* It should be READ-ONLY! Any modification should not be applied later
|
|
|
|
* This is to keep everything well modularized
|
2020-01-12 23:39:38 -06:00
|
|
|
*/
|
2020-01-16 21:22:56 -06:00
|
|
|
struct Arch {
|
2020-01-19 15:44:27 -06:00
|
|
|
/* Circuit models */
|
2020-01-12 23:39:38 -06:00
|
|
|
CircuitLibrary circuit_lib;
|
2022-10-06 19:08:50 -05:00
|
|
|
|
2020-01-19 15:44:27 -06:00
|
|
|
/* Technology devices */
|
2020-01-17 17:44:57 -06:00
|
|
|
TechnologyLibrary tech_lib;
|
2020-01-19 15:44:27 -06:00
|
|
|
|
2020-07-13 21:35:10 -05:00
|
|
|
/* Binding between circuit models and technology models */
|
2022-10-06 19:08:50 -05:00
|
|
|
std::map<CircuitModelId, TechnologyModelId> circuit_tech_binding;
|
2020-07-13 21:35:10 -05:00
|
|
|
|
2020-01-19 15:44:27 -06:00
|
|
|
/* Configuration protocol settings */
|
2020-01-18 22:19:20 -06:00
|
|
|
ConfigProtocol config_protocol;
|
2020-01-19 15:44:27 -06:00
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
/* Mapping from the names of routing switches
|
|
|
|
* to circuit models in circuit library
|
2020-01-19 15:44:27 -06:00
|
|
|
*/
|
|
|
|
std::map<std::string, CircuitModelId> cb_switch2circuit;
|
|
|
|
std::map<std::string, CircuitModelId> sb_switch2circuit;
|
|
|
|
|
|
|
|
/* Mapping from the names of routing segments
|
2022-10-06 19:08:50 -05:00
|
|
|
* to circuit models in circuit library
|
2020-01-19 15:44:27 -06:00
|
|
|
*/
|
|
|
|
std::map<std::string, CircuitModelId> routing_seg2circuit;
|
2020-01-19 16:00:19 -06:00
|
|
|
|
|
|
|
/* Mapping from the names of direct connection
|
2022-10-06 19:08:50 -05:00
|
|
|
* to circuit models in circuit library
|
2020-01-19 16:00:19 -06:00
|
|
|
*/
|
2020-02-14 18:40:59 -06:00
|
|
|
ArchDirect arch_direct;
|
2020-01-25 22:19:08 -06:00
|
|
|
|
2020-11-10 15:32:24 -06:00
|
|
|
/* Physical tile annotations:
|
|
|
|
* Global port definition for tile ports
|
2022-10-06 19:08:50 -05:00
|
|
|
*/
|
2020-11-10 15:32:24 -06:00
|
|
|
TileAnnotation tile_annotations;
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
/* Pb type annotations
|
2020-01-25 22:19:08 -06:00
|
|
|
* Bind from operating to physical
|
|
|
|
* Bind from physical to circuit model
|
|
|
|
*/
|
|
|
|
std::vector<PbTypeAnnotation> pb_type_annotations;
|
2020-01-12 23:39:38 -06:00
|
|
|
};
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
} // namespace openfpga
|
2020-01-16 21:22:56 -06:00
|
|
|
|
2020-01-12 23:39:38 -06:00
|
|
|
#endif
|