2015-06-30 13:32:05 +02:00
|
|
|
`ifndef ELINK_REGMAP_V_
|
|
|
|
`define ELINK_REGMAP_V_
|
|
|
|
|
2015-04-11 00:10:16 -04:00
|
|
|
//MEMORY MAP
|
|
|
|
|
2015-04-24 17:38:01 -04:00
|
|
|
//[31:20] = LINKID
|
2015-10-07 11:49:46 -04:00
|
|
|
//[19:16] = GROUP SELECT
|
2015-04-24 17:38:01 -04:00
|
|
|
//[15] = MMU SELECT (for RX/TX)
|
2015-10-07 11:49:46 -04:00
|
|
|
//[14:11] = USED BY MMU ONLY
|
2015-05-01 17:52:55 -04:00
|
|
|
//[10:8] = register group
|
|
|
|
//[7:2] = REGISTER ADDRESS (0..63)
|
2015-04-24 17:38:01 -04:00
|
|
|
//[1:0] = IGNORED (no byte access)
|
|
|
|
|
|
|
|
//Link register groups addr[19:16]
|
2015-05-04 10:41:42 -04:00
|
|
|
`define EGROUP_MMR 4'hF // reserved for registers
|
2015-05-01 17:52:55 -04:00
|
|
|
`define EGROUP_MMU 4'hE // RX & TX MMU
|
2015-05-04 10:41:42 -04:00
|
|
|
`define EGROUP_RR 4'hD // read response block
|
2015-05-01 17:52:55 -04:00
|
|
|
|
|
|
|
//ETX-REGS
|
|
|
|
`define E_RESET 6'd0 //F0200-reset
|
|
|
|
`define E_CLK 6'd1 //F0204-clock configuration
|
2015-05-02 23:04:13 -04:00
|
|
|
`define E_CHIPID 6'd2 //F0208-Epiphany chip id for colid/rowid pins
|
2015-05-01 17:52:55 -04:00
|
|
|
`define E_VERSION 6'd3 //F020C-version #
|
|
|
|
`define ETX_CFG 6'd4 //F0210-config
|
|
|
|
`define ETX_STATUS 6'd5 //F0214-tx status
|
|
|
|
`define ETX_GPIO 6'd6 //F0218-direct data for tx pins
|
2015-11-25 12:50:02 -05:00
|
|
|
`define ETX_MONITOR 6'd7 //F021C-transaction monitor
|
2015-05-01 17:52:55 -04:00
|
|
|
|
|
|
|
//ERX-REGS
|
|
|
|
`define ERX_CFG 6'd0 //F0300-config
|
|
|
|
`define ERX_STATUS 6'd1 //F0304-status register
|
|
|
|
`define ERX_GPIO 6'd2 //F0308-sampled data
|
2015-05-04 10:49:17 -04:00
|
|
|
`define ERX_OFFSET 6'd3 //F030C-memory base for remap
|
2015-11-06 22:34:08 -05:00
|
|
|
|
2015-11-03 10:31:06 -05:00
|
|
|
`define ERX_IDELAY0 6'd6 //F0318-tap delay for d[5:0]
|
|
|
|
`define ERX_IDELAY1 6'd7 //F031c-tap delays for {frame,d[7:6]}
|
|
|
|
`define ERX_TESTDATA 6'd8 //F0320-
|
2015-05-01 17:52:55 -04:00
|
|
|
|
2015-11-06 22:34:08 -05:00
|
|
|
//MAILBOX
|
|
|
|
`ifndef E_MAILBOXLO
|
|
|
|
`define E_MAILBOXLO 6'd4 //F0310-reserved
|
|
|
|
`endif
|
|
|
|
`ifndef E_MAILBOXHI
|
|
|
|
`define E_MAILBOXHI 6'd5 //F0314-reserved
|
|
|
|
`endif
|
|
|
|
|
2015-05-01 17:52:55 -04:00
|
|
|
//DMA (same numbering as in Epiphany, limit to 4 channels)
|
2015-05-02 23:04:13 -04:00
|
|
|
`define DMACFG 5'd0 //F0500/F0520
|
|
|
|
`define DMACOUNT 5'd1 //F0504/F0524
|
|
|
|
`define DMASTRIDE 5'd2 //F0508/F0528
|
|
|
|
`define DMASRCADDR 5'd3 //F050C/F052c
|
2015-05-01 17:52:55 -04:00
|
|
|
`define DMADSTADDR 5'd4 //F0510/F0530
|
|
|
|
`define DMAAUTO0 5'd5 //F0514/F0534
|
|
|
|
`define DMAAUTO1 5'd6 //F0518/F0538
|
|
|
|
`define DMASTATUS 5'd7 //F051C/F053c
|
2015-06-30 13:32:05 +02:00
|
|
|
|
|
|
|
`endif
|