2021-01-16 17:35:13 -06:00
|
|
|
#ifndef REPACK_DESIGN_CONSTRAINTS_H
|
|
|
|
#define REPACK_DESIGN_CONSTRAINTS_H
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* This file include the declaration of repack design constraints
|
|
|
|
*******************************************************************/
|
|
|
|
#include <string>
|
|
|
|
#include <map>
|
|
|
|
#include <array>
|
|
|
|
|
|
|
|
/* Headers from vtrutil library */
|
|
|
|
#include "vtr_vector.h"
|
2021-01-16 18:34:22 -06:00
|
|
|
#include "vtr_geometry.h"
|
|
|
|
|
|
|
|
/* Headers from openfpgautil library */
|
|
|
|
#include "openfpga_port.h"
|
2021-01-16 17:35:13 -06:00
|
|
|
|
|
|
|
#include "repack_design_constraints_fwd.h"
|
|
|
|
|
2021-01-16 22:57:17 -06:00
|
|
|
/* Constants */
|
|
|
|
constexpr char* REPACK_DESIGN_CONSTRAINT_OPEN_NET = "OPEN";
|
|
|
|
|
2021-01-16 17:35:13 -06:00
|
|
|
/********************************************************************
|
|
|
|
* A data structure to describe the design constraints for repacking tools
|
|
|
|
* This data structure may include a number of design constraints
|
|
|
|
* each of which may constrain:
|
|
|
|
* - pin assignment, for instance, force a net to be mapped to specific pin
|
|
|
|
*
|
|
|
|
* Typical usage:
|
|
|
|
* --------------
|
|
|
|
* // Create an object of design constraints
|
|
|
|
* RepackDesignConstraints repack_design_constraints;
|
|
|
|
* // Add a pin assignment
|
|
|
|
* RepackDesignConstraintId repack_dc_id = fabric_key.create_design_constraint(RepackDesignConstraints::PIN_ASSIGNMENT);
|
|
|
|
*
|
|
|
|
*******************************************************************/
|
|
|
|
class RepackDesignConstraints {
|
|
|
|
public: /* Type of design constraints */
|
|
|
|
enum e_design_constraint_type {
|
|
|
|
PIN_ASSIGNMENT,
|
|
|
|
NUM_DESIGN_CONSTRAINT_TYPES
|
|
|
|
};
|
|
|
|
public: /* Types */
|
|
|
|
typedef vtr::vector<RepackDesignConstraintId, RepackDesignConstraintId>::const_iterator repack_design_constraint_iterator;
|
|
|
|
/* Create range */
|
|
|
|
typedef vtr::Range<repack_design_constraint_iterator> repack_design_constraint_range;
|
|
|
|
public: /* Constructors */
|
|
|
|
RepackDesignConstraints();
|
|
|
|
public: /* Accessors: aggregates */
|
|
|
|
repack_design_constraint_range design_constraints() const;
|
|
|
|
public: /* Public Accessors: Basic data query */
|
|
|
|
/* Get the type of constraint */
|
|
|
|
e_design_constraint_type type(const RepackDesignConstraintId& repack_design_constraint_id) const;
|
|
|
|
|
2021-01-16 22:35:43 -06:00
|
|
|
/* Get the pb_type name to be constrained */
|
|
|
|
std::string pb_type(const RepackDesignConstraintId& repack_design_constraint_id) const;
|
2021-01-16 17:35:13 -06:00
|
|
|
|
|
|
|
/* Get the pin to be constrained */
|
2021-01-16 18:34:22 -06:00
|
|
|
openfpga::BasicPort pin(const RepackDesignConstraintId& repack_design_constraint_id) const;
|
2021-01-16 17:35:13 -06:00
|
|
|
|
|
|
|
/* Get the net to be constrained */
|
|
|
|
std::string net(const RepackDesignConstraintId& repack_design_constraint_id) const;
|
|
|
|
|
2021-04-21 14:53:08 -05:00
|
|
|
/* Find a constrained net */
|
|
|
|
std::string find_constrained_pin_net(const std::string& pb_type,
|
|
|
|
const openfpga::BasicPort& pin) const;
|
|
|
|
|
2021-01-16 17:35:13 -06:00
|
|
|
/* Check if there are any design constraints */
|
|
|
|
bool empty() const;
|
|
|
|
|
|
|
|
public: /* Public Mutators */
|
|
|
|
|
|
|
|
/* Reserve a number of design constraints to be memory efficent */
|
|
|
|
void reserve_design_constraints(const size_t& num_design_constraints);
|
|
|
|
|
|
|
|
/* Add a design constraint to storage */
|
|
|
|
RepackDesignConstraintId create_design_constraint(const e_design_constraint_type& repack_design_constraint_type);
|
|
|
|
|
2021-01-16 22:35:43 -06:00
|
|
|
/* Set the pb_type name to be constrained */
|
|
|
|
void set_pb_type(const RepackDesignConstraintId& repack_design_constraint_id,
|
|
|
|
const std::string& pb_type);
|
2021-01-16 17:35:13 -06:00
|
|
|
|
|
|
|
/* Set the pin to be constrained */
|
|
|
|
void set_pin(const RepackDesignConstraintId& repack_design_constraint_id,
|
2021-01-16 18:34:22 -06:00
|
|
|
const openfpga::BasicPort& pin);
|
2021-01-16 17:35:13 -06:00
|
|
|
|
|
|
|
/* Set the net to be constrained */
|
|
|
|
void set_net(const RepackDesignConstraintId& repack_design_constraint_id,
|
|
|
|
const std::string& net);
|
|
|
|
|
|
|
|
public: /* Public invalidators/validators */
|
|
|
|
bool valid_design_constraint_id(const RepackDesignConstraintId& repack_design_constraint_id) const;
|
2021-04-21 14:53:08 -05:00
|
|
|
/* Show if the net has no constraints (free to map to any pin)
|
|
|
|
* This function is used to identify the net name returned by APIs:
|
|
|
|
* - find_constrained_pin_net()
|
|
|
|
* - net()
|
|
|
|
*/
|
|
|
|
bool unconstrained_net(const std::string& net) const;
|
|
|
|
|
|
|
|
/* Show if the net is defined specifically not to map to any pin
|
|
|
|
* This function is used to identify the net name returned by APIs:
|
|
|
|
* - find_constrained_pin_net()
|
|
|
|
* - net()
|
|
|
|
*/
|
|
|
|
bool unmapped_net(const std::string& net) const;
|
|
|
|
|
2021-01-16 17:35:13 -06:00
|
|
|
private: /* Internal data */
|
|
|
|
/* Unique ids for each design constraint */
|
|
|
|
vtr::vector<RepackDesignConstraintId, RepackDesignConstraintId> repack_design_constraint_ids_;
|
|
|
|
|
|
|
|
/* Type for each design constraint */
|
|
|
|
vtr::vector<RepackDesignConstraintId, e_design_constraint_type> repack_design_constraint_types_;
|
|
|
|
|
|
|
|
/* Tiles to constraint */
|
2021-01-16 22:35:43 -06:00
|
|
|
vtr::vector<RepackDesignConstraintId, std::string> repack_design_constraint_pb_types_;
|
2021-01-16 17:35:13 -06:00
|
|
|
|
|
|
|
/* Pins to constraint */
|
2021-01-16 18:34:22 -06:00
|
|
|
vtr::vector<RepackDesignConstraintId, openfpga::BasicPort> repack_design_constraint_pins_;
|
2021-01-16 17:35:13 -06:00
|
|
|
|
|
|
|
/* Nets to constraint */
|
|
|
|
vtr::vector<RepackDesignConstraintId, std::string> repack_design_constraint_nets_;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|