2020-01-27 16:31:12 -06:00
|
|
|
/********************************************************************
|
|
|
|
* This file includes functions to read an OpenFPGA architecture file
|
|
|
|
* which are built on the libarchopenfpga library
|
|
|
|
*******************************************************************/
|
|
|
|
/* Headers from vtrutil library */
|
2020-01-27 21:40:18 -06:00
|
|
|
#include "vtr_time.h"
|
2020-01-27 18:43:22 -06:00
|
|
|
#include "vtr_assert.h"
|
2020-01-27 16:31:12 -06:00
|
|
|
#include "vtr_log.h"
|
|
|
|
|
2020-02-12 10:52:18 -06:00
|
|
|
#include "vpr_device_annotation.h"
|
2020-01-27 18:43:22 -06:00
|
|
|
#include "pb_type_utils.h"
|
2020-01-28 16:13:14 -06:00
|
|
|
#include "annotate_pb_types.h"
|
2020-01-28 22:59:10 -06:00
|
|
|
#include "annotate_pb_graph.h"
|
2020-02-05 22:50:52 -06:00
|
|
|
#include "annotate_routing.h"
|
2020-02-11 17:37:14 -06:00
|
|
|
#include "annotate_rr_gsb.h"
|
2020-01-27 16:31:12 -06:00
|
|
|
#include "openfpga_link_arch.h"
|
|
|
|
|
|
|
|
/* Include global variables of VPR */
|
|
|
|
#include "globals.h"
|
|
|
|
|
|
|
|
/* begin namespace openfpga */
|
|
|
|
namespace openfpga {
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Top-level function to link openfpga architecture to VPR, including:
|
|
|
|
* - physical pb_type
|
2020-01-28 16:13:14 -06:00
|
|
|
* - mode selection bits for pb_type and pb interconnect
|
|
|
|
* - circuit models for pb_type and pb interconnect
|
|
|
|
* - physical pb_graph nodes and pb_graph pins
|
|
|
|
* - circuit models for global routing architecture
|
2020-01-27 16:31:12 -06:00
|
|
|
*******************************************************************/
|
2020-01-31 12:36:58 -06:00
|
|
|
void link_arch(OpenfpgaContext& openfpga_context,
|
|
|
|
const Command& cmd, const CommandContext& cmd_context) {
|
2020-01-27 16:31:12 -06:00
|
|
|
|
2020-01-27 21:40:18 -06:00
|
|
|
vtr::ScopedStartFinishTimer timer("Link OpenFPGA architecture to VPR architecture");
|
|
|
|
|
2020-01-31 12:36:58 -06:00
|
|
|
CommandOptionId opt_verbose = cmd.option("verbose");
|
|
|
|
|
2020-01-28 16:13:14 -06:00
|
|
|
/* Annotate pb_type graphs
|
|
|
|
* - physical pb_type
|
|
|
|
* - mode selection bits for pb_type and pb interconnect
|
|
|
|
* - circuit models for pb_type and pb interconnect
|
|
|
|
*/
|
|
|
|
annotate_pb_types(g_vpr_ctx.device(), openfpga_context.arch(),
|
2020-02-12 10:52:18 -06:00
|
|
|
openfpga_context.mutable_vpr_device_annotation(),
|
2020-01-31 12:36:58 -06:00
|
|
|
cmd_context.option_enable(cmd, opt_verbose));
|
2020-01-27 16:31:12 -06:00
|
|
|
|
2020-01-30 17:40:13 -06:00
|
|
|
/* Annotate pb_graph_nodes
|
|
|
|
* - Give unique index to each node in the same type
|
|
|
|
* - Bind operating pb_graph_node to their physical pb_graph_node
|
|
|
|
* - Bind pins from operating pb_graph_node to their physical pb_graph_node pins
|
|
|
|
*/
|
|
|
|
annotate_pb_graph(g_vpr_ctx.device(),
|
2020-02-12 10:52:18 -06:00
|
|
|
openfpga_context.mutable_vpr_device_annotation(),
|
2020-01-31 12:36:58 -06:00
|
|
|
cmd_context.option_enable(cmd, opt_verbose));
|
2020-02-05 22:50:52 -06:00
|
|
|
|
|
|
|
/* Annotate net mapping to each rr_node
|
|
|
|
*/
|
|
|
|
openfpga_context.mutable_vpr_routing_annotation().init(g_vpr_ctx.device().rr_graph);
|
|
|
|
|
2020-02-06 13:54:55 -06:00
|
|
|
annotate_rr_node_nets(g_vpr_ctx.device(), g_vpr_ctx.clustering(), g_vpr_ctx.routing(),
|
|
|
|
openfpga_context.mutable_vpr_routing_annotation(),
|
|
|
|
cmd_context.option_enable(cmd, opt_verbose));
|
2020-02-11 17:37:14 -06:00
|
|
|
|
|
|
|
/* Build the routing graph annotation
|
|
|
|
* - RRGSB
|
|
|
|
* - DeviceRRGSB
|
|
|
|
*/
|
|
|
|
annotate_device_rr_gsb(g_vpr_ctx.device(),
|
|
|
|
openfpga_context.mutable_device_rr_gsb(),
|
|
|
|
cmd_context.option_enable(cmd, opt_verbose));
|
2020-01-27 16:31:12 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
} /* end namespace openfpga */
|