Skip to content

Commit

Permalink
Add flat version of sync_netlists_to_routing
Browse files Browse the repository at this point in the history
  • Loading branch information
duck2 committed Sep 9, 2024
1 parent a342b67 commit 58b5eac
Show file tree
Hide file tree
Showing 16 changed files with 482 additions and 93 deletions.
3 changes: 3 additions & 0 deletions libs/libarchfpga/src/physical_types.h
Original file line number Diff line number Diff line change
Expand Up @@ -1671,6 +1671,9 @@ constexpr std::array<const char*, size_t(SwitchType::NUM_SWITCH_TYPES)> SWITCH_T
*/
constexpr const char* VPR_DELAYLESS_SWITCH_NAME = "__vpr_delayless_switch__";

/* Internal switch: used by the flat router */
constexpr const char* VPR_INTERNAL_SWITCH_NAME = "Internal Switch";

enum class BufferSize {
AUTO,
ABSOLUTE
Expand Down
2 changes: 1 addition & 1 deletion libs/librrgraph/src/io/rr_graph_uxsdcxx_serializer.h
Original file line number Diff line number Diff line change
Expand Up @@ -526,7 +526,7 @@ class RrGraphSerializer final : public uxsd::RrGraphBase<RrGraphContextTypes> {
bool found_arch_name = false;
std::string string_name = std::string(name);
// The string name has the format of "Internal Switch/delay". So, I have to use compare to specify the portion I want to be compared.
bool is_internal_sw = string_name.compare(0, 15, "Internal Switch") == 0;
bool is_internal_sw = string_name.compare(0, strlen(VPR_INTERNAL_SWITCH_NAME), VPR_INTERNAL_SWITCH_NAME) == 0;
for (const auto& arch_sw_inf: arch_switch_inf_) {
if (string_name == arch_sw_inf.name || is_internal_sw) {
found_arch_name = true;
Expand Down
16 changes: 3 additions & 13 deletions utils/fasm/src/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ using namespace std;
#include "fasm.h"

#include "post_routing_pb_pin_fixup.h"
#include "sync_netlists_to_routing_flat.h"

/*
* Exit codes to signal success/failure to scripts
Expand Down Expand Up @@ -86,25 +87,14 @@ int main(int argc, const char **argv) {
bool is_flat = vpr_setup.RouterOpts.flat_routing;
if (flow_succeeded) {
if(is_flat) {
sync_netlists_to_routing((const Netlist<>&) g_vpr_ctx.atom().nlist,
g_vpr_ctx.device(),
g_vpr_ctx.mutable_atom(),
g_vpr_ctx.atom().lookup,
g_vpr_ctx.mutable_clustering(),
g_vpr_ctx.placement(),
g_vpr_ctx.routing(),
vpr_setup.PackerOpts.pack_verbosity > 2,
is_flat);
sync_netlists_to_routing_flat();
} else {
sync_netlists_to_routing((const Netlist<>&) g_vpr_ctx.clustering().clb_nlist,
g_vpr_ctx.device(),
g_vpr_ctx.mutable_atom(),
g_vpr_ctx.atom().lookup,
g_vpr_ctx.mutable_clustering(),
g_vpr_ctx.placement(),
g_vpr_ctx.routing(),
vpr_setup.PackerOpts.pack_verbosity > 2,
is_flat);
vpr_setup.PackerOpts.pack_verbosity > 2);
}
}

Expand Down
23 changes: 13 additions & 10 deletions utils/fasm/test/test_fasm.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,15 @@
#include "fasm_utils.h"
#include "arch_util.h"
#include "rr_graph_writer.h"
#include "post_routing_pb_pin_fixup.h"
#include <sstream>
#include <fstream>
#include <regex>
#include <cmath>
#include <algorithm>

#include "post_routing_pb_pin_fixup.h"
#include "sync_netlists_to_routing_flat.h"

static constexpr const char kArchFile[] = "test_fasm_arch.xml";
static constexpr const char kRrGraphFile[] = "test_fasm_rrgraph.xml";

Expand Down Expand Up @@ -327,15 +329,16 @@ TEST_CASE("fasm_integration_test", "[fasm]") {
/* Sync netlist to the actual routing (necessary if there are block
ports with equivalent pins) */
if (flow_succeeded) {
sync_netlists_to_routing((const Netlist<>&) g_vpr_ctx.clustering().clb_nlist,
g_vpr_ctx.device(),
g_vpr_ctx.mutable_atom(),
g_vpr_ctx.atom().lookup,
g_vpr_ctx.mutable_clustering(),
g_vpr_ctx.placement(),
g_vpr_ctx.routing(),
vpr_setup.PackerOpts.pack_verbosity > 2,
is_flat);
if (is_flat) {
sync_netlists_to_routing_flat();
} else {
sync_netlists_to_routing((const Netlist<>&) g_vpr_ctx.clustering().clb_nlist,
g_vpr_ctx.device(),
g_vpr_ctx.mutable_atom(),
g_vpr_ctx.mutable_clustering(),
g_vpr_ctx.placement(),
vpr_setup.PackerOpts.pack_verbosity > 2);
}
}

std::stringstream fasm_string;
Expand Down
1 change: 0 additions & 1 deletion vpr/src/base/atom_lookup.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,6 @@ ClusterNetId AtomLookup::clb_net(const AtomNetId net_id) const {
}

void AtomLookup::set_atom_clb_net(const AtomNetId net_id, const ClusterNetId clb_net_index) {
VTR_ASSERT(net_id);
//If either are invalid remove any mapping
if (!net_id && clb_net_index != ClusterNetId::INVALID()) {
//Remove
Expand Down
29 changes: 14 additions & 15 deletions vpr/src/base/vpr_api.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@
#include "arch_util.h"

#include "post_routing_pb_pin_fixup.h"

#include "sync_netlists_to_routing_flat.h"

#include "load_flat_place.h"

Expand Down Expand Up @@ -1441,27 +1441,26 @@ bool vpr_analysis_flow(const Netlist<>& net_list,
* - Turn on verbose output when users require verbose output
* for packer (default verbosity is set to 2 for compact logs)
*/
if (!is_flat) {
if (route_status.success()) {
if (route_status.success()) {
if (is_flat) {
sync_netlists_to_routing_flat();
} else {
sync_netlists_to_routing(net_list,
g_vpr_ctx.device(),
g_vpr_ctx.mutable_atom(),
g_vpr_ctx.atom().lookup,
g_vpr_ctx.mutable_clustering(),
g_vpr_ctx.placement(),
g_vpr_ctx.routing(),
vpr_setup.PackerOpts.pack_verbosity > 2,
is_flat);

std::string post_routing_packing_output_file_name = vpr_setup.PackerOpts.output_file + ".post_routing";
write_packing_results_to_xml(vpr_setup.PackerOpts.global_clocks,
Arch.architecture_id,
post_routing_packing_output_file_name.c_str());
} else {
VTR_LOG_WARN("Synchronization between packing and routing results is not applied due to illegal circuit implementation\n");
vpr_setup.PackerOpts.pack_verbosity > 2);
}
VTR_LOG("\n");

std::string post_routing_packing_output_file_name = vpr_setup.PackerOpts.output_file + ".post_routing";
write_packing_results_to_xml(vpr_setup.PackerOpts.global_clocks,
Arch.architecture_id,
post_routing_packing_output_file_name.c_str());
} else {
VTR_LOG_WARN("Synchronization between packing and routing results is not applied due to illegal circuit implementation\n");
}
VTR_LOG("\n");

vpr_analysis(net_list,
vpr_setup,
Expand Down
3 changes: 3 additions & 0 deletions vpr/src/base/vpr_context.h
Original file line number Diff line number Diff line change
Expand Up @@ -515,6 +515,9 @@ struct RoutingContext : public Context {
* @brief User specified routing constraints
*/
UserRouteConstraints constraints;

/** Is flat routing enabled? */
bool is_flat;
};

/**
Expand Down
38 changes: 8 additions & 30 deletions vpr/src/pack/post_routing_pb_pin_fixup.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -48,15 +48,13 @@ static std::vector<e_side> find_physical_tile_pin_side(t_physical_tile_type_ptr
* - if the net id does not match, we update the clustering context
*******************************************************************/
static void update_cluster_pin_with_post_routing_results(const Netlist<>& net_list,
const AtomContext& atom_ctx,
const DeviceContext& device_ctx,
ClusteringContext& clustering_ctx,
const vtr::vector<RRNodeId, ParentNetId>& rr_node_nets,
const vtr::vector<RRNodeId, ClusterNetId>& rr_node_nets,
const t_pl_loc& grid_coord,
const ClusterBlockId& blk_id,
size_t& num_mismatches,
const bool& verbose,
bool is_flat) {
const bool& verbose) {
const int sub_tile_z = grid_coord.sub_tile;
const int coord_x = grid_coord.x;
const int coord_y = grid_coord.y;
Expand Down Expand Up @@ -210,15 +208,7 @@ static void update_cluster_pin_with_post_routing_results(const Netlist<>& net_li
continue;
}

ClusterNetId cluster_equivalent_net_id = ClusterNetId::INVALID();
if (is_flat) {
cluster_equivalent_net_id = atom_ctx.lookup.clb_net(convert_to_atom_net_id(routing_net_id));
if (routing_net_id != ParentNetId::INVALID()) {
VTR_ASSERT(cluster_equivalent_net_id != ClusterNetId::INVALID());
}
} else {
cluster_equivalent_net_id = convert_to_cluster_net_id(routing_net_id);
}
ClusterNetId cluster_equivalent_net_id = convert_to_cluster_net_id(routing_net_id);

/* If the net from the routing results matches the net from the packing results,
* nothing to be changed. Move on to the next net.
Expand Down Expand Up @@ -1046,24 +1036,19 @@ static void update_cluster_routing_traces_with_post_routing_results(AtomContext&
void sync_netlists_to_routing(const Netlist<>& net_list,
const DeviceContext& device_ctx,
AtomContext& atom_ctx,
const AtomLookup& atom_look_up,
ClusteringContext& clustering_ctx,
const PlacementContext& placement_ctx,
const RoutingContext& routing_ctx,
const bool& verbose,
bool is_flat) {
const bool& verbose) {
vtr::ScopedStartFinishTimer timer("Synchronize the packed netlist to routing optimization");

/* Reset the database for post-routing clb net mapping */
clustering_ctx.post_routing_clb_pin_nets.clear();
clustering_ctx.pre_routing_net_pin_mapping.clear();

/* Create net-to-rr_node mapping */
vtr::vector<RRNodeId, ParentNetId> rr_node_nets = annotate_rr_node_nets(net_list,
vtr::vector<RRNodeId, ClusterNetId> rr_node_nets = annotate_rr_node_nets(clustering_ctx,
device_ctx,
routing_ctx,
verbose,
is_flat);
verbose);

IntraLbPbPinLookup intra_lb_pb_pin_lookup(device_ctx.logical_block_types);

Expand All @@ -1076,25 +1061,18 @@ void sync_netlists_to_routing(const Netlist<>& net_list,
/* Update the core logic (center blocks of the FPGA) */
for (const ParentBlockId& blk_id : net_list.blocks()) {
/* We know the entrance to grid info and mapping results, do the fix-up for this block */
ClusterBlockId clb_blk_id;
if (is_flat) {
clb_blk_id = atom_look_up.atom_clb(convert_to_atom_block_id(blk_id));
} else {
clb_blk_id = convert_to_cluster_block_id(blk_id);
}
ClusterBlockId clb_blk_id = convert_to_cluster_block_id(blk_id);
VTR_ASSERT(clb_blk_id != ClusterBlockId::INVALID());

if (seen_block_ids.insert(clb_blk_id).second) {
update_cluster_pin_with_post_routing_results(net_list,
atom_ctx,
device_ctx,
clustering_ctx,
rr_node_nets,
placement_ctx.block_locs()[clb_blk_id].loc,
clb_blk_id,
num_mismatches,
verbose,
is_flat);
verbose);

update_cluster_routing_traces_with_post_routing_results(atom_ctx,
intra_lb_pb_pin_lookup,
Expand Down
5 changes: 1 addition & 4 deletions vpr/src/pack/post_routing_pb_pin_fixup.h
Original file line number Diff line number Diff line change
Expand Up @@ -12,11 +12,8 @@
void sync_netlists_to_routing(const Netlist<>& net_list,
const DeviceContext& device_ctx,
AtomContext& atom_ctx,
const AtomLookup& atom_lookup,
ClusteringContext& clustering_ctx,
const PlacementContext& placement_ctx,
const RoutingContext& routing_ctx,
const bool& verbose,
bool is_flat);
const bool& verbose);

#endif
Loading

0 comments on commit 58b5eac

Please sign in to comment.