2020-02-14 18:40:59 -06:00
|
|
|
#ifndef ARCH_DIRECT_H
|
|
|
|
#define ARCH_DIRECT_H
|
|
|
|
|
2022-06-28 20:33:38 -05:00
|
|
|
#include <array>
|
2022-10-06 19:08:50 -05:00
|
|
|
#include <map>
|
2020-02-14 18:40:59 -06:00
|
|
|
|
|
|
|
#include "arch_direct_fwd.h"
|
2022-10-06 19:08:50 -05:00
|
|
|
#include "circuit_library_fwd.h"
|
|
|
|
#include "vtr_geometry.h"
|
|
|
|
#include "vtr_vector.h"
|
2020-02-14 18:40:59 -06:00
|
|
|
|
|
|
|
/********************************************************************
|
2022-10-06 19:08:50 -05:00
|
|
|
* Define the types of point to point connection between CLBs
|
2020-02-14 18:40:59 -06:00
|
|
|
* These types are supplementary to the original VPR direct connections
|
|
|
|
* Here we extend to the cross-row and cross-column connections
|
|
|
|
********************************************************************/
|
2024-05-17 20:59:53 -05:00
|
|
|
enum class e_direct_type {
|
|
|
|
INNER_COLUMN_OR_ROW,
|
|
|
|
PART_OF_CB,
|
2020-02-14 18:40:59 -06:00
|
|
|
INTER_COLUMN,
|
|
|
|
INTER_ROW,
|
|
|
|
NUM_DIRECT_TYPES
|
|
|
|
};
|
2024-05-18 14:33:19 -05:00
|
|
|
constexpr std::array<const char*, (size_t)e_direct_type::NUM_DIRECT_TYPES>
|
|
|
|
DIRECT_TYPE_STRING = {
|
|
|
|
{"inner_column_or_row", "part_of_cb", "inter_column", "inter_row"}};
|
2020-02-14 18:40:59 -06:00
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
enum e_direct_direction { POSITIVE_DIR, NEGATIVE_DIR, NUM_DIRECT_DIRECTIONS };
|
|
|
|
constexpr std::array<const char*, NUM_DIRECT_DIRECTIONS>
|
|
|
|
DIRECT_DIRECTION_STRING = {{"positive", "negative"}};
|
2020-02-14 18:40:59 -06:00
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* A data base to describe the direct connection in OpenFPGA architecture
|
|
|
|
* For each direct connection, it will include
|
2022-10-06 19:08:50 -05:00
|
|
|
* - name: the identifier to annotate the original direct connection in VPR
|
|
|
|
*architecture
|
2020-02-14 18:40:59 -06:00
|
|
|
* - circuit model: the circuit model to used to implement this connection
|
|
|
|
* - type: if this connection should be cross-column or cross-row
|
2022-10-06 19:08:50 -05:00
|
|
|
* - x-direction: how this connection is going to be applied to adjacent columns
|
2020-02-14 18:40:59 -06:00
|
|
|
* a positive x-direction means that column A will be connected
|
|
|
|
* to the column B on the right side of column A
|
2022-10-06 19:08:50 -05:00
|
|
|
* - y-direction: how this connection is going to be applied to adjacent rows
|
2020-02-14 18:40:59 -06:00
|
|
|
* a positive y-direction means that row A will be connected
|
|
|
|
* to the row B on the bottom side of row A
|
|
|
|
*
|
2022-10-06 19:08:50 -05:00
|
|
|
* Note that: this is the data structure to be used when parsing the XML
|
2020-02-14 18:40:59 -06:00
|
|
|
* this is NOT the data structure to be use in core engine
|
|
|
|
********************************************************************/
|
|
|
|
class ArchDirect {
|
2022-10-06 19:08:50 -05:00
|
|
|
public: /* Types */
|
|
|
|
typedef vtr::vector<ArchDirectId, ArchDirectId>::const_iterator
|
|
|
|
arch_direct_iterator;
|
|
|
|
/* Create range */
|
|
|
|
typedef vtr::Range<arch_direct_iterator> arch_direct_range;
|
|
|
|
|
|
|
|
public: /* Constructors */
|
|
|
|
ArchDirect();
|
|
|
|
|
|
|
|
public: /* Accessors: aggregates */
|
|
|
|
arch_direct_range directs() const;
|
|
|
|
|
|
|
|
public: /* Public Accessors: Basic data query on directs */
|
|
|
|
ArchDirectId direct(const std::string& name) const;
|
|
|
|
std::string name(const ArchDirectId& direct_id) const;
|
|
|
|
CircuitModelId circuit_model(const ArchDirectId& direct_id) const;
|
|
|
|
e_direct_type type(const ArchDirectId& direct_id) const;
|
|
|
|
e_direct_direction x_dir(const ArchDirectId& direct_id) const;
|
|
|
|
e_direct_direction y_dir(const ArchDirectId& direct_id) const;
|
|
|
|
|
|
|
|
public: /* Public Mutators */
|
|
|
|
ArchDirectId add_direct(const std::string& name);
|
|
|
|
void set_circuit_model(const ArchDirectId& direct_id,
|
|
|
|
const CircuitModelId& circuit_model);
|
|
|
|
void set_type(const ArchDirectId& direct_id, const e_direct_type& type);
|
|
|
|
void set_direction(const ArchDirectId& direct_id,
|
|
|
|
const e_direct_direction& x_dir,
|
|
|
|
const e_direct_direction& y_dir);
|
|
|
|
|
|
|
|
public: /* Public invalidators/validators */
|
|
|
|
bool valid_direct_id(const ArchDirectId& direct_id) const;
|
|
|
|
|
|
|
|
private: /* Internal data */
|
|
|
|
vtr::vector<ArchDirectId, ArchDirectId> direct_ids_;
|
|
|
|
|
|
|
|
/* Unique name: the identifier to annotate the original direct connection in
|
|
|
|
* VPR architecture */
|
|
|
|
vtr::vector<ArchDirectId, std::string> names_;
|
|
|
|
|
|
|
|
/* circuit model: the circuit model to used to implement this connection */
|
|
|
|
vtr::vector<ArchDirectId, CircuitModelId> circuit_models_;
|
|
|
|
|
|
|
|
/* type: if this connection should be cross-column or cross-row */
|
|
|
|
vtr::vector<ArchDirectId, e_direct_type> types_;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* x-direction: how this connection is going to be applied to adjacent columns
|
|
|
|
* a positive x-direction means that column A will be connected
|
|
|
|
* to the column B on the right side of column A
|
|
|
|
* y-direction: how this connection is going to be applied to adjacent rows
|
|
|
|
* a positive y-direction means that row A will be connected
|
|
|
|
* to the row B on the bottom side of row A
|
|
|
|
*/
|
|
|
|
vtr::vector<ArchDirectId, vtr::Point<e_direct_direction>> directions_;
|
|
|
|
|
|
|
|
/* Fast look-up */
|
|
|
|
std::map<std::string, ArchDirectId> direct_name2ids_;
|
2020-02-14 18:40:59 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|