mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	sv: carry over global typedefs from previous files
This breaks the ability to use a global typename as a standard identifier in a subsequent input file. This is otherwise backwards compatible, including for sources which previously included conflicting typedefs in each input file.
This commit is contained in:
		
							parent
							
								
									092e923330
								
							
						
					
					
						commit
						f71c2dcca6
					
				
					 3 changed files with 65 additions and 2 deletions
				
			
		|  | @ -61,7 +61,10 @@ static void add_package_types(dict<std::string, AST::AstNode *> &user_types, std | |||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	user_type_stack.clear(); | ||||
| 
 | ||||
| 	// carry over typedefs from previous files, but allow them to be overridden
 | ||||
| 	// note that these type maps are currently never reclaimed
 | ||||
| 	if (user_type_stack.empty() || !user_type_stack.back()->empty()) | ||||
| 		user_type_stack.push_back(new UserTypeMap()); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										23
									
								
								tests/verilog/typedef_across_files.ys
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								tests/verilog/typedef_across_files.ys
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,23 @@ | |||
| read_verilog -sv <<EOF | ||||
| typedef logic T; | ||||
| EOF | ||||
| 
 | ||||
| read_verilog -sv <<EOF | ||||
| typedef T [3:0] S; | ||||
| EOF | ||||
| 
 | ||||
| read_verilog -sv <<EOF | ||||
| module top; | ||||
|     T t; | ||||
|     S s; | ||||
|     always @* begin | ||||
|         assert ($bits(t) == 1); | ||||
|         assert ($bits(s) == 4); | ||||
|     end | ||||
| endmodule | ||||
| EOF | ||||
| 
 | ||||
| proc | ||||
| opt -full | ||||
| select -module top | ||||
| sat -verify -seq 1 -tempinduct -prove-asserts -show-all | ||||
							
								
								
									
										37
									
								
								tests/verilog/typedef_legacy_conflict.ys
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								tests/verilog/typedef_legacy_conflict.ys
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,37 @@ | |||
| read_verilog -sv <<EOF | ||||
| typedef logic T; | ||||
| typedef T [3:0] S; | ||||
| EOF | ||||
| 
 | ||||
| read_verilog -sv <<EOF | ||||
| module example; | ||||
|     // S and T refer to the definitions from the first file | ||||
|     T t; | ||||
|     S s; | ||||
|     always @* begin | ||||
|         assert ($bits(t) == 1); | ||||
|         assert ($bits(s) == 4); | ||||
|     end | ||||
| endmodule | ||||
| 
 | ||||
| typedef byte T; | ||||
| typedef T S; | ||||
| 
 | ||||
| module top; | ||||
|     // S and T refer to the most recent overrides | ||||
|     T t; | ||||
|     S s; | ||||
|     always @* begin | ||||
|         assert ($bits(t) == 8); | ||||
|         assert ($bits(s) == 8); | ||||
|     end | ||||
|     example e(); | ||||
| endmodule | ||||
| EOF | ||||
| 
 | ||||
| hierarchy | ||||
| proc | ||||
| flatten | ||||
| opt -full | ||||
| select -module top | ||||
| sat -verify -seq 1 -tempinduct -prove-asserts -show-all | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue