summaryrefslogtreecommitdiff
path: root/hdl/defs.svh
blob: ea8dbc13663add3ef717321dec438fcc10bb4786 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
`define RAM_ADDRESS_BITS    23
`define RAM_BYTE_BITS       8
`define RAM_WORD_BYTES      2
`define RAM_LINE_WORDS      1

`define PDP_ADDRESS_BITS    15

`define UART_BYTE_BITS      8

`define TAG_BITS            1

typedef bit             [`RAM_ADDRESS_BITS-1:0]                         ram_word_address_t;
typedef bit             [`RAM_ADDRESS_BITS-1:$clog2(`RAM_LINE_WORDS)]   ram_line_address_t;
typedef bit             [`RAM_BYTE_BITS-1:0]                            ram_byte_t;
typedef ram_byte_t      [`RAM_WORD_BYTES-1:0]                           ram_word_t;
typedef ram_word_t      [`RAM_LINE_WORDS-1:0]                           ram_line_t;
typedef bit             [$clog2(`RAM_WORD_BYTES):0]                     ram_word_mask_t;
typedef ram_word_mask_t [`RAM_LINE_WORDS-1:0]                           ram_line_mask_t;

typedef bit             [$clog2(`RAM_WORD_BYTES+1):0]                   ram_byte_count_t;
typedef bit             [$clog2(`RAM_LINE_WORDS+1):0]                   ram_word_count_t;

typedef bit             [`RAM_ADDRESS_BITS-1:`PDP_ADDRESS_BITS]         ram_pdp_address_space_t;

typedef bit             [`PDP_ADDRESS_BITS-1:0]                         pdp_word_address_t;
typedef bit             [`PDP_ADDRESS_BITS-1:$clog2(`RAM_LINE_WORDS)]   pdp_line_address_t;

typedef bit             [`TAG_BITS-1:0]                                 tag_t;

typedef bit             [`UART_BYTE_BITS-1:0]                           uart_byte_t;

typedef struct {
    ram_line_address_t  address;
    bit                 write;
    ram_line_t          data;
    ram_line_mask_t     mask;
    tag_t               tag;
} ram_command_t;

typedef struct {
    ram_line_address_t  address;
    ram_line_t          data;
    tag_t               tag;
} ram_read_response_t;

typedef struct {
    pdp_line_address_t  address;
    bit                 write;
    ram_line_t          data;
    ram_line_mask_t     mask;
    tag_t               tag;
} pdp_command_t;

typedef struct {
    pdp_line_address_t  address;
    ram_line_t          data;
    tag_t               tag;
} pdp_read_response_t;