You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			14 lines
		
	
	
		
			369 B
		
	
	
	
		
			Python
		
	
			
		
		
	
	
			14 lines
		
	
	
		
			369 B
		
	
	
	
		
			Python
		
	
from amaranth import *
 | 
						|
from amaranth.utils import bits_for
 | 
						|
 | 
						|
 | 
						|
__all__ = ["iea_mask"]
 | 
						|
 | 
						|
 | 
						|
def iea_mask(addr, msr_sf):
 | 
						|
    "Instruction effective address mask. In 32-bit mode (MSR.SF = 0), the upper 32 bits are cleared."
 | 
						|
    addr, msr_sf = Value.cast(addr), Value.cast(msr_sf)
 | 
						|
    assert len(msr_sf) == 1
 | 
						|
    mask = Cat(Repl(1, 32), Repl(msr_sf, 32))
 | 
						|
    return addr & mask
 |