mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Fixed handling of boolean attributes (kernel)
This commit is contained in:
		
							parent
							
								
									77726fb5fe
								
							
						
					
					
						commit
						eae43e2db4
					
				
					 3 changed files with 22 additions and 10 deletions
				
			
		|  | @ -167,6 +167,8 @@ void dump_const(FILE *f, RTLIL::Const &data, int width = -1, int offset = 0, boo | ||||||
| 		} else { | 		} else { | ||||||
| 	dump_bits: | 	dump_bits: | ||||||
| 			fprintf(f, "%d'b", width); | 			fprintf(f, "%d'b", width); | ||||||
|  | 			if (width == 0) | ||||||
|  | 				fprintf(f, "0"); | ||||||
| 			for (int i = offset+width-1; i >= offset; i--) { | 			for (int i = offset+width-1; i >= offset; i--) { | ||||||
| 				assert(i < (int)data.bits.size()); | 				assert(i < (int)data.bits.size()); | ||||||
| 				switch (data.bits[i]) { | 				switch (data.bits[i]) { | ||||||
|  | @ -234,10 +236,8 @@ void dump_attributes(FILE *f, std::string indent, std::map<RTLIL::IdString, RTLI | ||||||
| 		return; | 		return; | ||||||
| 	for (auto it = attributes.begin(); it != attributes.end(); it++) { | 	for (auto it = attributes.begin(); it != attributes.end(); it++) { | ||||||
| 		fprintf(f, "%s" "%s %s", indent.c_str(), attr2comment ? "/*" : "(*", id(it->first).c_str()); | 		fprintf(f, "%s" "%s %s", indent.c_str(), attr2comment ? "/*" : "(*", id(it->first).c_str()); | ||||||
| 		if (it->second.bits.size() > 0) { | 		fprintf(f, " = "); | ||||||
| 			fprintf(f, " = "); | 		dump_const(f, it->second); | ||||||
| 			dump_const(f, it->second); |  | ||||||
| 		} |  | ||||||
| 		fprintf(f, " %s%c", attr2comment ? "*/" : "*)", term); | 		fprintf(f, " %s%c", attr2comment ? "*/" : "*)", term); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -179,7 +179,7 @@ attr_assign: | ||||||
| 	hierarchical_id { | 	hierarchical_id { | ||||||
| 		if (attr_list.count(*$1) != 0) | 		if (attr_list.count(*$1) != 0) | ||||||
| 			delete attr_list[*$1]; | 			delete attr_list[*$1]; | ||||||
| 		attr_list[*$1] = AstNode::mkconst_int(0, false, 0); | 		attr_list[*$1] = AstNode::mkconst_int(1, false); | ||||||
| 		delete $1; | 		delete $1; | ||||||
| 	} | | 	} | | ||||||
| 	hierarchical_id '=' expr { | 	hierarchical_id '=' expr { | ||||||
|  |  | ||||||
|  | @ -233,6 +233,17 @@ struct RTLIL::Design { | ||||||
| 	} | 	} | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | #define RTLIL_ATTRIBUTE_MEMBERS                                \ | ||||||
|  | 	std::map<RTLIL::IdString, RTLIL::Const> attributes;    \ | ||||||
|  | 	void set_bool_attribute(RTLIL::IdString id) {          \ | ||||||
|  | 		attributes[id] = RTLIL::Const(1);              \ | ||||||
|  | 	}                                                      \ | ||||||
|  | 	bool get_bool_attribute(RTLIL::IdString id) const {    \ | ||||||
|  | 		if (attributes.count(id) == 0)                 \ | ||||||
|  | 			return false;                          \ | ||||||
|  | 		return attributes.at(id).as_bool();            \ | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| struct RTLIL::Module { | struct RTLIL::Module { | ||||||
| 	RTLIL::IdString name; | 	RTLIL::IdString name; | ||||||
| 	std::map<RTLIL::IdString, RTLIL::Wire*> wires; | 	std::map<RTLIL::IdString, RTLIL::Wire*> wires; | ||||||
|  | @ -240,7 +251,7 @@ struct RTLIL::Module { | ||||||
| 	std::map<RTLIL::IdString, RTLIL::Cell*> cells; | 	std::map<RTLIL::IdString, RTLIL::Cell*> cells; | ||||||
| 	std::map<RTLIL::IdString, RTLIL::Process*> processes; | 	std::map<RTLIL::IdString, RTLIL::Process*> processes; | ||||||
| 	std::vector<RTLIL::SigSig> connections; | 	std::vector<RTLIL::SigSig> connections; | ||||||
| 	std::map<RTLIL::IdString, RTLIL::Const> attributes; | 	RTLIL_ATTRIBUTE_MEMBERS | ||||||
| 	virtual ~Module(); | 	virtual ~Module(); | ||||||
| 	virtual RTLIL::IdString derive(RTLIL::Design *design, std::map<RTLIL::IdString, RTLIL::Const> parameters); | 	virtual RTLIL::IdString derive(RTLIL::Design *design, std::map<RTLIL::IdString, RTLIL::Const> parameters); | ||||||
| 	virtual void update_auto_wires(std::map<RTLIL::IdString, int> auto_sizes); | 	virtual void update_auto_wires(std::map<RTLIL::IdString, int> auto_sizes); | ||||||
|  | @ -255,20 +266,21 @@ struct RTLIL::Module { | ||||||
| 	template<typename T> void rewrite_sigspecs(T functor); | 	template<typename T> void rewrite_sigspecs(T functor); | ||||||
| 	void cloneInto(RTLIL::Module *new_mod) const; | 	void cloneInto(RTLIL::Module *new_mod) const; | ||||||
| 	virtual RTLIL::Module *clone() const; | 	virtual RTLIL::Module *clone() const; | ||||||
|  | 
 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct RTLIL::Wire { | struct RTLIL::Wire { | ||||||
| 	RTLIL::IdString name; | 	RTLIL::IdString name; | ||||||
| 	int width, start_offset, port_id; | 	int width, start_offset, port_id; | ||||||
| 	bool port_input, port_output, auto_width; | 	bool port_input, port_output, auto_width; | ||||||
| 	std::map<RTLIL::IdString, RTLIL::Const> attributes; | 	RTLIL_ATTRIBUTE_MEMBERS | ||||||
| 	Wire(); | 	Wire(); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct RTLIL::Memory { | struct RTLIL::Memory { | ||||||
| 	RTLIL::IdString name; | 	RTLIL::IdString name; | ||||||
| 	int width, start_offset, size; | 	int width, start_offset, size; | ||||||
| 	std::map<RTLIL::IdString, RTLIL::Const> attributes; | 	RTLIL_ATTRIBUTE_MEMBERS | ||||||
| 	Memory(); | 	Memory(); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | @ -276,8 +288,8 @@ struct RTLIL::Cell { | ||||||
| 	RTLIL::IdString name; | 	RTLIL::IdString name; | ||||||
| 	RTLIL::IdString type; | 	RTLIL::IdString type; | ||||||
| 	std::map<RTLIL::IdString, RTLIL::SigSpec> connections; | 	std::map<RTLIL::IdString, RTLIL::SigSpec> connections; | ||||||
| 	std::map<RTLIL::IdString, RTLIL::Const> attributes; |  | ||||||
| 	std::map<RTLIL::IdString, RTLIL::Const> parameters; | 	std::map<RTLIL::IdString, RTLIL::Const> parameters; | ||||||
|  | 	RTLIL_ATTRIBUTE_MEMBERS | ||||||
| 	void optimize(); | 	void optimize(); | ||||||
| 
 | 
 | ||||||
| 	template<typename T> void rewrite_sigspecs(T functor); | 	template<typename T> void rewrite_sigspecs(T functor); | ||||||
|  | @ -377,7 +389,7 @@ struct RTLIL::SyncRule { | ||||||
| 
 | 
 | ||||||
| struct RTLIL::Process { | struct RTLIL::Process { | ||||||
| 	RTLIL::IdString name; | 	RTLIL::IdString name; | ||||||
| 	std::map<RTLIL::IdString, RTLIL::Const> attributes; | 	RTLIL_ATTRIBUTE_MEMBERS | ||||||
| 	RTLIL::CaseRule root_case; | 	RTLIL::CaseRule root_case; | ||||||
| 	std::vector<RTLIL::SyncRule*> syncs; | 	std::vector<RTLIL::SyncRule*> syncs; | ||||||
| 	~Process(); | 	~Process(); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue