mirror of https://github.com/YosysHQ/yosys.git
Added [[CITE]] tags to abc and fsm_extract passes
This commit is contained in:
parent
89f009d171
commit
10956cb84a
|
@ -17,6 +17,14 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
// [[CITE]] ABC
|
||||||
|
// Berkeley Logic Synthesis and Verification Group, ABC: A System for Sequential Synthesis and Verification
|
||||||
|
// http://www.eecs.berkeley.edu/~alanmi/abc/
|
||||||
|
|
||||||
|
// [[CITE]] Kahn's Topological sorting algorithm
|
||||||
|
// Kahn, Arthur B. (1962), "Topological sorting of large networks", Communications of the ACM 5 (11): 558–562, doi:10.1145/368996.369025
|
||||||
|
// http://en.wikipedia.org/wiki/Topological_sorting
|
||||||
|
|
||||||
#include "kernel/register.h"
|
#include "kernel/register.h"
|
||||||
#include "kernel/sigtools.h"
|
#include "kernel/sigtools.h"
|
||||||
#include "kernel/log.h"
|
#include "kernel/log.h"
|
||||||
|
@ -187,6 +195,7 @@ static void dump_loop_graph(FILE *f, int &nr, std::map<int, std::set<int>> &edge
|
||||||
static void handle_loops()
|
static void handle_loops()
|
||||||
{
|
{
|
||||||
// http://en.wikipedia.org/wiki/Topological_sorting
|
// http://en.wikipedia.org/wiki/Topological_sorting
|
||||||
|
// (Kahn, Arthur B. (1962), "Topological sorting of large networks")
|
||||||
|
|
||||||
std::map<int, std::set<int>> edges;
|
std::map<int, std::set<int>> edges;
|
||||||
std::vector<int> in_edges_count(signal_list.size());
|
std::vector<int> in_edges_count(signal_list.size());
|
||||||
|
|
|
@ -17,6 +17,11 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
// [[CITE]]
|
||||||
|
// Yiqiong Shi; Chan Wai Ting; Bah-Hwee Gwee; Ye Ren, "A highly efficient method for extracting FSMs from flattened gate-level netlist,"
|
||||||
|
// Circuits and Systems (ISCAS), Proceedings of 2010 IEEE International Symposium on , vol., no., pp.2610,2613, May 30 2010-June 2 2010
|
||||||
|
// doi: 10.1109/ISCAS.2010.5537093
|
||||||
|
|
||||||
#include "kernel/log.h"
|
#include "kernel/log.h"
|
||||||
#include "kernel/register.h"
|
#include "kernel/register.h"
|
||||||
#include "kernel/sigtools.h"
|
#include "kernel/sigtools.h"
|
||||||
|
@ -283,7 +288,7 @@ static void extract_fsm(RTLIL::Wire *wire)
|
||||||
fsm_cell->connections["\\CTRL_IN"] = ctrl_in;
|
fsm_cell->connections["\\CTRL_IN"] = ctrl_in;
|
||||||
fsm_cell->connections["\\CTRL_OUT"] = ctrl_out;
|
fsm_cell->connections["\\CTRL_OUT"] = ctrl_out;
|
||||||
fsm_cell->parameters["\\NAME"] = RTLIL::Const(wire->name);
|
fsm_cell->parameters["\\NAME"] = RTLIL::Const(wire->name);
|
||||||
fsm_cell->attributes = wire->attributes;
|
fsm_cell->attributes = wire->attributes;
|
||||||
fsm_data.copy_to_cell(fsm_cell);
|
fsm_data.copy_to_cell(fsm_cell);
|
||||||
module->cells[fsm_cell->name] = fsm_cell;
|
module->cells[fsm_cell->name] = fsm_cell;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue