-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathprogmem.py
95 lines (68 loc) · 2.15 KB
/
progmem.py
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
import os
import sys
import struct
relative_path = '2.sw/main.bin'
absolute_path = os.path.join(os.path.dirname(__file__), relative_path)
progmem_text = ''
try:
with open(absolute_path, 'rb') as bin_file:
bin_contents = bin_file.read()
except Exception as e:
print(f"Open bin file Exception: {e}")
sys.exit(-1)
print(f"Bin file size: {len(bin_contents)} bytes")
hex_values = []
while len(bin_contents) != 0:
hex_values.append(struct.unpack("<I", bin_contents[0:4])[0])
bin_contents = bin_contents[4:]
addr = 0
try:
with open('progmem.v', 'w') as prog_mem_file:
for value in hex_values:
progmem_text += f" mem[\'h{addr:04X}] <= 32\'h{value:08X};\n"
addr += 1
progmem_body = f"""
module progmem (
// Clock & reset
input wire clk,
input wire rstn,
// PicoRV32 bus interface
input wire valid,
output wire ready,
input wire [31:0] addr,
output wire [31:0] rdata,
// Rewrite firmware
input wire wen,
input wire [31:0] waddr,
input wire [31:0] wdata
);
// ============================================================================
localparam MEM_SIZE_BITS = 13; // In 32-bit words
localparam MEM_SIZE = 1 << MEM_SIZE_BITS;
localparam MEM_ADDR_MASK = 32'h0010_0000;
// ============================================================================
wire [MEM_SIZE_BITS-1:0] mem_addr;
reg [ 31:0] mem_data;
reg [ 31:0] mem [0:MEM_SIZE];
initial begin
{progmem_text}
end
always @(posedge clk) mem_data <= mem[mem_addr];
// ============================================================================
reg o_ready;
always @(posedge clk or negedge rstn)
if (!rstn) o_ready <= 1'd0;
else o_ready <= valid && ((addr & MEM_ADDR_MASK) != 0);
// Output connectins
assign ready = o_ready;
assign rdata = mem_data;
assign mem_addr = addr[MEM_SIZE_BITS+1:2];
always @(posedge clk) begin
if (wen) mem[waddr] <= wdata;
end
endmodule
"""
prog_mem_file.write(progmem_body)
except Exception as e:
print(f"Write file Exception: {e}")
sys.exit(-1)