mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-30 19:22:31 +00:00 
			
		
		
		
	cxxrtl: fix crashes caused by a floating or constant clock input.
E.g. in:
    module test;
        wire clk = 0;
        reg data;
        always @(posedge clk)
            data <= 0;
    endmodule
			
			
This commit is contained in:
		
							parent
							
								
									7b0cfd5c36
								
							
						
					
					
						commit
						7067f0d788
					
				
					 1 changed files with 14 additions and 6 deletions
				
			
		|  | @ -1036,8 +1036,12 @@ struct CxxrtlWorker { | |||
| 				// Edge-sensitive logic
 | ||||
| 				RTLIL::SigBit clk_bit = cell->getPort(ID::CLK)[0]; | ||||
| 				clk_bit = sigmaps[clk_bit.wire->module](clk_bit); | ||||
| 				if (clk_bit.wire) { | ||||
| 					f << indent << "if (" << (cell->getParam(ID::CLK_POLARITY).as_bool() ? "posedge_" : "negedge_") | ||||
| 					            << mangle(clk_bit) << ") {\n"; | ||||
| 				} else { | ||||
| 					f << indent << "if (false) {\n"; | ||||
| 				} | ||||
| 				inc_indent(); | ||||
| 					if (cell->hasPort(ID::EN)) { | ||||
| 						f << indent << "if ("; | ||||
|  | @ -1130,8 +1134,12 @@ struct CxxrtlWorker { | |||
| 			if (cell->getParam(ID::CLK_ENABLE).as_bool()) { | ||||
| 				RTLIL::SigBit clk_bit = cell->getPort(ID::CLK)[0]; | ||||
| 				clk_bit = sigmaps[clk_bit.wire->module](clk_bit); | ||||
| 				if (clk_bit.wire) { | ||||
| 					f << indent << "if (" << (cell->getParam(ID::CLK_POLARITY).as_bool() ? "posedge_" : "negedge_") | ||||
| 					            << mangle(clk_bit) << ") {\n"; | ||||
| 				} else { | ||||
| 					f << indent << "if (false) {\n"; | ||||
| 				} | ||||
| 				inc_indent(); | ||||
| 			} | ||||
| 			RTLIL::Memory *memory = cell->module->memories[cell->getParam(ID::MEMID).decode_string()]; | ||||
|  | @ -2105,14 +2113,14 @@ struct CxxrtlWorker { | |||
| 
 | ||||
| 				// Various DFF cells are treated like posedge/negedge processes, see above for details.
 | ||||
| 				if (cell->type.in(ID($dff), ID($dffe), ID($adff), ID($adffe), ID($dffsr), ID($dffsre), ID($sdff), ID($sdffe), ID($sdffce))) { | ||||
| 					if (cell->getPort(ID::CLK).is_wire()) | ||||
| 					if (sigmap(cell->getPort(ID::CLK)).is_wire()) | ||||
| 						register_edge_signal(sigmap, cell->getPort(ID::CLK), | ||||
| 							cell->parameters[ID::CLK_POLARITY].as_bool() ? RTLIL::STp : RTLIL::STn); | ||||
| 				} | ||||
| 				// Similar for memory port cells.
 | ||||
| 				if (cell->type.in(ID($memrd), ID($memwr))) { | ||||
| 					if (cell->getParam(ID::CLK_ENABLE).as_bool()) { | ||||
| 						if (cell->getPort(ID::CLK).is_wire()) | ||||
| 						if (sigmap(cell->getPort(ID::CLK)).is_wire()) | ||||
| 							register_edge_signal(sigmap, cell->getPort(ID::CLK), | ||||
| 								cell->parameters[ID::CLK_POLARITY].as_bool() ? RTLIL::STp : RTLIL::STn); | ||||
| 					} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue