mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-25 08:54:37 +00:00 
			
		
		
		
	namespace Yosys
This commit is contained in:
		
							parent
							
								
									bcd2625a82
								
							
						
					
					
						commit
						f9a307a50b
					
				
					 96 changed files with 878 additions and 585 deletions
				
			
		
							
								
								
									
										4
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										4
									
								
								Makefile
									
										
									
									
									
								
							|  | @ -203,8 +203,8 @@ yosys: $(OBJS) | |||
| 
 | ||||
| kernel/version_$(GIT_REV).cc: Makefile | ||||
| 	$(P) rm -f kernel/version_*.o kernel/version_*.d kernel/version_*.cc | ||||
| 	$(Q) echo "extern const char *yosys_version_str; const char *yosys_version_str=\"Yosys $(YOSYS_VER) (git sha1 $(GIT_REV), $(CXX) ` \
 | ||||
| 			$(CXX) --version | tr ' ()' '\n' | grep '^[0-9]' | head -n1` $(filter -f% -m% -O% -DNDEBUG,$(CXXFLAGS)))\";" > kernel/version_$(GIT_REV).cc
 | ||||
| 	$(Q) echo "namespace Yosys { extern const char *yosys_version_str; const char *yosys_version_str=\"Yosys $(YOSYS_VER) (git sha1 $(GIT_REV), $(CXX) ` \
 | ||||
| 			$(CXX) --version | tr ' ()' '\n' | grep '^[0-9]' | head -n1` $(filter -f% -m% -O% -DNDEBUG,$(CXXFLAGS)))\"; }" > kernel/version_$(GIT_REV).cc
 | ||||
| 
 | ||||
| yosys-config: yosys-config.in | ||||
| 	$(P) $(SED) -e 's,@CXX@,$(CXX),;' -e 's,@CXXFLAGS@,$(CXXFLAGS),;' -e 's,@LDFLAGS@,$(LDFLAGS),;' -e 's,@LDLIBS@,$(LDLIBS),;' \
 | ||||
|  |  | |||
|  | @ -28,6 +28,9 @@ | |||
| #include "kernel/log.h" | ||||
| #include <string> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct BlifDumperConfig | ||||
| { | ||||
| 	bool icells_mode; | ||||
|  | @ -397,3 +400,4 @@ struct BlifBackend : public Backend { | |||
| 	} | ||||
| } BlifBackend; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -30,6 +30,9 @@ | |||
| #include <string> | ||||
| #include <math.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct BtorDumperConfig | ||||
| { | ||||
| 	bool subckt_mode; | ||||
|  | @ -1057,3 +1060,4 @@ struct BtorBackend : public Backend { | |||
| 	} | ||||
| } BtorBackend; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -27,6 +27,9 @@ | |||
| #include "kernel/log.h" | ||||
| #include <string> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| #define EDIF_DEF(_id) edif_names(RTLIL::unescape_id(_id), true).c_str() | ||||
| #define EDIF_REF(_id) edif_names(RTLIL::unescape_id(_id), false).c_str() | ||||
| 
 | ||||
|  | @ -345,3 +348,4 @@ struct EdifBackend : public Backend { | |||
| 	} | ||||
| } EdifBackend; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -26,7 +26,9 @@ | |||
| #include "kernel/yosys.h" | ||||
| #include <errno.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| using namespace ILANG_BACKEND; | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void ILANG_BACKEND::dump_const(std::ostream &f, const RTLIL::Const &data, int width, int offset, bool autoint) | ||||
| { | ||||
|  | @ -391,6 +393,9 @@ void ILANG_BACKEND::dump_design(std::ostream &f, RTLIL::Design *design, bool onl | |||
| 	log_assert(init_autoidx == autoidx); | ||||
| } | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct IlangBackend : public Backend { | ||||
| 	IlangBackend() : Backend("ilang", "write design to ilang file") { } | ||||
| 	virtual void help() | ||||
|  | @ -510,3 +515,4 @@ struct DumpPass : public Pass { | |||
| 	} | ||||
| } DumpPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -24,6 +24,8 @@ | |||
| #include "kernel/log.h" | ||||
| #include <string> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static std::string netname(std::set<std::string> &conntypes_code, std::set<std::string> &celltypes_code, std::set<std::string> &constcells_code, RTLIL::SigSpec sig) | ||||
| { | ||||
|  | @ -215,3 +217,4 @@ struct IntersynthBackend : public Backend { | |||
| 	} | ||||
| } IntersynthBackend; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -24,6 +24,9 @@ | |||
| #include "kernel/log.h" | ||||
| #include <string> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static void print_spice_net(std::ostream &f, RTLIL::SigBit s, std::string &neg, std::string &pos, std::string &ncpf, int &nc_counter) | ||||
| { | ||||
| 	if (s.wire) { | ||||
|  | @ -231,3 +234,4 @@ struct SpiceBackend : public Backend { | |||
| 	} | ||||
| } SpiceBackend; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -26,7 +26,6 @@ | |||
|  * | ||||
|  */ | ||||
| 
 | ||||
| #include "verilog_backend.h" | ||||
| #include "kernel/register.h" | ||||
| #include "kernel/celltypes.h" | ||||
| #include "kernel/log.h" | ||||
|  | @ -35,7 +34,8 @@ | |||
| #include <set> | ||||
| #include <map> | ||||
| 
 | ||||
| namespace { | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| bool norename, noattr, attr2comment, noexpr; | ||||
| int auto_name_counter, auto_name_offset, auto_name_digits; | ||||
|  | @ -1016,8 +1016,6 @@ void dump_module(std::ostream &f, std::string indent, RTLIL::Module *module) | |||
| 	active_module = NULL; | ||||
| } | ||||
| 
 | ||||
| } /* namespace */ | ||||
| 
 | ||||
| struct VerilogBackend : public Backend { | ||||
| 	VerilogBackend() : Backend("verilog", "write design to verilog file") { } | ||||
| 	virtual void help() | ||||
|  | @ -1139,3 +1137,4 @@ struct VerilogBackend : public Backend { | |||
| 	} | ||||
| } VerilogBackend; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -1,38 +0,0 @@ | |||
| /*
 | ||||
|  *  yosys -- Yosys Open SYnthesis Suite | ||||
|  * | ||||
|  *  Copyright (C) 2012  Clifford Wolf <clifford@clifford.at> | ||||
|  *   | ||||
|  *  Permission to use, copy, modify, and/or distribute this software for any | ||||
|  *  purpose with or without fee is hereby granted, provided that the above | ||||
|  *  copyright notice and this permission notice appear in all copies. | ||||
|  *   | ||||
|  *  THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|  *  WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|  *  MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|  *  ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|  *  WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|  *  ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
|  *  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  * | ||||
|  *  --- | ||||
|  * | ||||
|  *  A simple and straightforward verilog backend. | ||||
|  * | ||||
|  *  Note that RTLIL processes can't always be mapped easily to a Verilog | ||||
|  *  process. Therefore this frontend should only be used to export a | ||||
|  *  Verilog netlist (i.e. after the "proc" pass has converted all processes | ||||
|  *  to logic networks and registers). | ||||
|  * | ||||
|  */ | ||||
| 
 | ||||
| #ifndef VERILOG_BACKEND_H | ||||
| #define VERILOG_BACKEND_H | ||||
| 
 | ||||
| #include "kernel/yosys.h" | ||||
| 
 | ||||
| namespace VERILOG_BACKEND { | ||||
| 	void verilog_backend(std::ostream &f, std::vector<std::string> args, RTLIL::Design *design); | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
|  | @ -24,6 +24,8 @@ | |||
| #include <dlfcn.h> | ||||
| #include <ffi.h> | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| typedef void (*ffi_fptr) (); | ||||
| 
 | ||||
| static ffi_fptr resolve_fn (std::string symbol_name) | ||||
|  | @ -129,12 +131,18 @@ AST::AstNode *AST::dpi_call(const std::string &rtype, const std::string &fname, | |||
| 	return newNode; | ||||
| } | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| #else /* YOSYS_ENABLE_PLUGINS */ | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| AST::AstNode *AST::dpi_call(const std::string&, const std::string &fname, const std::vector<std::string>&, const std::vector<AstNode*>&) | ||||
| { | ||||
| 	log_error("Can't call DPI function `%s': this version of yosys is built without plugin support\n", fname.c_str()); | ||||
| } | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| #endif /* YOSYS_ENABLE_PLUGINS */ | ||||
| 
 | ||||
|  |  | |||
|  | @ -26,13 +26,13 @@ | |||
| #include "kernel/register.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void rtlil_frontend_ilang_yyerror(char const *s) | ||||
| { | ||||
| 	log_error("Parser error in line %d: %s\n", rtlil_frontend_ilang_yyget_lineno(), s); | ||||
| 	YOSYS_NAMESPACE_PREFIX log_error("Parser error in line %d: %s\n", rtlil_frontend_ilang_yyget_lineno(), s); | ||||
| } | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct IlangFrontend : public Frontend { | ||||
| 	IlangFrontend() : Frontend("ilang", "read modules from ilang file") { } | ||||
| 	virtual void help() | ||||
|  |  | |||
|  | @ -32,6 +32,8 @@ | |||
| #include "ilang_frontend.h" | ||||
| #include "parser.tab.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| 
 | ||||
| #define YY_INPUT(buf,result,max_size) \ | ||||
|         result = ILANG_FRONTEND::lexin->readsome(buf, max_size); | ||||
| 
 | ||||
|  |  | |||
|  | @ -22,7 +22,6 @@ | |||
| #include "kernel/log.h" | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| using namespace PASS_DFFLIBMAP; | ||||
| 
 | ||||
| struct token_t { | ||||
| 	char type; | ||||
|  |  | |||
|  | @ -300,22 +300,6 @@ struct VerilogFrontend : public Frontend { | |||
| 	} | ||||
| } VerilogFrontend; | ||||
| 
 | ||||
| // the yyerror function used by bison to report parser errors
 | ||||
| void frontend_verilog_yyerror(char const *fmt, ...) | ||||
| { | ||||
| 	va_list ap; | ||||
| 	char buffer[1024]; | ||||
| 	char *p = buffer; | ||||
| 	p += snprintf(p, buffer + sizeof(buffer) - p, "Parser error in line %s:%d: ", | ||||
| 			AST::current_filename.c_str(), frontend_verilog_yyget_lineno()); | ||||
| 	va_start(ap, fmt); | ||||
| 	p += vsnprintf(p, buffer + sizeof(buffer) - p, fmt, ap); | ||||
| 	va_end(ap); | ||||
| 	p += snprintf(p, buffer + sizeof(buffer) - p, "\n"); | ||||
| 	log_error("%s", buffer); | ||||
| 	exit(1); | ||||
| } | ||||
| 
 | ||||
| struct VerilogDefaults : public Pass { | ||||
| 	VerilogDefaults() : Pass("verilog_defaults", "set default options for read_verilog") { } | ||||
| 	virtual void help() | ||||
|  | @ -376,3 +360,19 @@ struct VerilogDefaults : public Pass { | |||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| // the yyerror function used by bison to report parser errors
 | ||||
| void frontend_verilog_yyerror(char const *fmt, ...) | ||||
| { | ||||
| 	va_list ap; | ||||
| 	char buffer[1024]; | ||||
| 	char *p = buffer; | ||||
| 	p += snprintf(p, buffer + sizeof(buffer) - p, "Parser error in line %s:%d: ", | ||||
| 			YOSYS_NAMESPACE_PREFIX AST::current_filename.c_str(), frontend_verilog_yyget_lineno()); | ||||
| 	va_start(ap, fmt); | ||||
| 	p += vsnprintf(p, buffer + sizeof(buffer) - p, fmt, ap); | ||||
| 	va_end(ap); | ||||
| 	p += snprintf(p, buffer + sizeof(buffer) - p, "\n"); | ||||
| 	YOSYS_NAMESPACE_PREFIX log_error("%s", buffer); | ||||
| 	exit(1); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -23,6 +23,8 @@ | |||
| #include "kernel/log.h" | ||||
| #include "kernel/rtlil.h" | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct BitPatternPool | ||||
| { | ||||
| 	int width; | ||||
|  | @ -133,4 +135,6 @@ struct BitPatternPool | |||
| 	} | ||||
| };  | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -25,6 +25,8 @@ | |||
| #include "kernel/celltypes.h" | ||||
| #include "kernel/macc.h" | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct ConstEval | ||||
| { | ||||
| 	RTLIL::Module *module; | ||||
|  | @ -376,4 +378,6 @@ struct ConstEval | |||
| 	} | ||||
| }; | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
							
								
								
									
										11
									
								
								kernel/log.h
									
										
									
									
									
								
							
							
						
						
									
										11
									
								
								kernel/log.h
									
										
									
									
									
								
							|  | @ -26,6 +26,9 @@ | |||
| #include <sys/time.h> | ||||
| #include <sys/resource.h> | ||||
| 
 | ||||
| // from libs/sha1/sha1.h
 | ||||
| class SHA1; | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| #define S__LINE__sub2(x) #x | ||||
|  | @ -37,7 +40,7 @@ struct log_cmd_error_expection { }; | |||
| extern std::vector<FILE*> log_files; | ||||
| extern std::vector<std::ostream*> log_streams; | ||||
| extern FILE *log_errfile; | ||||
| extern class SHA1 *log_hasher; | ||||
| extern SHA1 *log_hasher; | ||||
| 
 | ||||
| extern bool log_time; | ||||
| extern bool log_cmd_error_throw; | ||||
|  | @ -68,9 +71,9 @@ template<typename T> static inline const char *log_id(T *obj) { | |||
| 
 | ||||
| void log_cell(RTLIL::Cell *cell, std::string indent = ""); | ||||
| 
 | ||||
| #define log_abort() log_error("Abort in %s:%d.\n", __FILE__, __LINE__) | ||||
| #define log_assert(_assert_expr_) do { if (_assert_expr_) break; log_error("Assert `%s' failed in %s:%d.\n", #_assert_expr_, __FILE__, __LINE__); } while (0) | ||||
| #define log_ping() log("-- %s:%d %s --\n", __FILE__, __LINE__, __PRETTY_FUNCTION__) | ||||
| #define log_abort() YOSYS_NAMESPACE_PREFIX log_error("Abort in %s:%d.\n", __FILE__, __LINE__) | ||||
| #define log_assert(_assert_expr_) do { if (_assert_expr_) break; YOSYS_NAMESPACE_PREFIX log_error("Assert `%s' failed in %s:%d.\n", #_assert_expr_, __FILE__, __LINE__); } while (0) | ||||
| #define log_ping() YOSYS_NAMESPACE_PREFIX log("-- %s:%d %s --\n", __FILE__, __LINE__, __PRETTY_FUNCTION__) | ||||
| 
 | ||||
| 
 | ||||
| // ---------------------------------------------------
 | ||||
|  |  | |||
|  | @ -26,6 +26,9 @@ | |||
| #include "kernel/macc.h" | ||||
| 
 | ||||
| #include "libs/ezsat/ezminisat.h" | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| typedef ezMiniSAT ezDefaultSAT; | ||||
| 
 | ||||
| struct SatGen | ||||
|  | @ -1158,4 +1161,6 @@ struct SatGen | |||
| 	} | ||||
| }; | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -25,6 +25,8 @@ | |||
| #ifndef UTILS_H | ||||
| #define UTILS_H | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| // ------------------------------------------------
 | ||||
| // A map-like container, but you can save and restore the state
 | ||||
| // ------------------------------------------------
 | ||||
|  | @ -207,4 +209,6 @@ struct TopoSort | |||
| 	} | ||||
| }; | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -60,18 +60,10 @@ | |||
| 
 | ||||
| #define PRIVATE_NAMESPACE_BEGIN  namespace { | ||||
| #define PRIVATE_NAMESPACE_END    } | ||||
| 
 | ||||
| #if 0 | ||||
| #define YOSYS_NAMESPACE_BEGIN    namespace Yosys { | ||||
| #define YOSYS_NAMESPACE_END      } | ||||
| #define YOSYS_NAMESPACE_PREFIX   Yosys:: | ||||
| #define USING_YOSYS_NAMESPACE    using namespace Yosys; | ||||
| #else | ||||
| #  define YOSYS_NAMESPACE_BEGIN | ||||
| #  define YOSYS_NAMESPACE_END | ||||
| #  define YOSYS_NAMESPACE_PREFIX | ||||
| #  define USING_YOSYS_NAMESPACE | ||||
| #endif | ||||
| 
 | ||||
| #if __cplusplus >= 201103L | ||||
| #  define OVERRIDE override | ||||
|  |  | |||
|  | @ -53,6 +53,9 @@ | |||
| 
 | ||||
| #include "blifparse.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| enum class gate_type_t { | ||||
| 	G_NONE, | ||||
| 	G_FF, | ||||
|  | @ -1207,3 +1210,4 @@ struct AbcPass : public Pass { | |||
| 	} | ||||
| } AbcPass; | ||||
|   | ||||
|  PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -18,9 +18,8 @@ | |||
|  */ | ||||
| 
 | ||||
| #include "blifparse.h" | ||||
| #include "kernel/log.h" | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static bool read_next_line(char *&buffer, size_t &buffer_size, int &line_count, FILE *f) | ||||
| { | ||||
|  | @ -240,3 +239,5 @@ error: | |||
| 	// return NULL;
 | ||||
| } | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
|  |  | |||
|  | @ -20,9 +20,12 @@ | |||
| #ifndef ABC_BLIFPARSE | ||||
| #define ABC_BLIFPARSE | ||||
| 
 | ||||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/yosys.h" | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| extern RTLIL::Design *abc_parse_blif(FILE *f, std::string dff_name); | ||||
| 
 | ||||
| #endif | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -17,9 +17,10 @@ | |||
|  * | ||||
|  */ | ||||
| 
 | ||||
| #include "kernel/register.h" | ||||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| #include "kernel/yosys.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static void add_wire(RTLIL::Design *design, RTLIL::Module *module, std::string name, int width, bool flag_input, bool flag_output, bool flag_global) | ||||
| { | ||||
|  | @ -150,3 +151,4 @@ struct AddPass : public Pass { | |||
| 	} | ||||
| } AddPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -23,6 +23,9 @@ | |||
| #include "kernel/celltypes.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static void unset_drivers(RTLIL::Design *design, RTLIL::Module *module, SigMap &sigmap, RTLIL::SigSpec &sig) | ||||
| { | ||||
| 	CellTypes ct(design); | ||||
|  | @ -183,3 +186,4 @@ struct ConnectPass : public Pass { | |||
| 	} | ||||
| } ConnectPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,6 +22,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct ConnwrappersWorker | ||||
| { | ||||
| 	struct portdecl_t { | ||||
|  | @ -203,3 +206,4 @@ struct ConnwrappersPass : public Pass { | |||
| 	} | ||||
| } ConnwrappersPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -21,6 +21,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct CopyPass : public Pass { | ||||
| 	CopyPass() : Pass("copy", "copy modules in the design") { } | ||||
| 	virtual void help() | ||||
|  | @ -53,3 +56,4 @@ struct CopyPass : public Pass { | |||
| 	} | ||||
| } CopyPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,6 +25,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct CoverPass : public Pass { | ||||
| 	CoverPass() : Pass("cover", "print code coverage counters") { } | ||||
| 	virtual void help() | ||||
|  | @ -142,3 +145,4 @@ struct CoverPass : public Pass { | |||
| 	} | ||||
| } CoverPass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -17,9 +17,10 @@ | |||
|  * | ||||
|  */ | ||||
| 
 | ||||
| #include "kernel/register.h" | ||||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| #include "kernel/yosys.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct DeletePass : public Pass { | ||||
| 	DeletePass() : Pass("delete", "delete objects in the design") { } | ||||
|  | @ -140,3 +141,4 @@ struct DeletePass : public Pass { | |||
| 	} | ||||
| } DeletePass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,6 +22,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct LogPass : public Pass { | ||||
| 	LogPass() : Pass("log", "print text and log files") { } | ||||
| 	virtual void help() | ||||
|  | @ -76,3 +79,4 @@ struct LogPass : public Pass { | |||
| 	} | ||||
| } LogPass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -21,6 +21,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static void rename_in_module(RTLIL::Module *module, std::string from_name, std::string to_name) | ||||
| { | ||||
| 	from_name = RTLIL::escape_id(from_name); | ||||
|  | @ -196,3 +199,4 @@ struct RenamePass : public Pass { | |||
| 	} | ||||
| } RenamePass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,6 +22,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct ScatterPass : public Pass { | ||||
| 	ScatterPass() : Pass("scatter", "add additional intermediate nets") { } | ||||
| 	virtual void help() | ||||
|  | @ -67,3 +70,4 @@ struct ScatterPass : public Pass { | |||
| 	} | ||||
| } ScatterPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -29,6 +29,9 @@ | |||
| #include <stdio.h> | ||||
| #include <set> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct SccWorker | ||||
| { | ||||
| 	RTLIL::Design *design; | ||||
|  | @ -297,3 +300,4 @@ struct SccPass : public Pass { | |||
| 	} | ||||
| } SccPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,6 +25,9 @@ | |||
| #include <fnmatch.h> | ||||
| #include <errno.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| using RTLIL::id2cstr; | ||||
| 
 | ||||
| static std::vector<RTLIL::Selection> work_stack; | ||||
|  | @ -795,6 +798,9 @@ static void select_stmt(RTLIL::Design *design, std::string arg) | |||
| 	select_filter_active_mod(design, work_stack.back()); | ||||
| } | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| // used in kernel/register.cc and maybe other locations, extern decl. in register.h
 | ||||
| void handle_extra_select_args(Pass *pass, std::vector<std::string> args, size_t argidx, size_t args_size, RTLIL::Design *design) | ||||
| { | ||||
|  | @ -818,6 +824,9 @@ void handle_extra_select_args(Pass *pass, std::vector<std::string> args, size_t | |||
| 		design->selection_stack.push_back(RTLIL::Selection(false)); | ||||
| } | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct SelectPass : public Pass { | ||||
| 	SelectPass() : Pass("select", "modify and view the list of selected objects") { } | ||||
| 	virtual void help() | ||||
|  | @ -1384,3 +1393,4 @@ struct LsPass : public Pass { | |||
| 	} | ||||
| } LsPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -21,6 +21,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct setunset_t | ||||
| { | ||||
| 	RTLIL::IdString name; | ||||
|  | @ -178,3 +181,4 @@ struct SetparamPass : public Pass { | |||
| 	} | ||||
| } SetparamPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -23,6 +23,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct SetundefWorker | ||||
| { | ||||
| 	int next_bit_mode; | ||||
|  | @ -153,3 +156,4 @@ struct SetundefPass : public Pass { | |||
| 	} | ||||
| } SetundefPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -27,6 +27,9 @@ | |||
| #  include <readline/readline.h> | ||||
| #endif | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| using RTLIL::id2cstr; | ||||
| 
 | ||||
| #undef CLUSTER_CELLS_AND_PORTBOXES | ||||
|  | @ -795,3 +798,4 @@ struct ShowPass : public Pass { | |||
| 	} | ||||
| } ShowPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -24,6 +24,9 @@ | |||
| #include "kernel/log.h" | ||||
| #include <tuple> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct SpliceWorker | ||||
| { | ||||
| 	RTLIL::Design *design; | ||||
|  | @ -349,3 +352,4 @@ struct SplicePass : public Pass { | |||
| 	} | ||||
| } SplicePass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,6 +22,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct SplitnetsWorker | ||||
| { | ||||
| 	std::map<RTLIL::Wire*, std::vector<RTLIL::SigBit>> splitmap; | ||||
|  | @ -183,3 +186,4 @@ struct SplitnetsPass : public Pass { | |||
| 	} | ||||
| } SplitnetsPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -21,8 +21,9 @@ | |||
| #include "kernel/celltypes.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| namespace | ||||
| { | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct statdata_t | ||||
| { | ||||
| 	#define STAT_INT_MEMBERS X(num_wires) X(num_wire_bits) X(num_pub_wires) X(num_pub_wire_bits) \ | ||||
|  | @ -160,7 +161,6 @@ namespace | |||
| 
 | ||||
| 	return mod_data; | ||||
| } | ||||
| } | ||||
| 
 | ||||
| struct StatPass : public Pass { | ||||
| 	StatPass() : Pass("stat", "print some statistics") { } | ||||
|  | @ -243,3 +243,4 @@ struct StatPass : public Pass { | |||
| 	} | ||||
| } StatPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,6 +22,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct TeePass : public Pass { | ||||
| 	TeePass() : Pass("tee", "redirect command output to file") { } | ||||
| 	virtual void help() | ||||
|  | @ -86,3 +89,4 @@ struct TeePass : public Pass { | |||
| 	} | ||||
| } TeePass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -20,6 +20,7 @@ | |||
| 
 | ||||
| #include "kernel/yosys.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct TraceMonitor : public RTLIL::Monitor | ||||
|  |  | |||
|  | @ -20,6 +20,9 @@ | |||
| 
 | ||||
| #include "kernel/yosys.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct WriteFileFrontend : public Frontend { | ||||
| 	WriteFileFrontend() : Frontend("=write_file", "write a text to a file") { } | ||||
| 	virtual void help() | ||||
|  | @ -74,3 +77,4 @@ struct WriteFileFrontend : public Frontend { | |||
| 	} | ||||
| } WriteFileFrontend; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,6 +22,9 @@ | |||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct FsmPass : public Pass { | ||||
| 	FsmPass() : Pass("fsm", "extract and optimize finite state machines") { } | ||||
| 	virtual void help() | ||||
|  | @ -137,3 +140,4 @@ struct FsmPass : public Pass { | |||
| 	} | ||||
| } FsmPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -24,6 +24,9 @@ | |||
| #include "kernel/celltypes.h" | ||||
| #include "fsmdata.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static RTLIL::Module *module; | ||||
| static SigMap assign_map; | ||||
| typedef std::pair<RTLIL::Cell*, RTLIL::IdString> sig2driver_entry_t; | ||||
|  | @ -189,3 +192,4 @@ struct FsmDetectPass : public Pass { | |||
| 	} | ||||
| } FsmDetectPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,6 +25,9 @@ | |||
| #include "fsmdata.h" | ||||
| #include <string.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct FsmExpand | ||||
| { | ||||
| 	RTLIL::Module *module; | ||||
|  | @ -273,3 +276,4 @@ struct FsmExpandPass : public Pass { | |||
| 	} | ||||
| } FsmExpandPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -28,6 +28,9 @@ | |||
| #include <iostream> | ||||
| #include <fstream> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| /**
 | ||||
|  * Convert a signal into a KISS-compatible textual representation. | ||||
|  */ | ||||
|  | @ -182,3 +185,5 @@ struct FsmExportPass : public Pass { | |||
| 					} | ||||
| 	} | ||||
| } FsmExportPass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -29,6 +29,9 @@ | |||
| #include "kernel/celltypes.h" | ||||
| #include "fsmdata.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static RTLIL::Module *module; | ||||
| static SigMap assign_map; | ||||
| typedef std::pair<RTLIL::IdString, RTLIL::IdString> sig2driver_entry_t; | ||||
|  | @ -456,3 +459,4 @@ struct FsmExtractPass : public Pass { | |||
| 	} | ||||
| } FsmExtractPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,6 +25,9 @@ | |||
| #include "fsmdata.h" | ||||
| #include <string.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct FsmInfoPass : public Pass { | ||||
| 	FsmInfoPass() : Pass("fsm_info", "print information on finite state machines") { } | ||||
| 	virtual void help() | ||||
|  | @ -56,3 +59,4 @@ struct FsmInfoPass : public Pass { | |||
| 	} | ||||
| } FsmInfoPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,6 +25,9 @@ | |||
| #include "fsmdata.h" | ||||
| #include <string.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static bool pattern_is_subset(const RTLIL::Const &super_pattern, const RTLIL::Const &sub_pattern) | ||||
| { | ||||
| 	log_assert(SIZE(super_pattern.bits) == SIZE(sub_pattern.bits)); | ||||
|  | @ -345,3 +348,4 @@ struct FsmMapPass : public Pass { | |||
| 	} | ||||
| } FsmMapPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,6 +25,9 @@ | |||
| #include "fsmdata.h" | ||||
| #include <string.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct FsmOpt | ||||
| { | ||||
| 	FsmData fsm_data; | ||||
|  | @ -309,11 +312,15 @@ struct FsmOpt | |||
| 	} | ||||
| }; | ||||
| 
 | ||||
| void FsmData::optimize_fsm(RTLIL::Cell *cell, RTLIL::Module *module) | ||||
| PRIVATE_NAMESPACE_END | ||||
| 
 | ||||
| void YOSYS_NAMESPACE_PREFIX FsmData::optimize_fsm(RTLIL::Cell *cell, RTLIL::Module *module) | ||||
| { | ||||
| 	FsmOpt fsmopt(cell, module); | ||||
| } | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct FsmOptPass : public Pass { | ||||
| 	FsmOptPass() : Pass("fsm_opt", "optimize finite state machines") { } | ||||
| 	virtual void help() | ||||
|  | @ -341,3 +348,4 @@ struct FsmOptPass : public Pass { | |||
| 	} | ||||
| } FsmOptPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -27,6 +27,9 @@ | |||
| #include <string.h> | ||||
| #include <errno.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static void fm_set_fsm_print(RTLIL::Cell *cell, RTLIL::Module *module, FsmData &fsm_data, const char *prefix, FILE *f) | ||||
| { | ||||
| 	std::string name = cell->parameters["\\NAME"].decode_string(); | ||||
|  | @ -168,3 +171,4 @@ struct FsmRecodePass : public Pass { | |||
| 	} | ||||
| } FsmRecodePass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -20,8 +20,9 @@ | |||
| #ifndef FSMDATA_H | ||||
| #define FSMDATA_H | ||||
| 
 | ||||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| #include "kernel/yosys.h" | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct FsmData | ||||
| { | ||||
|  | @ -172,4 +173,6 @@ struct FsmData | |||
| 	static void optimize_fsm(RTLIL::Cell *cell, RTLIL::Module *module); | ||||
| }; | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -25,15 +25,16 @@ | |||
| #include <set> | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| namespace { | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct generate_port_decl_t { | ||||
| 	bool input, output; | ||||
| 	RTLIL::IdString portname; | ||||
| 	int index; | ||||
| }; | ||||
| } | ||||
| 
 | ||||
| static void generate(RTLIL::Design *design, const std::vector<std::string> &celltypes, const std::vector<generate_port_decl_t> &portdecls) | ||||
| void generate(RTLIL::Design *design, const std::vector<std::string> &celltypes, const std::vector<generate_port_decl_t> &portdecls) | ||||
| { | ||||
| 	std::set<RTLIL::IdString> found_celltypes; | ||||
| 
 | ||||
|  | @ -135,7 +136,7 @@ static void generate(RTLIL::Design *design, const std::vector<std::string> &cell | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static bool expand_module(RTLIL::Design *design, RTLIL::Module *module, bool flag_check, std::vector<std::string> &libdirs) | ||||
| bool expand_module(RTLIL::Design *design, RTLIL::Module *module, bool flag_check, std::vector<std::string> &libdirs) | ||||
| { | ||||
| 	bool did_something = false; | ||||
| 	std::map<RTLIL::Cell*, std::pair<int, int>> array_cells; | ||||
|  | @ -245,7 +246,7 @@ static bool expand_module(RTLIL::Design *design, RTLIL::Module *module, bool fla | |||
| 	return did_something; | ||||
| } | ||||
| 
 | ||||
| static void hierarchy_worker(RTLIL::Design *design, std::set<RTLIL::Module*> &used, RTLIL::Module *mod, int indent) | ||||
| void hierarchy_worker(RTLIL::Design *design, std::set<RTLIL::Module*> &used, RTLIL::Module *mod, int indent) | ||||
| { | ||||
| 	if (used.count(mod) > 0) | ||||
| 		return; | ||||
|  | @ -262,7 +263,7 @@ static void hierarchy_worker(RTLIL::Design *design, std::set<RTLIL::Module*> &us | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void hierarchy(RTLIL::Design *design, RTLIL::Module *top, bool purge_lib, bool first_pass) | ||||
| void hierarchy(RTLIL::Design *design, RTLIL::Module *top, bool purge_lib, bool first_pass) | ||||
| { | ||||
| 	std::set<RTLIL::Module*> used; | ||||
| 	hierarchy_worker(design, used, top, 0); | ||||
|  | @ -528,3 +529,4 @@ struct HierarchyPass : public Pass { | |||
| 	} | ||||
| } HierarchyPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -24,6 +24,9 @@ | |||
| #include <stdio.h> | ||||
| #include <set> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct SubmodWorker | ||||
| { | ||||
| 	CellTypes ct; | ||||
|  | @ -347,3 +350,4 @@ struct SubmodPass : public Pass { | |||
| 	} | ||||
| } SubmodPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,6 +22,9 @@ | |||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct MemoryPass : public Pass { | ||||
| 	MemoryPass() : Pass("memory", "translate memories to basic cells") { } | ||||
| 	virtual void help() | ||||
|  | @ -73,3 +76,4 @@ struct MemoryPass : public Pass { | |||
| 	} | ||||
| } MemoryPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -23,7 +23,10 @@ | |||
| #include <algorithm> | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| static bool memcells_cmp(RTLIL::Cell *a, RTLIL::Cell *b) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| bool memcells_cmp(RTLIL::Cell *a, RTLIL::Cell *b) | ||||
| { | ||||
| 	if (a->type == "$memrd" && b->type == "$memrd") | ||||
| 		return a->name < b->name; | ||||
|  | @ -32,7 +35,7 @@ static bool memcells_cmp(RTLIL::Cell *a, RTLIL::Cell *b) | |||
| 	return a->parameters.at("\\PRIORITY").as_int() < b->parameters.at("\\PRIORITY").as_int(); | ||||
| } | ||||
| 
 | ||||
| static void handle_memory(RTLIL::Module *module, RTLIL::Memory *memory) | ||||
| void handle_memory(RTLIL::Module *module, RTLIL::Memory *memory) | ||||
| { | ||||
| 	log("Collecting $memrd and $memwr for memory `%s' in module `%s':\n", | ||||
| 			memory->name.c_str(), module->name.c_str()); | ||||
|  | @ -205,3 +208,4 @@ struct MemoryCollectPass : public Pass { | |||
| 	} | ||||
| } MemoryCollectPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,13 +22,16 @@ | |||
| #include <stdlib.h> | ||||
| #include <sstream> | ||||
| 
 | ||||
| static void normalize_sig(RTLIL::Module *module, RTLIL::SigSpec &sig) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void normalize_sig(RTLIL::Module *module, RTLIL::SigSpec &sig) | ||||
| { | ||||
| 	for (auto &conn : module->connections()) | ||||
| 		sig.replace(conn.first, conn.second); | ||||
| } | ||||
| 
 | ||||
| static bool find_sig_before_dff(RTLIL::Module *module, std::vector<RTLIL::Cell*> &dff_cells, RTLIL::SigSpec &sig, RTLIL::SigSpec &clk, bool &clk_polarity, bool after = false) | ||||
| bool find_sig_before_dff(RTLIL::Module *module, std::vector<RTLIL::Cell*> &dff_cells, RTLIL::SigSpec &sig, RTLIL::SigSpec &clk, bool &clk_polarity, bool after = false) | ||||
| { | ||||
| 	normalize_sig(module, sig); | ||||
| 
 | ||||
|  | @ -66,7 +69,7 @@ static bool find_sig_before_dff(RTLIL::Module *module, std::vector<RTLIL::Cell*> | |||
| 	return true; | ||||
| } | ||||
| 
 | ||||
| static void handle_wr_cell(RTLIL::Module *module, std::vector<RTLIL::Cell*> &dff_cells, RTLIL::Cell *cell) | ||||
| void handle_wr_cell(RTLIL::Module *module, std::vector<RTLIL::Cell*> &dff_cells, RTLIL::Cell *cell) | ||||
| { | ||||
| 	log("Checking cell `%s' in module `%s': ", cell->name.c_str(), module->name.c_str()); | ||||
| 
 | ||||
|  | @ -105,7 +108,7 @@ static void handle_wr_cell(RTLIL::Module *module, std::vector<RTLIL::Cell*> &dff | |||
| 	log("no (compatible) $dff found.\n"); | ||||
| } | ||||
| 
 | ||||
| static void disconnect_dff(RTLIL::Module *module, RTLIL::SigSpec sig) | ||||
| void disconnect_dff(RTLIL::Module *module, RTLIL::SigSpec sig) | ||||
| { | ||||
| 	normalize_sig(module, sig); | ||||
| 	sig.sort_and_unify(); | ||||
|  | @ -123,7 +126,7 @@ static void disconnect_dff(RTLIL::Module *module, RTLIL::SigSpec sig) | |||
| 		} | ||||
| } | ||||
| 
 | ||||
| static void handle_rd_cell(RTLIL::Module *module, std::vector<RTLIL::Cell*> &dff_cells, RTLIL::Cell *cell) | ||||
| void handle_rd_cell(RTLIL::Module *module, std::vector<RTLIL::Cell*> &dff_cells, RTLIL::Cell *cell) | ||||
| { | ||||
| 	log("Checking cell `%s' in module `%s': ", cell->name.c_str(), module->name.c_str()); | ||||
| 
 | ||||
|  | @ -161,7 +164,7 @@ static void handle_rd_cell(RTLIL::Module *module, std::vector<RTLIL::Cell*> &dff | |||
| 	log("no (compatible) $dff found.\n"); | ||||
| } | ||||
| 
 | ||||
| static void handle_module(RTLIL::Module *module, bool flag_wr_only) | ||||
| void handle_module(RTLIL::Module *module, bool flag_wr_only) | ||||
| { | ||||
| 	std::vector<RTLIL::Cell*> dff_cells; | ||||
| 
 | ||||
|  | @ -216,3 +219,4 @@ struct MemoryDffPass : public Pass { | |||
| 	} | ||||
| } MemoryDffPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -23,6 +23,9 @@ | |||
| #include <set> | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct MemoryMapWorker | ||||
| { | ||||
| 	RTLIL::Design *design; | ||||
|  | @ -339,3 +342,4 @@ struct MemoryMapPass : public Pass { | |||
| 	} | ||||
| } MemoryMapPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,9 +22,10 @@ | |||
| #include "kernel/sigtools.h" | ||||
| #include "kernel/modtools.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static bool memcells_cmp(RTLIL::Cell *a, RTLIL::Cell *b) | ||||
| bool memcells_cmp(RTLIL::Cell *a, RTLIL::Cell *b) | ||||
| { | ||||
| 	if (a->type == "$memrd" && b->type == "$memrd") | ||||
| 		return a->name < b->name; | ||||
|  | @ -741,4 +742,3 @@ struct MemorySharePass : public Pass { | |||
| } MemorySharePass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
| 
 | ||||
|  |  | |||
|  | @ -23,7 +23,10 @@ | |||
| #include <algorithm> | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| static void handle_memory(RTLIL::Module *module, RTLIL::Cell *memory) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void handle_memory(RTLIL::Module *module, RTLIL::Cell *memory) | ||||
| { | ||||
| 	log("Creating $memrd and $memwr for memory `%s' in module `%s':\n", | ||||
| 			memory->name.c_str(), module->name.c_str()); | ||||
|  | @ -76,7 +79,7 @@ static void handle_memory(RTLIL::Module *module, RTLIL::Cell *memory) | |||
| 	module->remove(memory); | ||||
| } | ||||
| 
 | ||||
| static void handle_module(RTLIL::Design *design, RTLIL::Module *module) | ||||
| void handle_module(RTLIL::Design *design, RTLIL::Module *module) | ||||
| { | ||||
| 	std::vector<RTLIL::IdString> memcells; | ||||
| 	for (auto &cell_it : module->cells_) | ||||
|  | @ -107,3 +110,4 @@ struct MemoryUnpackPass : public Pass { | |||
| 	} | ||||
| } MemoryUnpackPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,6 +22,9 @@ | |||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct OptPass : public Pass { | ||||
| 	OptPass() : Pass("opt", "perform simple optimizations") { } | ||||
| 	virtual void help() | ||||
|  | @ -142,3 +145,4 @@ struct OptPass : public Pass { | |||
| 	} | ||||
| } OptPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,12 +25,15 @@ | |||
| #include <stdio.h> | ||||
| #include <set> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| using RTLIL::id2cstr; | ||||
| 
 | ||||
| static CellTypes ct, ct_reg, ct_all; | ||||
| static int count_rm_cells, count_rm_wires; | ||||
| CellTypes ct, ct_reg, ct_all; | ||||
| int count_rm_cells, count_rm_wires; | ||||
| 
 | ||||
| static void rmunused_module_cells(RTLIL::Module *module, bool verbose) | ||||
| void rmunused_module_cells(RTLIL::Module *module, bool verbose) | ||||
| { | ||||
| 	SigMap assign_map(module); | ||||
| 	std::set<RTLIL::Cell*, RTLIL::sort_by_name_id<RTLIL::Cell>> queue, unused; | ||||
|  | @ -93,7 +96,7 @@ static void rmunused_module_cells(RTLIL::Module *module, bool verbose) | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static int count_nontrivial_wire_attrs(RTLIL::Wire *w) | ||||
| int count_nontrivial_wire_attrs(RTLIL::Wire *w) | ||||
| { | ||||
| 	int count = w->attributes.size(); | ||||
| 	count -= w->attributes.count("\\src"); | ||||
|  | @ -101,7 +104,7 @@ static int count_nontrivial_wire_attrs(RTLIL::Wire *w) | |||
| 	return count; | ||||
| } | ||||
| 
 | ||||
| static bool compare_signals(RTLIL::SigBit &s1, RTLIL::SigBit &s2, SigPool ®s, SigPool &conns, std::set<RTLIL::Wire*> &direct_wires) | ||||
| bool compare_signals(RTLIL::SigBit &s1, RTLIL::SigBit &s2, SigPool ®s, SigPool &conns, std::set<RTLIL::Wire*> &direct_wires) | ||||
| { | ||||
| 	RTLIL::Wire *w1 = s1.wire; | ||||
| 	RTLIL::Wire *w2 = s2.wire; | ||||
|  | @ -136,7 +139,7 @@ static bool compare_signals(RTLIL::SigBit &s1, RTLIL::SigBit &s2, SigPool ®s, | |||
| 	return w2->name < w1->name; | ||||
| } | ||||
| 
 | ||||
| static bool check_public_name(RTLIL::IdString id) | ||||
| bool check_public_name(RTLIL::IdString id) | ||||
| { | ||||
| 	const std::string &id_str = id.str(); | ||||
| 	if (id_str[0] == '$') | ||||
|  | @ -148,7 +151,7 @@ static bool check_public_name(RTLIL::IdString id) | |||
| 	return true; | ||||
| } | ||||
| 
 | ||||
| static void rmunused_module_signals(RTLIL::Module *module, bool purge_mode, bool verbose) | ||||
| void rmunused_module_signals(RTLIL::Module *module, bool purge_mode, bool verbose) | ||||
| { | ||||
| 	SigPool register_signals; | ||||
| 	SigPool connected_signals; | ||||
|  | @ -285,7 +288,7 @@ static void rmunused_module_signals(RTLIL::Module *module, bool purge_mode, bool | |||
| 		log("  removed %d unused temporary wires.\n", del_wires_count); | ||||
| } | ||||
| 
 | ||||
| static void rmunused_module(RTLIL::Module *module, bool purge_mode, bool verbose) | ||||
| void rmunused_module(RTLIL::Module *module, bool purge_mode, bool verbose) | ||||
| { | ||||
| 	if (verbose) | ||||
| 		log("Finding unused cells or wires in module %s..\n", module->name.c_str()); | ||||
|  | @ -419,3 +422,4 @@ struct CleanPass : public Pass { | |||
| 	} | ||||
| } CleanPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -26,9 +26,12 @@ | |||
| #include <stdio.h> | ||||
| #include <algorithm> | ||||
| 
 | ||||
| static bool did_something; | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static void replace_undriven(RTLIL::Design *design, RTLIL::Module *module) | ||||
| bool did_something; | ||||
| 
 | ||||
| void replace_undriven(RTLIL::Design *design, RTLIL::Module *module) | ||||
| { | ||||
| 	CellTypes ct(design); | ||||
| 	SigMap sigmap(module); | ||||
|  | @ -70,7 +73,7 @@ static void replace_undriven(RTLIL::Design *design, RTLIL::Module *module) | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void replace_cell(SigMap &assign_map, RTLIL::Module *module, RTLIL::Cell *cell, std::string info, std::string out_port, RTLIL::SigSpec out_val) | ||||
| void replace_cell(SigMap &assign_map, RTLIL::Module *module, RTLIL::Cell *cell, std::string info, std::string out_port, RTLIL::SigSpec out_val) | ||||
| { | ||||
| 	RTLIL::SigSpec Y = cell->getPort(out_port); | ||||
| 	out_val.extend_u0(Y.size(), false); | ||||
|  | @ -85,7 +88,7 @@ static void replace_cell(SigMap &assign_map, RTLIL::Module *module, RTLIL::Cell | |||
| 	did_something = true; | ||||
| } | ||||
| 
 | ||||
| static bool group_cell_inputs(RTLIL::Module *module, RTLIL::Cell *cell, bool commutative, SigMap &sigmap) | ||||
| bool group_cell_inputs(RTLIL::Module *module, RTLIL::Cell *cell, bool commutative, SigMap &sigmap) | ||||
| { | ||||
| 	std::string b_name = cell->hasPort("\\B") ? "\\B" : "\\A"; | ||||
| 
 | ||||
|  | @ -183,7 +186,7 @@ static bool group_cell_inputs(RTLIL::Module *module, RTLIL::Cell *cell, bool com | |||
| 	return true; | ||||
| } | ||||
| 
 | ||||
| static void replace_const_cells(RTLIL::Design *design, RTLIL::Module *module, bool consume_x, bool mux_undef, bool mux_bool, bool do_fine, bool keepdc) | ||||
| void replace_const_cells(RTLIL::Design *design, RTLIL::Module *module, bool consume_x, bool mux_undef, bool mux_bool, bool do_fine, bool keepdc) | ||||
| { | ||||
| 	if (!design->selected(module)) | ||||
| 		return; | ||||
|  | @ -1006,3 +1009,4 @@ struct OptConstPass : public Pass { | |||
| 	} | ||||
| } OptConstPass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,6 +25,9 @@ | |||
| #include <stdio.h> | ||||
| #include <set> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| using RTLIL::id2cstr; | ||||
| 
 | ||||
| struct OptMuxtreeWorker | ||||
|  | @ -438,3 +441,4 @@ struct OptMuxtreePass : public Pass { | |||
| 	} | ||||
| } OptMuxtreePass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,6 +25,9 @@ | |||
| #include <stdio.h> | ||||
| #include <set> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct OptReduceWorker | ||||
| { | ||||
| 	RTLIL::Design *design; | ||||
|  | @ -378,3 +381,4 @@ struct OptReducePass : public Pass { | |||
| 	} | ||||
| } OptReducePass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -23,10 +23,13 @@ | |||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| static SigMap assign_map, dff_init_map; | ||||
| static SigSet<RTLIL::Cell*> mux_drivers; | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static bool handle_dff(RTLIL::Module *mod, RTLIL::Cell *dff) | ||||
| SigMap assign_map, dff_init_map; | ||||
| SigSet<RTLIL::Cell*> mux_drivers; | ||||
| 
 | ||||
| bool handle_dff(RTLIL::Module *mod, RTLIL::Cell *dff) | ||||
| { | ||||
| 	RTLIL::SigSpec sig_d, sig_q, sig_c, sig_r; | ||||
| 	RTLIL::Const val_cp, val_rp, val_rv; | ||||
|  | @ -215,3 +218,4 @@ struct OptRmdffPass : public Pass { | |||
| 	} | ||||
| } OptRmdffPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -28,6 +28,9 @@ | |||
| 
 | ||||
| #define USE_CELL_HASH_CACHE | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct OptShareWorker | ||||
| { | ||||
| 	RTLIL::Design *design; | ||||
|  | @ -319,3 +322,4 @@ struct OptSharePass : public Pass { | |||
| 	} | ||||
| } OptSharePass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -23,6 +23,7 @@ | |||
| #include "kernel/modtools.h" | ||||
| #include "kernel/utils.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct ShareWorkerConfig | ||||
|  | @ -1168,4 +1169,3 @@ struct SharePass : public Pass { | |||
| } SharePass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
| 
 | ||||
|  |  | |||
|  | @ -22,6 +22,9 @@ | |||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct ProcPass : public Pass { | ||||
| 	ProcPass() : Pass("proc", "translate processes to netlists") { } | ||||
| 	virtual void help() | ||||
|  | @ -81,3 +84,4 @@ struct ProcPass : public Pass { | |||
| 	} | ||||
| } ProcPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -23,10 +23,14 @@ | |||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| // defined in proc_clean.cc
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| extern void proc_clean_case(RTLIL::CaseRule *cs, bool &did_something, int &count, int max_depth); | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| static bool check_signal(RTLIL::Module *mod, RTLIL::SigSpec signal, RTLIL::SigSpec ref, bool &polarity) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| bool check_signal(RTLIL::Module *mod, RTLIL::SigSpec signal, RTLIL::SigSpec ref, bool &polarity) | ||||
| { | ||||
| 	if (signal.size() != 1) | ||||
| 		return false; | ||||
|  | @ -81,7 +85,7 @@ static bool check_signal(RTLIL::Module *mod, RTLIL::SigSpec signal, RTLIL::SigSp | |||
| 	return false; | ||||
| } | ||||
| 
 | ||||
| static void apply_const(RTLIL::Module *mod, const RTLIL::SigSpec rspec, RTLIL::SigSpec &rval, RTLIL::CaseRule *cs, RTLIL::SigSpec const_sig, bool polarity, bool unknown) | ||||
| void apply_const(RTLIL::Module *mod, const RTLIL::SigSpec rspec, RTLIL::SigSpec &rval, RTLIL::CaseRule *cs, RTLIL::SigSpec const_sig, bool polarity, bool unknown) | ||||
| { | ||||
| 	for (auto &action : cs->actions) { | ||||
| 		if (unknown) | ||||
|  | @ -114,7 +118,7 @@ static void apply_const(RTLIL::Module *mod, const RTLIL::SigSpec rspec, RTLIL::S | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void eliminate_const(RTLIL::Module *mod, RTLIL::CaseRule *cs, RTLIL::SigSpec const_sig, bool polarity) | ||||
| void eliminate_const(RTLIL::Module *mod, RTLIL::CaseRule *cs, RTLIL::SigSpec const_sig, bool polarity) | ||||
| { | ||||
| 	for (auto sw : cs->switches) { | ||||
| 		bool this_polarity = polarity; | ||||
|  | @ -149,7 +153,7 @@ static void eliminate_const(RTLIL::Module *mod, RTLIL::CaseRule *cs, RTLIL::SigS | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void proc_arst(RTLIL::Module *mod, RTLIL::Process *proc, SigMap &assign_map) | ||||
| void proc_arst(RTLIL::Module *mod, RTLIL::Process *proc, SigMap &assign_map) | ||||
| { | ||||
| restart_proc_arst: | ||||
| 	if (proc->root_case.switches.size() != 1) | ||||
|  | @ -280,3 +284,4 @@ struct ProcArstPass : public Pass { | |||
| 	} | ||||
| } ProcArstPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,8 +22,12 @@ | |||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| extern void proc_clean_switch(RTLIL::SwitchRule *sw, RTLIL::CaseRule *parent, bool &did_something, int &count, int max_depth); | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| extern void proc_clean_case(RTLIL::CaseRule *cs, bool &did_something, int &count, int max_depth); | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void proc_clean_switch(RTLIL::SwitchRule *sw, RTLIL::CaseRule *parent, bool &did_something, int &count, int max_depth) | ||||
| { | ||||
|  | @ -89,6 +93,9 @@ void proc_clean_switch(RTLIL::SwitchRule *sw, RTLIL::CaseRule *parent, bool &did | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void proc_clean_case(RTLIL::CaseRule *cs, bool &did_something, int &count, int max_depth) | ||||
| { | ||||
| 	for (size_t i = 0; i < cs->actions.size(); i++) { | ||||
|  | @ -109,7 +116,10 @@ void proc_clean_case(RTLIL::CaseRule *cs, bool &did_something, int &count, int m | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void proc_clean(RTLIL::Module *mod, RTLIL::Process *proc, int &total_count) | ||||
| YOSYS_NAMESPACE_END | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void proc_clean(RTLIL::Module *mod, RTLIL::Process *proc, int &total_count) | ||||
| { | ||||
| 	int count = 0; | ||||
| 	bool did_something = true; | ||||
|  | @ -174,3 +184,4 @@ struct ProcCleanPass : public Pass { | |||
| 	} | ||||
| } ProcCleanPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,7 +25,10 @@ | |||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| static RTLIL::SigSpec find_any_lvalue(const RTLIL::Process *proc) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| RTLIL::SigSpec find_any_lvalue(const RTLIL::Process *proc) | ||||
| { | ||||
| 	RTLIL::SigSpec lvalue; | ||||
| 
 | ||||
|  | @ -50,7 +53,7 @@ static RTLIL::SigSpec find_any_lvalue(const RTLIL::Process *proc) | |||
| 	return lvalue; | ||||
| } | ||||
| 
 | ||||
| static void gen_dffsr_complex(RTLIL::Module *mod, RTLIL::SigSpec sig_d, RTLIL::SigSpec sig_q, RTLIL::SigSpec clk, bool clk_polarity, | ||||
| void gen_dffsr_complex(RTLIL::Module *mod, RTLIL::SigSpec sig_d, RTLIL::SigSpec sig_q, RTLIL::SigSpec clk, bool clk_polarity, | ||||
| 		std::map<RTLIL::SigSpec, std::set<RTLIL::SyncRule*>> &async_rules, RTLIL::Process *proc) | ||||
| { | ||||
| 	RTLIL::SigSpec sig_sr_set = RTLIL::SigSpec(0, sig_d.size()); | ||||
|  | @ -140,7 +143,7 @@ static void gen_dffsr_complex(RTLIL::Module *mod, RTLIL::SigSpec sig_d, RTLIL::S | |||
| 			cell->type.c_str(), cell->name.c_str(), clk_polarity ? "positive" : "negative"); | ||||
| } | ||||
| 
 | ||||
| static void gen_dffsr(RTLIL::Module *mod, RTLIL::SigSpec sig_in, RTLIL::SigSpec sig_set, RTLIL::SigSpec sig_out, | ||||
| void gen_dffsr(RTLIL::Module *mod, RTLIL::SigSpec sig_in, RTLIL::SigSpec sig_set, RTLIL::SigSpec sig_out, | ||||
| 		bool clk_polarity, bool set_polarity, RTLIL::SigSpec clk, RTLIL::SigSpec set, RTLIL::Process *proc) | ||||
| { | ||||
| 	std::stringstream sstr; | ||||
|  | @ -187,7 +190,7 @@ static void gen_dffsr(RTLIL::Module *mod, RTLIL::SigSpec sig_in, RTLIL::SigSpec | |||
| 			clk_polarity ? "positive" : "negative", set_polarity ? "positive" : "negative"); | ||||
| } | ||||
| 
 | ||||
| static void gen_dff(RTLIL::Module *mod, RTLIL::SigSpec sig_in, RTLIL::Const val_rst, RTLIL::SigSpec sig_out, | ||||
| void gen_dff(RTLIL::Module *mod, RTLIL::SigSpec sig_in, RTLIL::Const val_rst, RTLIL::SigSpec sig_out, | ||||
| 		bool clk_polarity, bool arst_polarity, RTLIL::SigSpec clk, RTLIL::SigSpec *arst, RTLIL::Process *proc) | ||||
| { | ||||
| 	std::stringstream sstr; | ||||
|  | @ -215,7 +218,7 @@ static void gen_dff(RTLIL::Module *mod, RTLIL::SigSpec sig_in, RTLIL::Const val_ | |||
| 	log(".\n"); | ||||
| } | ||||
| 
 | ||||
| static void proc_dff(RTLIL::Module *mod, RTLIL::Process *proc, ConstEval &ce) | ||||
| void proc_dff(RTLIL::Module *mod, RTLIL::Process *proc, ConstEval &ce) | ||||
| { | ||||
| 	while (1) | ||||
| 	{ | ||||
|  | @ -380,3 +383,4 @@ struct ProcDffPass : public Pass { | |||
| 	} | ||||
| } ProcDffPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -23,7 +23,10 @@ | |||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| static void proc_get_const(RTLIL::SigSpec &sig, RTLIL::CaseRule &rule) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void proc_get_const(RTLIL::SigSpec &sig, RTLIL::CaseRule &rule) | ||||
| { | ||||
| 	log_assert(rule.compare.size() == 0); | ||||
| 
 | ||||
|  | @ -37,7 +40,7 @@ static void proc_get_const(RTLIL::SigSpec &sig, RTLIL::CaseRule &rule) | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void proc_init(RTLIL::Module *mod, RTLIL::Process *proc) | ||||
| void proc_init(RTLIL::Module *mod, RTLIL::Process *proc) | ||||
| { | ||||
| 	bool found_init = false; | ||||
| 
 | ||||
|  | @ -109,3 +112,4 @@ struct ProcInitPass : public Pass { | |||
| 	} | ||||
| } ProcInitPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -24,7 +24,10 @@ | |||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| static RTLIL::SigSpec find_any_lvalue(const RTLIL::CaseRule *cs) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| RTLIL::SigSpec find_any_lvalue(const RTLIL::CaseRule *cs) | ||||
| { | ||||
| 	for (auto &action : cs->actions) { | ||||
| 		if (action.first.size()) | ||||
|  | @ -41,7 +44,7 @@ static RTLIL::SigSpec find_any_lvalue(const RTLIL::CaseRule *cs) | |||
| 	return RTLIL::SigSpec(); | ||||
| } | ||||
| 
 | ||||
| static void extract_core_signal(const RTLIL::CaseRule *cs, RTLIL::SigSpec &sig) | ||||
| void extract_core_signal(const RTLIL::CaseRule *cs, RTLIL::SigSpec &sig) | ||||
| { | ||||
| 	for (auto &action : cs->actions) { | ||||
| 		RTLIL::SigSpec lvalue = action.first.extract(sig); | ||||
|  | @ -54,7 +57,7 @@ static void extract_core_signal(const RTLIL::CaseRule *cs, RTLIL::SigSpec &sig) | |||
| 		extract_core_signal(cs2, sig); | ||||
| } | ||||
| 
 | ||||
| static RTLIL::SigSpec gen_cmp(RTLIL::Module *mod, const RTLIL::SigSpec &signal, const std::vector<RTLIL::SigSpec> &compare, RTLIL::SwitchRule *sw) | ||||
| RTLIL::SigSpec gen_cmp(RTLIL::Module *mod, const RTLIL::SigSpec &signal, const std::vector<RTLIL::SigSpec> &compare, RTLIL::SwitchRule *sw) | ||||
| { | ||||
| 	std::stringstream sstr; | ||||
| 	sstr << "$procmux$" << (autoidx++); | ||||
|  | @ -122,7 +125,7 @@ static RTLIL::SigSpec gen_cmp(RTLIL::Module *mod, const RTLIL::SigSpec &signal, | |||
| 	return RTLIL::SigSpec(ctrl_wire); | ||||
| } | ||||
| 
 | ||||
| static RTLIL::SigSpec gen_mux(RTLIL::Module *mod, const RTLIL::SigSpec &signal, const std::vector<RTLIL::SigSpec> &compare, RTLIL::SigSpec when_signal, RTLIL::SigSpec else_signal, RTLIL::Cell *&last_mux_cell, RTLIL::SwitchRule *sw) | ||||
| RTLIL::SigSpec gen_mux(RTLIL::Module *mod, const RTLIL::SigSpec &signal, const std::vector<RTLIL::SigSpec> &compare, RTLIL::SigSpec when_signal, RTLIL::SigSpec else_signal, RTLIL::Cell *&last_mux_cell, RTLIL::SwitchRule *sw) | ||||
| { | ||||
| 	log_assert(when_signal.size() == else_signal.size()); | ||||
| 
 | ||||
|  | @ -156,7 +159,7 @@ static RTLIL::SigSpec gen_mux(RTLIL::Module *mod, const RTLIL::SigSpec &signal, | |||
| 	return RTLIL::SigSpec(result_wire); | ||||
| } | ||||
| 
 | ||||
| static void append_pmux(RTLIL::Module *mod, const RTLIL::SigSpec &signal, const std::vector<RTLIL::SigSpec> &compare, RTLIL::SigSpec when_signal, RTLIL::Cell *last_mux_cell, RTLIL::SwitchRule *sw) | ||||
| void append_pmux(RTLIL::Module *mod, const RTLIL::SigSpec &signal, const std::vector<RTLIL::SigSpec> &compare, RTLIL::SigSpec when_signal, RTLIL::Cell *last_mux_cell, RTLIL::SwitchRule *sw) | ||||
| { | ||||
| 	log_assert(last_mux_cell != NULL); | ||||
| 	log_assert(when_signal.size() == last_mux_cell->getPort("\\A").size()); | ||||
|  | @ -176,7 +179,7 @@ static void append_pmux(RTLIL::Module *mod, const RTLIL::SigSpec &signal, const | |||
| 	last_mux_cell->parameters["\\S_WIDTH"] = last_mux_cell->getPort("\\S").size(); | ||||
| } | ||||
| 
 | ||||
| static RTLIL::SigSpec signal_to_mux_tree(RTLIL::Module *mod, RTLIL::CaseRule *cs, const RTLIL::SigSpec &sig, const RTLIL::SigSpec &defval) | ||||
| RTLIL::SigSpec signal_to_mux_tree(RTLIL::Module *mod, RTLIL::CaseRule *cs, const RTLIL::SigSpec &sig, const RTLIL::SigSpec &defval) | ||||
| { | ||||
| 	RTLIL::SigSpec result = defval; | ||||
| 
 | ||||
|  | @ -233,7 +236,7 @@ static RTLIL::SigSpec signal_to_mux_tree(RTLIL::Module *mod, RTLIL::CaseRule *cs | |||
| 	return result; | ||||
| } | ||||
| 
 | ||||
| static void proc_mux(RTLIL::Module *mod, RTLIL::Process *proc) | ||||
| void proc_mux(RTLIL::Module *mod, RTLIL::Process *proc) | ||||
| { | ||||
| 	bool first = true; | ||||
| 	while (1) | ||||
|  | @ -283,3 +286,4 @@ struct ProcMuxPass : public Pass { | |||
| 	} | ||||
| } ProcMuxPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -25,7 +25,10 @@ | |||
| #include <stdio.h> | ||||
| #include <set> | ||||
| 
 | ||||
| static void proc_rmdead(RTLIL::SwitchRule *sw, int &counter) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void proc_rmdead(RTLIL::SwitchRule *sw, int &counter) | ||||
| { | ||||
| 	BitPatternPool pool(sw->signal); | ||||
| 
 | ||||
|  | @ -98,3 +101,4 @@ struct ProcRmdeadPass : public Pass { | |||
| 	} | ||||
| } ProcRmdeadPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -31,7 +31,8 @@ | |||
| #include <string.h> | ||||
| #include <algorithm> | ||||
| 
 | ||||
| namespace { | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| /* this should only be used for regression testing of ConstEval -- see vloghammer */ | ||||
| struct BruteForceEquivChecker | ||||
|  | @ -357,8 +358,6 @@ struct VlogHammerReporter | |||
| 	} | ||||
| }; | ||||
| 
 | ||||
| } /* namespace */ | ||||
| 
 | ||||
| struct EvalPass : public Pass { | ||||
| 	EvalPass() : Pass("eval", "evaluate the circuit given an input") { } | ||||
| 	virtual void help() | ||||
|  | @ -601,3 +600,4 @@ struct EvalPass : public Pass { | |||
| 	} | ||||
| } EvalPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -23,6 +23,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct dff_map_info_t { | ||||
| 	RTLIL::SigSpec sig_d, sig_clk, sig_arst; | ||||
| 	bool clk_polarity, arst_polarity; | ||||
|  | @ -37,7 +40,7 @@ struct dff_map_bit_info_t { | |||
| 	RTLIL::Cell *cell; | ||||
| }; | ||||
| 
 | ||||
| static bool consider_wire(RTLIL::Wire *wire, std::map<RTLIL::IdString, dff_map_info_t> &dff_dq_map) | ||||
| bool consider_wire(RTLIL::Wire *wire, std::map<RTLIL::IdString, dff_map_info_t> &dff_dq_map) | ||||
| { | ||||
| 	if (wire->name[0] == '$' || dff_dq_map.count(wire->name)) | ||||
| 		return false; | ||||
|  | @ -46,7 +49,7 @@ static bool consider_wire(RTLIL::Wire *wire, std::map<RTLIL::IdString, dff_map_i | |||
| 	return true; | ||||
| } | ||||
| 
 | ||||
| static bool consider_cell(RTLIL::Design *design, std::set<RTLIL::IdString> &dff_cells, RTLIL::Cell *cell) | ||||
| bool consider_cell(RTLIL::Design *design, std::set<RTLIL::IdString> &dff_cells, RTLIL::Cell *cell) | ||||
| { | ||||
| 	if (cell->name[0] == '$' || dff_cells.count(cell->name)) | ||||
| 		return false; | ||||
|  | @ -55,7 +58,7 @@ static bool consider_cell(RTLIL::Design *design, std::set<RTLIL::IdString> &dff_ | |||
| 	return true; | ||||
| } | ||||
| 
 | ||||
| static bool compare_wires(RTLIL::Wire *wire1, RTLIL::Wire *wire2) | ||||
| bool compare_wires(RTLIL::Wire *wire1, RTLIL::Wire *wire2) | ||||
| { | ||||
| 	log_assert(wire1->name == wire2->name); | ||||
| 	if (wire1->width != wire2->width) | ||||
|  | @ -63,7 +66,7 @@ static bool compare_wires(RTLIL::Wire *wire1, RTLIL::Wire *wire2) | |||
| 	return true; | ||||
| } | ||||
| 
 | ||||
| static bool compare_cells(RTLIL::Cell *cell1, RTLIL::Cell *cell2) | ||||
| bool compare_cells(RTLIL::Cell *cell1, RTLIL::Cell *cell2) | ||||
| { | ||||
| 	log_assert(cell1->name == cell2->name); | ||||
| 	if (cell1->type != cell2->type) | ||||
|  | @ -73,7 +76,7 @@ static bool compare_cells(RTLIL::Cell *cell1, RTLIL::Cell *cell2) | |||
| 	return true; | ||||
| } | ||||
| 
 | ||||
| static void find_dff_wires(std::set<RTLIL::IdString> &dff_wires, RTLIL::Module *module) | ||||
| void find_dff_wires(std::set<RTLIL::IdString> &dff_wires, RTLIL::Module *module) | ||||
| { | ||||
| 	CellTypes ct; | ||||
| 	ct.setup_internals_mem(); | ||||
|  | @ -93,7 +96,7 @@ static void find_dff_wires(std::set<RTLIL::IdString> &dff_wires, RTLIL::Module * | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void create_dff_dq_map(std::map<RTLIL::IdString, dff_map_info_t> &map, RTLIL::Design *design, RTLIL::Module *module) | ||||
| void create_dff_dq_map(std::map<RTLIL::IdString, dff_map_info_t> &map, RTLIL::Design *design, RTLIL::Module *module) | ||||
| { | ||||
| 	std::map<RTLIL::SigBit, dff_map_bit_info_t> bit_info; | ||||
| 	SigMap sigmap(module); | ||||
|  | @ -208,7 +211,7 @@ static void create_dff_dq_map(std::map<RTLIL::IdString, dff_map_info_t> &map, RT | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static RTLIL::Wire *add_new_wire(RTLIL::Module *module, RTLIL::IdString name, int width = 1) | ||||
| RTLIL::Wire *add_new_wire(RTLIL::Module *module, RTLIL::IdString name, int width = 1) | ||||
| { | ||||
| 	if (module->count_id(name)) | ||||
| 		log_error("Attempting to create wire %s, but a wire of this name exists already! Hint: Try another value for -sep.\n", log_id(name)); | ||||
|  | @ -644,3 +647,4 @@ struct ExposePass : public Pass { | |||
| 	} | ||||
| } ExposePass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -28,7 +28,8 @@ | |||
| #include <string.h> | ||||
| #include <algorithm> | ||||
| 
 | ||||
| namespace { | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| bool inv_mode; | ||||
| int verbose_level, reduce_counter, reduce_stop_at; | ||||
|  | @ -745,8 +746,6 @@ struct FreduceWorker | |||
| 	} | ||||
| }; | ||||
| 
 | ||||
| } /* namespace */ | ||||
| 
 | ||||
| struct FreducePass : public Pass { | ||||
| 	FreducePass() : Pass("freduce", "perform functional reduction") { } | ||||
| 	virtual void help() | ||||
|  | @ -827,3 +826,4 @@ struct FreducePass : public Pass { | |||
| 	} | ||||
| } FreducePass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -21,7 +21,10 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| static void create_miter_equiv(struct Pass *that, std::vector<std::string> args, RTLIL::Design *design) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void create_miter_equiv(struct Pass *that, std::vector<std::string> args, RTLIL::Design *design) | ||||
| { | ||||
| 	bool flag_ignore_gold_x = false; | ||||
| 	bool flag_make_outputs = false; | ||||
|  | @ -299,3 +302,4 @@ struct MiterPass : public Pass { | |||
| 	} | ||||
| } MiterPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -33,7 +33,8 @@ | |||
| #include <errno.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| namespace { | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct SatHelper | ||||
| { | ||||
|  | @ -766,9 +767,7 @@ struct SatHelper | |||
| 	} | ||||
| }; | ||||
| 
 | ||||
| } /* namespace */ | ||||
| 
 | ||||
| static void print_proof_failed() | ||||
| void print_proof_failed() | ||||
| { | ||||
| 	log("\n"); | ||||
| 	log("   ______                   ___       ___       _ _            _ _ \n"); | ||||
|  | @ -780,7 +779,7 @@ static void print_proof_failed() | |||
| 	log("\n"); | ||||
| } | ||||
| 
 | ||||
| static void print_timeout() | ||||
| void print_timeout() | ||||
| { | ||||
| 	log("\n"); | ||||
| 	log("        _____  _  _      _____ ____  _     _____\n"); | ||||
|  | @ -791,7 +790,7 @@ static void print_timeout() | |||
| 	log("\n"); | ||||
| } | ||||
| 
 | ||||
| static void print_qed() | ||||
| void print_qed() | ||||
| { | ||||
| 	log("\n"); | ||||
| 	log("                  /$$$$$$      /$$$$$$$$     /$$$$$$$    \n"); | ||||
|  | @ -1484,3 +1483,4 @@ struct SatPass : public Pass { | |||
| 	} | ||||
| } SatPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -21,6 +21,9 @@ | |||
| #include "kernel/sigtools.h" | ||||
| #include "kernel/macc.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct AlumaccWorker | ||||
| { | ||||
| 	RTLIL::Module *module; | ||||
|  | @ -561,3 +564,4 @@ struct AlumaccPass : public Pass { | |||
| 	} | ||||
| } AlumaccPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -23,7 +23,8 @@ | |||
| #include <string.h> | ||||
| #include <errno.h> | ||||
| 
 | ||||
| using namespace PASS_DFFLIBMAP; | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct cell_mapping { | ||||
| 	std::string cell_name; | ||||
|  | @ -538,3 +539,4 @@ struct DfflibmapPass : public Pass { | |||
| 	} | ||||
| } DfflibmapPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -26,10 +26,11 @@ | |||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| using RTLIL::id2cstr; | ||||
| 
 | ||||
| namespace | ||||
| { | ||||
| class SubCircuitSolver : public SubCircuit::Solver | ||||
| { | ||||
| public: | ||||
|  | @ -348,7 +349,6 @@ namespace | |||
| 		return left_idx < right_idx; | ||||
| 	return left->name < right->name; | ||||
| } | ||||
| } | ||||
| 
 | ||||
| struct ExtractPass : public Pass { | ||||
| 	ExtractPass() : Pass("extract", "find subcircuits and replace them with cells") { } | ||||
|  | @ -761,3 +761,4 @@ struct ExtractPass : public Pass { | |||
| 	} | ||||
| } ExtractPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -21,6 +21,9 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static std::string hicell_celltype, hicell_portname; | ||||
| static std::string locell_celltype, locell_portname; | ||||
| static bool singleton_mode; | ||||
|  | @ -119,3 +122,4 @@ struct HilomapPass : public Pass { | |||
| 	} | ||||
| } HilomapPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -21,7 +21,10 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| static void split_portname_pair(std::string &port1, std::string &port2) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void split_portname_pair(std::string &port1, std::string &port2) | ||||
| { | ||||
| 	size_t pos = port1.find_first_of(':'); | ||||
| 	if (pos != std::string::npos) { | ||||
|  | @ -207,3 +210,4 @@ struct IopadmapPass : public Pass { | |||
| 	} | ||||
| } IopadmapPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -29,7 +29,7 @@ | |||
| #include "kernel/log.h" | ||||
| #endif | ||||
| 
 | ||||
| using namespace PASS_DFFLIBMAP; | ||||
| using namespace Yosys; | ||||
| 
 | ||||
| std::set<std::string> LibertyAst::blacklist; | ||||
| std::set<std::string> LibertyAst::whitelist; | ||||
|  |  | |||
|  | @ -25,7 +25,7 @@ | |||
| #include <vector> | ||||
| #include <set> | ||||
| 
 | ||||
| namespace PASS_DFFLIBMAP | ||||
| namespace Yosys | ||||
| { | ||||
| 	struct LibertyAst | ||||
| 	{ | ||||
|  |  | |||
|  | @ -20,7 +20,8 @@ | |||
| #include "kernel/yosys.h" | ||||
| #include "kernel/macc.h" | ||||
| 
 | ||||
| extern void maccmap(RTLIL::Module *module, RTLIL::Cell *cell, bool unmap = false); | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct MaccmapWorker | ||||
| { | ||||
|  | @ -256,6 +257,11 @@ struct MaccmapWorker | |||
| 	} | ||||
| }; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| extern void maccmap(RTLIL::Module *module, RTLIL::Cell *cell, bool unmap = false); | ||||
| 
 | ||||
| void maccmap(RTLIL::Module *module, RTLIL::Cell *cell, bool unmap) | ||||
| { | ||||
| 	int width = SIZE(cell->getPort("\\Y")); | ||||
|  | @ -354,6 +360,9 @@ void maccmap(RTLIL::Module *module, RTLIL::Cell *cell, bool unmap) | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct MaccmapPass : public Pass { | ||||
| 	MaccmapPass() : Pass("maccmap", "mapping macc cells") { } | ||||
| 	virtual void help() | ||||
|  | @ -392,3 +401,4 @@ struct MaccmapPass : public Pass { | |||
| 	} | ||||
| } MaccmapPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -24,7 +24,8 @@ | |||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| extern void simplemap_get_mappers(std::map<RTLIL::IdString, void(*)(RTLIL::Module*, RTLIL::Cell*)> &mappers); | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static void simplemap_not(RTLIL::Module *module, RTLIL::Cell *cell) | ||||
| { | ||||
|  | @ -372,6 +373,11 @@ static void simplemap_dlatch(RTLIL::Module *module, RTLIL::Cell *cell) | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| extern void simplemap_get_mappers(std::map<RTLIL::IdString, void(*)(RTLIL::Module*, RTLIL::Cell*)> &mappers); | ||||
| 
 | ||||
| void simplemap_get_mappers(std::map<RTLIL::IdString, void(*)(RTLIL::Module*, RTLIL::Cell*)> &mappers) | ||||
| { | ||||
| 	mappers["$not"]         = simplemap_not; | ||||
|  | @ -398,6 +404,9 @@ void simplemap_get_mappers(std::map<RTLIL::IdString, void(*)(RTLIL::Module*, RTL | |||
| 	mappers["$dlatch"]      = simplemap_dlatch; | ||||
| } | ||||
| 
 | ||||
| YOSYS_NAMESPACE_END | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct SimplemapPass : public Pass { | ||||
| 	SimplemapPass() : Pass("simplemap", "mapping simple coarse-grain cells") { } | ||||
| 	virtual void help() | ||||
|  | @ -440,3 +449,4 @@ struct SimplemapPass : public Pass { | |||
| 	} | ||||
| } SimplemapPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -28,13 +28,20 @@ | |||
| 
 | ||||
| #include "passes/techmap/techmap.inc" | ||||
| 
 | ||||
| YOSYS_NAMESPACE_BEGIN | ||||
| 
 | ||||
| // see simplemap.cc
 | ||||
| extern void simplemap_get_mappers(std::map<RTLIL::IdString, void(*)(RTLIL::Module*, RTLIL::Cell*)> &mappers); | ||||
| 
 | ||||
| // see maccmap.cc
 | ||||
| extern void maccmap(RTLIL::Module *module, RTLIL::Cell *cell, bool unmap = false); | ||||
| 
 | ||||
| static void apply_prefix(std::string prefix, std::string &id) | ||||
| YOSYS_NAMESPACE_END | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| void apply_prefix(std::string prefix, std::string &id) | ||||
| { | ||||
| 	if (id[0] == '\\') | ||||
| 		id = prefix + "." + id.substr(1); | ||||
|  | @ -42,7 +49,7 @@ static void apply_prefix(std::string prefix, std::string &id) | |||
| 		id = "$techmap" + prefix + "." + id; | ||||
| } | ||||
| 
 | ||||
| static void apply_prefix(std::string prefix, RTLIL::SigSpec &sig, RTLIL::Module *module) | ||||
| void apply_prefix(std::string prefix, RTLIL::SigSpec &sig, RTLIL::Module *module) | ||||
| { | ||||
| 	std::vector<RTLIL::SigChunk> chunks = sig; | ||||
| 	for (auto &chunk : chunks) | ||||
|  | @ -1080,3 +1087,4 @@ struct FlattenPass : public Pass { | |||
| 	} | ||||
| } FlattenPass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -21,6 +21,9 @@ | |||
| #include "kernel/yosys.h" | ||||
| #include "kernel/satgen.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static uint32_t xorshift32_state = 123456789; | ||||
| 
 | ||||
| static uint32_t xorshift32(uint32_t limit) { | ||||
|  | @ -283,3 +286,4 @@ struct TestAbcloopPass : public Pass { | |||
| 	} | ||||
| } TestAbcloopPass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,6 +22,7 @@ | |||
| #include <stdio.h> | ||||
| #include <time.h> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static std::string id(std::string internal_id) | ||||
|  |  | |||
|  | @ -24,6 +24,9 @@ | |||
| #include "kernel/macc.h" | ||||
| #include <algorithm> | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| static uint32_t xorshift32_state = 123456789; | ||||
| 
 | ||||
| static uint32_t xorshift32(uint32_t limit) { | ||||
|  | @ -743,3 +746,4 @@ struct TestCellPass : public Pass { | |||
| 	} | ||||
| } TestCellPass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,7 +22,10 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| static bool check_label(bool &active, std::string run_from, std::string run_to, std::string label) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| bool check_label(bool &active, std::string run_from, std::string run_to, std::string label) | ||||
| { | ||||
| 	if (!run_from.empty() && run_from == run_to) { | ||||
| 		active = (label == run_from); | ||||
|  | @ -154,3 +157,4 @@ struct SynthPass : public Pass { | |||
| 	} | ||||
| } SynthPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
|  | @ -22,7 +22,10 @@ | |||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| static bool check_label(bool &active, std::string run_from, std::string run_to, std::string label) | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| bool check_label(bool &active, std::string run_from, std::string run_to, std::string label) | ||||
| { | ||||
| 	if (label == run_from) | ||||
| 		active = true; | ||||
|  | @ -208,3 +211,4 @@ struct SynthXilinxPass : public Pass { | |||
| 	} | ||||
| } SynthXilinxPass; | ||||
|   | ||||
| PRIVATE_NAMESPACE_END | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue