diff options
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/hashlib.h | 72 | ||||
| -rw-r--r-- | kernel/log.h | 7 | ||||
| -rw-r--r-- | kernel/register.cc | 7 | ||||
| -rw-r--r-- | kernel/rtlil.cc | 52 | ||||
| -rw-r--r-- | kernel/rtlil.h | 4 | ||||
| -rw-r--r-- | kernel/yosys.cc | 15 | ||||
| -rw-r--r-- | kernel/yosys.h | 8 | 
7 files changed, 154 insertions, 11 deletions
| diff --git a/kernel/hashlib.h b/kernel/hashlib.h index e7cb312ed..996bda38e 100644 --- a/kernel/hashlib.h +++ b/kernel/hashlib.h @@ -314,11 +314,11 @@ class dict  	int do_insert(const K &key, int &hash)  	{  		if (hashtable.empty()) { -			entries.push_back(entry_t(std::pair<K, T>(key, T()), -1)); +			entries.emplace_back(std::pair<K, T>(key, T()), -1);  			do_rehash();  			hash = do_hash(key);  		} else { -			entries.push_back(entry_t(std::pair<K, T>(key, T()), hashtable[hash])); +			entries.emplace_back(std::pair<K, T>(key, T()), hashtable[hash]);  			hashtable[hash] = entries.size() - 1;  		}  		return entries.size() - 1; @@ -327,11 +327,25 @@ class dict  	int do_insert(const std::pair<K, T> &value, int &hash)  	{  		if (hashtable.empty()) { -			entries.push_back(entry_t(value, -1)); +			entries.emplace_back(value, -1);  			do_rehash();  			hash = do_hash(value.first);  		} else { -			entries.push_back(entry_t(value, hashtable[hash])); +			entries.emplace_back(value, hashtable[hash]); +			hashtable[hash] = entries.size() - 1; +		} +		return entries.size() - 1; +	} + +	int do_insert(std::pair<K, T> &&rvalue, int &hash) +	{ +		if (hashtable.empty()) { +			auto key = rvalue.first; +			entries.emplace_back(std::forward<std::pair<K, T>>(rvalue), -1); +			do_rehash(); +			hash = do_hash(key); +		} else { +			entries.emplace_back(std::forward<std::pair<K, T>>(rvalue), hashtable[hash]);  			hashtable[hash] = entries.size() - 1;  		}  		return entries.size() - 1; @@ -441,6 +455,56 @@ public:  		return std::pair<iterator, bool>(iterator(this, i), true);  	} +	std::pair<iterator, bool> insert(std::pair<K, T> &&rvalue) +	{ +		int hash = do_hash(rvalue.first); +		int i = do_lookup(rvalue.first, hash); +		if (i >= 0) +			return std::pair<iterator, bool>(iterator(this, i), false); +		i = do_insert(std::forward<std::pair<K, T>>(rvalue), hash); +		return std::pair<iterator, bool>(iterator(this, i), true); +	} + +	std::pair<iterator, bool> emplace(K const &key, T const &value) +	{ +		int hash = do_hash(key); +		int i = do_lookup(key, hash); +		if (i >= 0) +			return std::pair<iterator, bool>(iterator(this, i), false); +		i = do_insert(std::make_pair(key, value), hash); +		return std::pair<iterator, bool>(iterator(this, i), true); +	} + +	std::pair<iterator, bool> emplace(K const &key, T &&rvalue) +	{ +		int hash = do_hash(key); +		int i = do_lookup(key, hash); +		if (i >= 0) +			return std::pair<iterator, bool>(iterator(this, i), false); +		i = do_insert(std::make_pair(key, std::forward<T>(rvalue)), hash); +		return std::pair<iterator, bool>(iterator(this, i), true); +	} + +	std::pair<iterator, bool> emplace(K &&rkey, T const &value) +	{ +		int hash = do_hash(rkey); +		int i = do_lookup(rkey, hash); +		if (i >= 0) +			return std::pair<iterator, bool>(iterator(this, i), false); +		i = do_insert(std::make_pair(std::forward<K>(rkey), value), hash); +		return std::pair<iterator, bool>(iterator(this, i), true); +	} + +	std::pair<iterator, bool> emplace(K &&rkey, T &&rvalue) +	{ +		int hash = do_hash(rkey); +		int i = do_lookup(rkey, hash); +		if (i >= 0) +			return std::pair<iterator, bool>(iterator(this, i), false); +		i = do_insert(std::make_pair(std::forward<K>(rkey), std::forward<T>(rvalue)), hash); +		return std::pair<iterator, bool>(iterator(this, i), true); +	} +  	int erase(const K &key)  	{  		int hash = do_hash(key); diff --git a/kernel/log.h b/kernel/log.h index cd0e8185c..5478482ac 100644 --- a/kernel/log.h +++ b/kernel/log.h @@ -29,18 +29,25 @@  #if defined(__GNUC__) && !defined( __clang__) && ( __GNUC__ == 4 && __GNUC_MINOR__ <= 8)  	#include <boost/xpressive/xpressive.hpp>  	#define YS_REGEX_TYPE boost::xpressive::sregex +	#define YS_REGEX_MATCH_TYPE boost::xpressive::smatch  	#define YS_REGEX_NS boost::xpressive  	#define YS_REGEX_COMPILE(param) boost::xpressive::sregex::compile(param, \  					boost::xpressive::regex_constants::nosubs | \  					boost::xpressive::regex_constants::optimize) +	#define YS_REGEX_COMPILE_WITH_SUBS(param) boost::xpressive::sregex::compile(param, \ +					boost::xpressive::regex_constants::optimize)  # else  	#include <regex>  	#define YS_REGEX_TYPE std::regex +	#define YS_REGEX_MATCH_TYPE std::smatch  	#define YS_REGEX_NS std  	#define YS_REGEX_COMPILE(param) std::regex(param, \  					std::regex_constants::nosubs | \  					std::regex_constants::optimize | \  					std::regex_constants::egrep) +	#define YS_REGEX_COMPILE_WITH_SUBS(param) std::regex(param, \ +					std::regex_constants::optimize | \ +					std::regex_constants::egrep)  #endif  #ifndef _WIN32 diff --git a/kernel/register.cc b/kernel/register.cc index af8c1b8e8..925d0d776 100644 --- a/kernel/register.cc +++ b/kernel/register.cc @@ -485,20 +485,21 @@ void Frontend::extra_args(std::istream *&f, std::string &filename, std::vector<s  			cmd_error(args, argidx, "Extra filename argument in direct file mode.");  		filename = arg; +		//Accommodate heredocs with EOT marker spaced out from "<<", e.g. "<< EOT" vs. "<<EOT"  		if (filename == "<<" && argidx+1 < args.size())  			filename += args[++argidx];  		if (filename.compare(0, 2, "<<") == 0) { -			if (Frontend::current_script_file == NULL) -				log_error("Unexpected here document '%s' outside of script!\n", filename.c_str());  			if (filename.size() <= 2)  				log_error("Missing EOT marker in here document!\n");  			std::string eot_marker = filename.substr(2); +			if (Frontend::current_script_file == nullptr) +				filename = "<stdin>";  			last_here_document.clear();  			while (1) {  				std::string buffer;  				char block[4096];  				while (1) { -					if (fgets(block, 4096, Frontend::current_script_file) == NULL) +					if (fgets(block, 4096, Frontend::current_script_file == nullptr? stdin : Frontend::current_script_file) == nullptr)  						log_error("Unexpected end of file in here document '%s'!\n", filename.c_str());  					buffer += block;  					if (buffer.size() > 0 && (buffer[buffer.size() - 1] == '\n' || buffer[buffer.size() - 1] == '\r')) diff --git a/kernel/rtlil.cc b/kernel/rtlil.cc index 00c116115..6996a02c4 100644 --- a/kernel/rtlil.cc +++ b/kernel/rtlil.cc @@ -42,11 +42,58 @@ int RTLIL::IdString::last_created_idx_ptr_;  #endif  #define X(_id) IdString RTLIL::ID::_id; -#include "constids.inc" +#include "kernel/constids.inc"  #undef X  dict<std::string, std::string> RTLIL::constpad; +const pool<IdString> &RTLIL::builtin_ff_cell_types() { +	static const pool<IdString> res = { +		ID($sr), +		ID($ff), +		ID($dff), +		ID($dffe), +		ID($dffsr), +		ID($adff), +		ID($dlatch), +		ID($dlatchsr), +		ID($_DFFE_NN_), +		ID($_DFFE_NP_), +		ID($_DFFE_PN_), +		ID($_DFFE_PP_), +		ID($_DFFSR_NNN_), +		ID($_DFFSR_NNP_), +		ID($_DFFSR_NPN_), +		ID($_DFFSR_NPP_), +		ID($_DFFSR_PNN_), +		ID($_DFFSR_PNP_), +		ID($_DFFSR_PPN_), +		ID($_DFFSR_PPP_), +		ID($_DFF_NN0_), +		ID($_DFF_NN1_), +		ID($_DFF_NP0_), +		ID($_DFF_NP1_), +		ID($_DFF_N_), +		ID($_DFF_PN0_), +		ID($_DFF_PN1_), +		ID($_DFF_PP0_), +		ID($_DFF_PP1_), +		ID($_DFF_P_), +		ID($_DLATCHSR_NNN_), +		ID($_DLATCHSR_NNP_), +		ID($_DLATCHSR_NPN_), +		ID($_DLATCHSR_NPP_), +		ID($_DLATCHSR_PNN_), +		ID($_DLATCHSR_PNP_), +		ID($_DLATCHSR_PPN_), +		ID($_DLATCHSR_PPP_), +		ID($_DLATCH_N_), +		ID($_DLATCH_P_), +		ID($_FF_), +	}; +	return res; +} +  RTLIL::Const::Const()  {  	flags = RTLIL::CONST_FLAG_NONE; @@ -550,6 +597,7 @@ void RTLIL::Design::remove(RTLIL::Module *module)  	}  	log_assert(modules_.at(module->name) == module); +	log_assert(refcount_modules_ == 0);  	modules_.erase(module->name);  	delete module;  } @@ -720,6 +768,8 @@ void RTLIL::Module::makeblackbox()  		delete it->second;  	processes.clear(); +	connections_.clear(); +  	remove(delwires);  	set_bool_attribute(ID::blackbox);  } diff --git a/kernel/rtlil.h b/kernel/rtlil.h index 7279835ea..17f038e36 100644 --- a/kernel/rtlil.h +++ b/kernel/rtlil.h @@ -377,12 +377,14 @@ namespace RTLIL  	namespace ID {  #define X(_id) extern IdString _id; -#include "constids.inc" +#include "kernel/constids.inc"  #undef X  	};  	extern dict<std::string, std::string> constpad; +	const pool<IdString> &builtin_ff_cell_types(); +  	static inline std::string escape_id(const std::string &str) {  		if (str.size() > 0 && str[0] != '\\' && str[0] != '$')  			return "\\" + str; diff --git a/kernel/yosys.cc b/kernel/yosys.cc index 380f7030b..01131601f 100644 --- a/kernel/yosys.cc +++ b/kernel/yosys.cc @@ -516,7 +516,7 @@ void yosys_setup()  	already_setup = true;  #define X(_id) RTLIL::ID::_id = "\\" # _id; -#include "constids.inc" +#include "kernel/constids.inc"  #undef X  	#ifdef WITH_PYTHON @@ -835,7 +835,7 @@ std::string proc_share_dirname()  	std::string proc_share_path = proc_self_path + "share/";  	if (check_file_exists(proc_share_path, true))  		return proc_share_path; -	proc_share_path = proc_self_path + "../share/yosys/"; +	proc_share_path = proc_self_path + "../share/" + proc_program_prefix()+ "yosys/";  	if (check_file_exists(proc_share_path, true))  		return proc_share_path;  #    ifdef YOSYS_DATDIR @@ -848,6 +848,15 @@ std::string proc_share_dirname()  }  #endif +std::string proc_program_prefix() +{ +	std::string program_prefix; +#ifdef YOSYS_PROGRAM_PREFIX +	program_prefix = YOSYS_PROGRAM_PREFIX; +#endif +	return program_prefix; +} +  bool fgetline(FILE *f, std::string &buffer)  {  	buffer = ""; @@ -1034,6 +1043,8 @@ void run_backend(std::string filename, std::string command, RTLIL::Design *desig  			command = "verilog";  		else if (filename.size() > 3 && filename.compare(filename.size()-3, std::string::npos, ".il") == 0)  			command = "ilang"; +		else if (filename.size() > 3 && filename.compare(filename.size()-3, std::string::npos, ".cc") == 0) +			command = "cxxrtl";  		else if (filename.size() > 4 && filename.compare(filename.size()-4, std::string::npos, ".aig") == 0)  			command = "aiger";  		else if (filename.size() > 5 && filename.compare(filename.size()-5, std::string::npos, ".blif") == 0) diff --git a/kernel/yosys.h b/kernel/yosys.h index 16e0aaf1c..ed48eec09 100644 --- a/kernel/yosys.h +++ b/kernel/yosys.h @@ -117,6 +117,10 @@ extern Tcl_Obj *Tcl_ObjSetVar2(Tcl_Interp *interp, Tcl_Obj *part1Ptr, Tcl_Obj *p  #    define PATH_MAX MAX_PATH  #    define isatty _isatty  #    define fileno _fileno +#  else +//   mingw includes `wingdi.h` which defines a TRANSPARENT macro +//   that conflicts with X(TRANSPARENT) entry in kernel/constids.inc +#    undef TRANSPARENT  #  endif  #endif @@ -207,6 +211,7 @@ namespace RTLIL {  	struct SigSpec;  	struct Wire;  	struct Cell; +	struct Memory;  	struct Module;  	struct Design;  	struct Monitor; @@ -229,6 +234,7 @@ using RTLIL::Design;  namespace hashlib {  	template<> struct hash_ops<RTLIL::Wire*> : hash_obj_ops {};  	template<> struct hash_ops<RTLIL::Cell*> : hash_obj_ops {}; +	template<> struct hash_ops<RTLIL::Memory*> : hash_obj_ops {};  	template<> struct hash_ops<RTLIL::Module*> : hash_obj_ops {};  	template<> struct hash_ops<RTLIL::Design*> : hash_obj_ops {};  	template<> struct hash_ops<RTLIL::Monitor*> : hash_obj_ops {}; @@ -236,6 +242,7 @@ namespace hashlib {  	template<> struct hash_ops<const RTLIL::Wire*> : hash_obj_ops {};  	template<> struct hash_ops<const RTLIL::Cell*> : hash_obj_ops {}; +	template<> struct hash_ops<const RTLIL::Memory*> : hash_obj_ops {};  	template<> struct hash_ops<const RTLIL::Module*> : hash_obj_ops {};  	template<> struct hash_ops<const RTLIL::Design*> : hash_obj_ops {};  	template<> struct hash_ops<const RTLIL::Monitor*> : hash_obj_ops {}; @@ -321,6 +328,7 @@ namespace ID = RTLIL::ID;  RTLIL::Design *yosys_get_design();  std::string proc_self_dirname();  std::string proc_share_dirname(); +std::string proc_program_prefix();  const char *create_prompt(RTLIL::Design *design, int recursion_counter);  std::vector<std::string> glob_filename(const std::string &filename_pattern);  void rewrite_filename(std::string &filename); | 
