mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-11-04 05:19:11 +00:00 
			
		
		
		
	Fixed procedural assignments to non-unique lvalues, e.g. {y,y} = {a,b}
This commit is contained in:
		
							parent
							
								
									ee071586c5
								
							
						
					
					
						commit
						766032c5f8
					
				
					 1 changed files with 11 additions and 0 deletions
				
			
		| 
						 | 
					@ -429,6 +429,17 @@ struct AST_INTERNAL::ProcessGenerator
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
				RTLIL::SigSpec unmapped_lvalue = ast->children[0]->genRTLIL(), lvalue = unmapped_lvalue;
 | 
									RTLIL::SigSpec unmapped_lvalue = ast->children[0]->genRTLIL(), lvalue = unmapped_lvalue;
 | 
				
			||||||
				RTLIL::SigSpec rvalue = ast->children[1]->genWidthRTLIL(lvalue.size(), &subst_rvalue_map.stdmap());
 | 
									RTLIL::SigSpec rvalue = ast->children[1]->genWidthRTLIL(lvalue.size(), &subst_rvalue_map.stdmap());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									pool<SigBit> lvalue_sigbits;
 | 
				
			||||||
 | 
									for (int i = 0; i < GetSize(lvalue); i++) {
 | 
				
			||||||
 | 
										if (lvalue_sigbits.count(lvalue[i]) > 0) {
 | 
				
			||||||
 | 
											unmapped_lvalue.remove(i);
 | 
				
			||||||
 | 
											lvalue.remove(i);
 | 
				
			||||||
 | 
											rvalue.remove(i--);
 | 
				
			||||||
 | 
										} else
 | 
				
			||||||
 | 
											lvalue_sigbits.insert(lvalue[i]);
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				lvalue.replace(subst_lvalue_map.stdmap());
 | 
									lvalue.replace(subst_lvalue_map.stdmap());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (ast->type == AST_ASSIGN_EQ) {
 | 
									if (ast->type == AST_ASSIGN_EQ) {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue