Give AsyncCrossing slave interfaces registers visibility into when they were written (#288)
This commit is contained in:
		
				
					committed by
					
						 Wesley W. Terpstra
						Wesley W. Terpstra
					
				
			
			
				
	
			
			
			
						parent
						
							bdb7b1de36
						
					
				
				
					commit
					47acbf928b
				
			| @@ -48,6 +48,7 @@ class RegisterWriteCrossingIO[T <: Data](gen: T) extends Bundle { | |||||||
|   val slave_reset    = Bool(INPUT) |   val slave_reset    = Bool(INPUT) | ||||||
|   val slave_allow    = Bool(INPUT) // honour requests from the master |   val slave_allow    = Bool(INPUT) // honour requests from the master | ||||||
|   val slave_register = gen.asOutput |   val slave_register = gen.asOutput | ||||||
|  |   val slave_valid    = Bool(OUTPUT) // is high on 1st cycle slave_register has a new value | ||||||
| } | } | ||||||
|  |  | ||||||
| class RegisterWriteCrossing[T <: Data](gen: T, sync: Int = 3) extends Module { | class RegisterWriteCrossing[T <: Data](gen: T, sync: Int = 3) extends Module { | ||||||
| @@ -65,6 +66,7 @@ class RegisterWriteCrossing[T <: Data](gen: T, sync: Int = 3) extends Module { | |||||||
|  |  | ||||||
|   crossing.io.enq.bits := io.master_port.request.bits |   crossing.io.enq.bits := io.master_port.request.bits | ||||||
|   io.slave_register := crossing.io.deq.bits |   io.slave_register := crossing.io.deq.bits | ||||||
|  |   io.slave_valid    := crossing.io.deq.valid | ||||||
|  |  | ||||||
|   // If the slave is not operational, just drop the write. |   // If the slave is not operational, just drop the write. | ||||||
|   val progress = crossing.io.enq.ready || !io.master_allow |   val progress = crossing.io.enq.ready || !io.master_allow | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user