-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathsram.vhdl
executable file
·168 lines (137 loc) · 4.9 KB
/
sram.vhdl
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
-- sram64kx8.vhdl
-- standard SRAM vhdl code, 64K*8 Bit,
-- simplistic model without timing
-- with startup initialization from file
--
-- (C) 2007 Jonathan Geisler
-- modified to work word (32-bits) at a time instead of byte at a time
--
-- (C) 1993,1994 Norman Hendrich, Dept. Computer Science
-- University of Hamburg
-- 22041 Hamburg, Germany
-- hendrich@informatik.uni-hamburg.de
--
-- initialization code taken and modified from DLX memory-behaviour.vhdl:
-- Copyright (C) 1993, Peter J. Ashenden
-- Mail: Dept. Computer Science
-- University of Adelaide, SA 5005, Australia
-- e-mail: petera@cs.adelaide.edu.au
--
use std.textio.all;
Library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;
use IEEE.std_logic_arith.all;
entity sram64kx8 is
generic (rom_data_file_name: string := "memory.dat");
port (ncs : in std_logic; -- not chip select
addr: in std_logic_vector( 31 downto 0 );
data: inout std_logic_vector( 31 downto 0 );
nwe : in std_logic; -- not write enable
noe : in std_logic -- not output enable
);
end sram64kx8;
architecture sram_behaviour of sram64kx8 is
begin
mem: process
constant low_address: natural := 0;
constant high_address: natural := 65535; -- 64K SRAM
subtype byte is std_logic_vector( 7 downto 0 );
type memory_array is
array (natural range low_address to high_address) of byte;
variable mem: memory_array;
variable address : integer;
variable L : line;
procedure read_hex_integer(L: inout line; value: out integer) is
variable ch: character;
variable result: integer;
begin
result := 0;
for i in 1 to 8 loop
read(L, ch);
if ('0' <= ch and ch <= '9') then
result := result * 16 + character'pos(ch) - character'pos('0');
else
result := result * 16 + character'pos(ch) - character'pos('a') + 10;
end if;
end loop;
value := result;
end read_hex_integer;
--
-- load initial memory contents from text-file
-- and print a copy to stdout...
--
procedure load( mem: out memory_array) is
file binary_file : text is in rom_data_file_name;
variable L : line;
variable add, val, i : integer;
variable c : character;
variable val_bits : std_logic_vector(31 downto 0);
begin
write( output, "sram initialization:" );
-- first initialize the RAM array with zeroes
for add in low_address to high_address loop
mem(add) := "00000000";
end loop;
-- and now read the data file
while not endfile(binary_file) loop
readline(binary_file, L );
read_hex_integer(L, add);
read(L, c); -- delimiting space
read_hex_integer(L, val);
--
write( L, add);
write( L, ' ' );
write( L, val);
writeline( output, L );
--
val_bits := conv_std_logic_vector(val, 32);
mem( add ) := val_bits(7 downto 0);
mem( add + 1 ) := val_bits(15 downto 8);
mem( add + 2 ) := val_bits(23 downto 16);
mem( add + 3 ) := val_bits(31 downto 24);
end loop;
end load;
begin
load( mem );
data <= "ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ" ;
--
--
-- process memory cycles
--
loop
if (ncs = '0') then
-- decode address
address := conv_integer( addr(15 downto 0) );
--
if nwe = '0' then
--- write cycle
mem( address ) := data(7 downto 0);
mem( address + 1 ) := data(15 downto 8);
mem( address + 2 ) := data(23 downto 16);
mem( address + 3 ) := data(31 downto 24);
data <= "ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ";
elsif nwe = '1' then
-- read cycle
if noe = '0' then
data(7 downto 0) <= mem( address );
data(15 downto 8) <= mem( address + 1);
data(23 downto 16) <= mem( address + 2);
data(31 downto 24) <= mem( address + 3);
else
data <= "ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ";
end if;
else
data <= "ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ";
end if;
else
data <= "ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ";
end if;
wait on ncs, nwe, noe, addr, data; -- FNH, 29.1.99: added data
end loop;
end process;
end sram_behaviour;
configuration cfg_sram of sram64kx8 is
for sram_behaviour
end for;
end cfg_sram;