47 parameter DEBUG_LOAD =
'h1,
// parallel load of the distributed shift registe (both ways) 49 parameter DEBUG_CMD_LATENCY =
2 // >0 extra registers in the debug_sl (distriburted in parallel) 52 input mrst,
// @ posedge mclk - sync reset 53 // programming interface 54 input [
7:
0]
cmd_ad,
// byte-serial command address/data (up to 6 bytes: AL-AH-D0-D1-D2-D3 55 input cmd_stb,
// strobe (with first byte) for the command a/d 57 output [
7:
0]
status_ad,
// status address/data - up to 5 bytes: A - {seq,status[1:0]} - status[2:9] - status[10:17] - status[18:25] 58 output status_rq,
// input request to send status downstream 59 input status_start,
// Acknowledge of the first status packet byte (address) 62 output debug_do,
// data out to the debug ring @posedge mclk, LSB first 63 output debug_sl,
// 0 - idle, (1,0) - shift, (1,1) - load 64 input debug_di // input data from the debug ring, LSB first 73 reg cmd;
//command stae (0 - idle) 86 always @ (
posedge mclk)
begin 104 else tgl <=
tgl ^
shift_done;
// When counter == 127 - toggle tgl to initiate status send 112 .
rst (
1'b0),
// input 125 )
cmd_deser_32bit_i (
126 .
rst (
1'b0),
//rst), // input 139 .
REGISTER_STATUS (
0),
142 )
status_generate_i (
143 .
rst (
1'b0),
// rst), // input
10278DEBUG_READ_REG_ADDR'hfd
status_generate_i status_generate
[ADDR_MASK2!=0?2:ADDR_MASK1!=0?1:0:0] 9935we
10301cmd_regreg[DEBUG_CMD_LATENCY:0]
10302debug_latency_plus1wire[3:0]
10277DEBUG_STATUS_REG_ADDR'hfc
[DATA_WIDTH-1:0] 9934data
[ADDR_WIDTH-1:0] 9933addr
[ALL_BITS-1:0] 10777status
cmd_deser_32bit_i cmd_deser