2020-01-23 14:24:35 -06:00
|
|
|
#ifndef OPENFPGA_CONTEXT_H
|
|
|
|
#define OPENFPGA_CONTEXT_H
|
|
|
|
|
2020-02-26 12:09:23 -06:00
|
|
|
#include <vector>
|
2020-01-23 20:10:53 -06:00
|
|
|
#include "vpr_context.h"
|
2020-01-23 14:24:35 -06:00
|
|
|
#include "openfpga_arch.h"
|
2020-01-29 18:49:33 -06:00
|
|
|
#include "vpr_netlist_annotation.h"
|
2020-02-12 10:52:18 -06:00
|
|
|
#include "vpr_device_annotation.h"
|
2020-02-05 22:50:52 -06:00
|
|
|
#include "vpr_clustering_annotation.h"
|
2020-02-24 17:09:29 -06:00
|
|
|
#include "vpr_placement_annotation.h"
|
2020-02-05 22:50:52 -06:00
|
|
|
#include "vpr_routing_annotation.h"
|
2020-02-12 15:58:23 -06:00
|
|
|
#include "mux_library.h"
|
2020-02-14 23:21:32 -06:00
|
|
|
#include "tile_direct.h"
|
2020-02-12 18:53:23 -06:00
|
|
|
#include "module_manager.h"
|
2020-02-15 21:38:45 -06:00
|
|
|
#include "openfpga_flow_manager.h"
|
2020-02-23 00:04:42 -06:00
|
|
|
#include "bitstream_manager.h"
|
2020-02-11 17:37:14 -06:00
|
|
|
#include "device_rr_gsb.h"
|
2020-02-26 18:10:57 -06:00
|
|
|
#include "io_location_map.h"
|
2020-01-23 14:24:35 -06:00
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* This file includes the declaration of the date structure
|
|
|
|
* OpenfpgaContext, which is used for data exchange between
|
|
|
|
* different modules in OpenFPGA shell environment
|
|
|
|
*
|
|
|
|
* If a command of OpenFPGA needs to exchange data with other commands,
|
|
|
|
* it must use this data structure to access/mutate.
|
|
|
|
* In such case, you must add data structures to OpenfpgaContext
|
|
|
|
*
|
|
|
|
* Note:
|
|
|
|
* Please respect to the following rules when using the OpenfpgaContext
|
|
|
|
* 1. This data structure will be created only once in the main() function
|
|
|
|
* The data structure is design to be large and contain all the
|
|
|
|
* data structure required by each module of OpenFPGA core engine.
|
|
|
|
* Do NOT create or duplicate in your own module!
|
|
|
|
* 2. Be clear in your mind if you want to access/mutate the data inside OpenfpgaContext
|
|
|
|
* Read-only data should be accessed by
|
|
|
|
* const OpenfpgaContext&
|
|
|
|
* Mutate should use reference
|
|
|
|
* OpenfpgaContext&
|
|
|
|
* 3. Please keep the definition of OpenfpgaContext short
|
|
|
|
* Do put ONLY well-modularized data structure under this root.
|
2020-01-23 20:10:53 -06:00
|
|
|
* 4. We build this data structure based on the Context from VPR
|
|
|
|
* which does NOT allow users to copy the internal members
|
|
|
|
* This is due to that the data structures in the OpenFPGA context
|
|
|
|
* are typically big in terms of memory
|
2020-01-23 14:24:35 -06:00
|
|
|
*******************************************************************/
|
2020-01-23 20:10:53 -06:00
|
|
|
class OpenfpgaContext : public Context {
|
|
|
|
public: /* Public accessors */
|
|
|
|
const openfpga::Arch& arch() const { return arch_; }
|
2020-02-12 10:52:18 -06:00
|
|
|
const openfpga::VprDeviceAnnotation& vpr_device_annotation() const { return vpr_device_annotation_; }
|
2020-01-29 18:49:33 -06:00
|
|
|
const openfpga::VprNetlistAnnotation& vpr_netlist_annotation() const { return vpr_netlist_annotation_; }
|
2020-02-05 22:50:52 -06:00
|
|
|
const openfpga::VprClusteringAnnotation& vpr_clustering_annotation() const { return vpr_clustering_annotation_; }
|
2020-02-24 17:09:29 -06:00
|
|
|
const openfpga::VprPlacementAnnotation& vpr_placement_annotation() const { return vpr_placement_annotation_; }
|
2020-02-05 22:50:52 -06:00
|
|
|
const openfpga::VprRoutingAnnotation& vpr_routing_annotation() const { return vpr_routing_annotation_; }
|
2020-02-11 17:37:14 -06:00
|
|
|
const openfpga::DeviceRRGSB& device_rr_gsb() const { return device_rr_gsb_; }
|
2020-02-12 15:58:23 -06:00
|
|
|
const openfpga::MuxLibrary& mux_lib() const { return mux_lib_; }
|
2020-02-14 23:21:32 -06:00
|
|
|
const openfpga::TileDirect& tile_direct() const { return tile_direct_; }
|
2020-02-12 18:53:23 -06:00
|
|
|
const openfpga::ModuleManager& module_graph() const { return module_graph_; }
|
2020-02-15 21:38:45 -06:00
|
|
|
const openfpga::FlowManager& flow_manager() const { return flow_manager_; }
|
2020-02-23 00:04:42 -06:00
|
|
|
const openfpga::BitstreamManager& bitstream_manager() const { return bitstream_manager_; }
|
2020-02-26 12:09:23 -06:00
|
|
|
const std::vector<openfpga::ConfigBitId>& fabric_bitstream() const { return fabric_bitstream_; }
|
2020-03-02 18:58:44 -06:00
|
|
|
const openfpga::IoLocationMap& io_location_map() const { return io_location_map_; }
|
|
|
|
const std::unordered_map<AtomNetId, t_net_power>& net_activity() const { return net_activity_; }
|
2020-01-23 20:10:53 -06:00
|
|
|
public: /* Public mutators */
|
|
|
|
openfpga::Arch& mutable_arch() { return arch_; }
|
2020-02-12 10:52:18 -06:00
|
|
|
openfpga::VprDeviceAnnotation& mutable_vpr_device_annotation() { return vpr_device_annotation_; }
|
2020-01-29 18:49:33 -06:00
|
|
|
openfpga::VprNetlistAnnotation& mutable_vpr_netlist_annotation() { return vpr_netlist_annotation_; }
|
2020-02-05 22:50:52 -06:00
|
|
|
openfpga::VprClusteringAnnotation& mutable_vpr_clustering_annotation() { return vpr_clustering_annotation_; }
|
2020-02-24 17:09:29 -06:00
|
|
|
openfpga::VprPlacementAnnotation& mutable_vpr_placement_annotation() { return vpr_placement_annotation_; }
|
2020-02-05 22:50:52 -06:00
|
|
|
openfpga::VprRoutingAnnotation& mutable_vpr_routing_annotation() { return vpr_routing_annotation_; }
|
2020-02-11 17:37:14 -06:00
|
|
|
openfpga::DeviceRRGSB& mutable_device_rr_gsb() { return device_rr_gsb_; }
|
2020-02-12 15:58:23 -06:00
|
|
|
openfpga::MuxLibrary& mutable_mux_lib() { return mux_lib_; }
|
2020-02-14 23:21:32 -06:00
|
|
|
openfpga::TileDirect& mutable_tile_direct() { return tile_direct_; }
|
2020-02-12 18:53:23 -06:00
|
|
|
openfpga::ModuleManager& mutable_module_graph() { return module_graph_; }
|
2020-02-15 21:38:45 -06:00
|
|
|
openfpga::FlowManager& mutable_flow_manager() { return flow_manager_; }
|
2020-02-23 00:04:42 -06:00
|
|
|
openfpga::BitstreamManager& mutable_bitstream_manager() { return bitstream_manager_; }
|
2020-02-26 12:09:23 -06:00
|
|
|
std::vector<openfpga::ConfigBitId>& mutable_fabric_bitstream() { return fabric_bitstream_; }
|
2020-02-26 18:10:57 -06:00
|
|
|
openfpga::IoLocationMap& mutable_io_location_map() { return io_location_map_; }
|
2020-02-29 14:29:16 -06:00
|
|
|
std::unordered_map<AtomNetId, t_net_power>& mutable_net_activity() { return net_activity_; }
|
2020-01-23 20:10:53 -06:00
|
|
|
private: /* Internal data */
|
2020-01-23 14:24:35 -06:00
|
|
|
/* Data structure to store information from read_openfpga_arch library */
|
|
|
|
openfpga::Arch arch_;
|
2020-02-11 17:37:14 -06:00
|
|
|
|
2020-01-27 16:31:12 -06:00
|
|
|
/* Annotation to pb_type of VPR */
|
2020-02-12 10:52:18 -06:00
|
|
|
openfpga::VprDeviceAnnotation vpr_device_annotation_;
|
2020-02-11 17:37:14 -06:00
|
|
|
|
2020-01-29 18:49:33 -06:00
|
|
|
/* Naming fix to netlist */
|
|
|
|
openfpga::VprNetlistAnnotation vpr_netlist_annotation_;
|
2020-02-11 17:37:14 -06:00
|
|
|
|
2020-02-14 23:21:32 -06:00
|
|
|
/* Pin net fix to cluster results */
|
2020-02-05 22:50:52 -06:00
|
|
|
openfpga::VprClusteringAnnotation vpr_clustering_annotation_;
|
2020-02-11 17:37:14 -06:00
|
|
|
|
2020-02-24 17:09:29 -06:00
|
|
|
/* Placement results */
|
|
|
|
openfpga::VprPlacementAnnotation vpr_placement_annotation_;
|
|
|
|
|
2020-02-11 17:37:14 -06:00
|
|
|
/* Routing results annotation */
|
2020-02-05 22:50:52 -06:00
|
|
|
openfpga::VprRoutingAnnotation vpr_routing_annotation_;
|
2020-02-11 17:37:14 -06:00
|
|
|
|
|
|
|
/* Device-level annotation */
|
|
|
|
openfpga::DeviceRRGSB device_rr_gsb_;
|
2020-02-12 15:58:23 -06:00
|
|
|
|
|
|
|
/* Library of physical implmentation of routing multiplexers */
|
|
|
|
openfpga::MuxLibrary mux_lib_;
|
2020-02-12 18:53:23 -06:00
|
|
|
|
2020-02-14 23:21:32 -06:00
|
|
|
/* Inner/inter-column/row tile direct connections */
|
|
|
|
openfpga::TileDirect tile_direct_;
|
|
|
|
|
2020-02-12 18:53:23 -06:00
|
|
|
/* Fabric module graph */
|
|
|
|
openfpga::ModuleManager module_graph_;
|
2020-02-26 18:10:57 -06:00
|
|
|
openfpga::IoLocationMap io_location_map_;
|
2020-02-23 00:04:42 -06:00
|
|
|
|
|
|
|
/* Bitstream database */
|
|
|
|
openfpga::BitstreamManager bitstream_manager_;
|
2020-02-26 12:09:23 -06:00
|
|
|
std::vector<openfpga::ConfigBitId> fabric_bitstream_;
|
2020-02-29 14:29:16 -06:00
|
|
|
|
|
|
|
/* Net activities of users' implementation */
|
|
|
|
std::unordered_map<AtomNetId, t_net_power> net_activity_;
|
2020-02-15 21:38:45 -06:00
|
|
|
|
|
|
|
/* Flow status */
|
|
|
|
openfpga::FlowManager flow_manager_;
|
2020-01-23 14:24:35 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|