2020-02-06 18:14:29 -06:00
|
|
|
#ifndef LUT_UTILS_H
|
|
|
|
#define LUT_UTILS_H
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Include header files that are required by function declaration
|
|
|
|
*******************************************************************/
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
2020-02-25 13:45:13 -06:00
|
|
|
#include <map>
|
2020-02-06 18:14:29 -06:00
|
|
|
#include "atom_netlist.h"
|
2020-02-25 13:45:13 -06:00
|
|
|
#include "mux_graph.h"
|
|
|
|
#include "physical_types.h"
|
|
|
|
#include "vpr_device_annotation.h"
|
2020-02-06 18:14:29 -06:00
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Function declaration
|
|
|
|
*******************************************************************/
|
|
|
|
|
|
|
|
/* begin namespace openfpga */
|
|
|
|
namespace openfpga {
|
|
|
|
|
|
|
|
AtomNetlist::TruthTable lut_truth_table_adaption(const AtomNetlist::TruthTable& orig_tt,
|
|
|
|
const std::vector<int>& rotated_pin_map);
|
|
|
|
|
|
|
|
std::vector<std::string> truth_table_to_string(const AtomNetlist::TruthTable& tt);
|
|
|
|
|
2020-02-25 23:39:42 -06:00
|
|
|
AtomNetlist::TruthTable build_wired_lut_truth_table(const size_t& lut_size,
|
|
|
|
const size_t& wire_input_id);
|
2020-02-25 13:45:13 -06:00
|
|
|
|
|
|
|
AtomNetlist::TruthTable adapt_truth_table_for_frac_lut(const size_t& lut_frac_level,
|
|
|
|
const size_t& lut_output_mask,
|
|
|
|
const AtomNetlist::TruthTable& truth_table);
|
|
|
|
|
|
|
|
bool lut_truth_table_use_on_set(const AtomNetlist::TruthTable& truth_table);
|
|
|
|
|
|
|
|
std::vector<bool> build_frac_lut_bitstream(const CircuitLibrary& circuit_lib,
|
|
|
|
const MuxGraph& lut_mux_graph,
|
|
|
|
const VprDeviceAnnotation& device_annotation,
|
2020-02-25 14:34:13 -06:00
|
|
|
const std::map<const t_pb_graph_pin*, AtomNetlist::TruthTable>& truth_tables,
|
2020-02-25 13:45:13 -06:00
|
|
|
const size_t& default_sram_bit_value);
|
|
|
|
|
2021-02-18 20:37:17 -06:00
|
|
|
bool is_wired_lut(const std::vector<AtomNetId>& input_nets,
|
|
|
|
const AtomNetId& output_net);
|
|
|
|
|
2020-02-06 18:14:29 -06:00
|
|
|
} /* end namespace openfpga */
|
|
|
|
|
|
|
|
#endif
|