diff options
| author | Noah Moroze <noahmoroze@gmail.com> | 2021-03-02 18:28:56 -0500 | 
|---|---|---|
| committer | Noah Moroze <noahmoroze@gmail.com> | 2021-03-02 18:28:56 -0500 | 
| commit | 90b40aa51f7d666792d4f0b1830ee75b81678a1f (patch) | |
| tree | 13c0b084d9d6e02128ebc7cbf3af348d0e600a4a /kernel | |
| parent | 375af199ef4df45ccf02c66e0171b4282c6cf1eb (diff) | |
| download | yosys-90b40aa51f7d666792d4f0b1830ee75b81678a1f.tar.gz yosys-90b40aa51f7d666792d4f0b1830ee75b81678a1f.tar.bz2 yosys-90b40aa51f7d666792d4f0b1830ee75b81678a1f.zip | |
clk2fflogic: nice names for autogenerated signals
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/yosys.cc | 17 | ||||
| -rw-r--r-- | kernel/yosys.h | 3 | 
2 files changed, 20 insertions, 0 deletions
| diff --git a/kernel/yosys.cc b/kernel/yosys.cc index dcaf364e9..1caf80c11 100644 --- a/kernel/yosys.cc +++ b/kernel/yosys.cc @@ -616,6 +616,23 @@ RTLIL::IdString new_id(std::string file, int line, std::string func)  	return stringf("$auto$%s:%d:%s$%d", file.c_str(), line, func.c_str(), autoidx++);  } +RTLIL::IdString new_id_suffix(std::string file, int line, std::string func, std::string suffix) +{ +#ifdef _WIN32 +	size_t pos = file.find_last_of("/\\"); +#else +	size_t pos = file.find_last_of('/'); +#endif +	if (pos != std::string::npos) +		file = file.substr(pos+1); + +	pos = func.find_last_of(':'); +	if (pos != std::string::npos) +		func = func.substr(pos+1); + +	return stringf("$auto$%s:%d:%s$%s$%d", file.c_str(), line, func.c_str(), suffix.c_str(), autoidx++); +} +  RTLIL::Design *yosys_get_design()  {  	return yosys_design; diff --git a/kernel/yosys.h b/kernel/yosys.h index 43aecdbc8..5df7e2df0 100644 --- a/kernel/yosys.h +++ b/kernel/yosys.h @@ -321,9 +321,12 @@ Tcl_Interp *yosys_get_tcl_interp();  extern RTLIL::Design *yosys_design;  RTLIL::IdString new_id(std::string file, int line, std::string func); +RTLIL::IdString new_id_suffix(std::string file, int line, std::string func, std::string suffix);  #define NEW_ID \  	YOSYS_NAMESPACE_PREFIX new_id(__FILE__, __LINE__, __FUNCTION__) +#define NEW_ID_SUFFIX(suffix) \ +	YOSYS_NAMESPACE_PREFIX new_id_suffix(__FILE__, __LINE__, __FUNCTION__, suffix)  // Create a statically allocated IdString object, using for example ID::A or ID($add).  // | 
