OpenCores
URL https://opencores.org/ocsvn/sdram_controller/sdram_controller/trunk

Subversion Repositories sdram_controller

[/] [sdram_controller/] [trunk/] [sdram.vhd] - Blame information for rev 7

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 lynn0p
----------------------------------------------------------------------------------
2
-- Company: OPL Aerospatiale AG
3
-- Engineer: Owen Lynn <lynn0p@hotmail.com>
4
-- 
5
-- Create Date:    14:25:41 08/20/2009 
6
-- Design Name:    DDR SDRAM Controller
7
-- Module Name:    sdram_controller - impl 
8
-- Project Name: 
9
-- Target Devices: Spartan3e Starter Board
10
-- Tool versions:  ISE 11.2
11 7 lynn0p
-- Description: This is the main controller module. This is where the signals 
12
--  to/from the DDR SDRAM chip happen.
13 2 lynn0p
--  
14
-- Dependencies: 
15
--
16
-- Revision: 
17
-- Revision 0.01 - File Created
18
-- Additional Comments: 
19
--  Copyright (c) 2009 Owen Lynn <lynn0p@hotmail.com>
20
--  Released under the GNU Lesser General Public License, Version 3
21
--
22
----------------------------------------------------------------------------------
23
library IEEE;
24
use IEEE.STD_LOGIC_1164.ALL;
25
use IEEE.STD_LOGIC_ARITH.ALL;
26
use IEEE.STD_LOGIC_UNSIGNED.ALL;
27
 
28
---- Uncomment the following library declaration if instantiating
29
---- any Xilinx primitives in this code.
30 7 lynn0p
--library UNISIM;
31
--use UNISIM.VComponents.all;
32 2 lynn0p
 
33 7 lynn0p
-- This is not meant to be a high performance controller. No fancy command
34
--  scheduling, does the bare minimum to work without screwing up timing.
35
-- Do NOT put this controller in something mission critical! This is the creation
36
--  of a guy in his bedroom, learning digital circuits.
37
-- Intended to be used exclusively with the Spartan3e Starter Board and targets
38
--  the mt46v32m16 chip. Dunno if it will work anywhere else.
39
-- Uses the ODDR2 and DCM Xilinx primitives, for other FPGAs, you'll need to
40
--  patch in equivalents. See sdram_support for the details.
41
-- I'd strongly recommend running it through a post-PAR simulation if you're
42
--  porting to any other FPGA, as the timings will probably change on you.
43
-- Consumes two DCMs, runs off of the main 50mhz board clock. Could possibly
44
--  consume one DCM if you want to feed it the 100mhz clock directly.
45
-- Has an 8bit wide datapath, moderate changes could support 16bits, 32 bits
46
--  you'll have to work some. You want more than that, you'll be doing brain
47
--  surgery on the FSMs - good luck.
48 2 lynn0p
 
49 7 lynn0p
-- This design has been tested with the testbench only. There may be glitches
50
--  hidden in here somewhere still. Consider this to be an alpha release.
51 2 lynn0p
-- Did I mention that you shouldn't put this in anything mission critical? 
52
 
53 7 lynn0p
-- Be careful with the synthesizer settings too. Do not let the FSM extractor
54
--  choose something other than one-hot. Be careful with equivalent register
55
--  removal. I've rolled all synthesizer settings back to default and things
56
--  seem to be OK, but pay attention to the synthesizer reports!
57 2 lynn0p
 
58
-- TODO: implement reset signal
59
entity sdram_controller is
60
        port(      -- user facing signals 
61
                 clk50mhz : in  std_logic;
62
                en : in  std_logic;
63
                    reset : in  std_logic;
64
                       op : in  std_logic_vector(1 downto 0);        -- 00/11: NOP, 01: READ, 10: write
65
                     addr : in  std_logic_vector(25 downto 0);       -- address to read/write 
66
                   op_ack : out std_logic;                           -- op, addr and data_i should be captured when this goes high
67
                   busy_n : out std_logic;                           -- busy when LOW, ops will be ignored until busy goes high again
68
                   data_o : out std_logic_vector(7 downto 0);        -- data from read shows up here
69
                   data_i : in  std_logic_vector(7 downto 0);        -- data to write needs to be here
70
 
71
                -- SDRAM facing signals 
72
                          dram_clkp : out   std_logic;                         -- 0 deg phase 100mhz clock going out to SDRAM chip
73
                          dram_clkn : out   std_logic;                         -- 180 deg phase version of dram_clkp
74
                dram_clke : out   std_logic;                         -- clock enable, owned by the init module
75
                            dram_cs : out   std_logic;                         -- tied low upon powerup
76
                 dram_cmd : out   std_logic_vector(2 downto 0);      -- this is the command vector <we_n,cas_n,ras_n>
77
           dram_bank : out   std_logic_vector(1 downto 0);      -- bank address
78
                          dram_addr : out   std_logic_vector(12 downto 0);     -- row/col/mode register
79
                            dram_dm : out   std_logic_vector(1 downto 0);      -- masks used for writing
80
                           dram_dqs : inout std_logic_vector(1 downto 0);      -- strobes used for writing
81
                            dram_dq : inout std_logic_vector(15 downto 0);     -- data lines
82
 
83
                          -- debug signals (possibly could be repurposed later for wider data)
84
                          debug_reg : out   std_logic_vector(7 downto 0)
85
                                 );
86
end sdram_controller;
87
 
88
architecture impl of sdram_controller is
89
 
90
        -- component decls begin here
91
        component sdram_dcm is
92
                port(
93
                        reset      : in  std_logic;
94
                        clk50mhz   : in  std_logic;
95
                        locked     : out std_logic;
96
                        dram_clkp  : out std_logic;
97
                        dram_clkn  : out std_logic;
98
                        clk_000    : out std_logic;
99
                        clk_090    : out std_logic;
100
                        clk_180    : out std_logic;
101
                        clk_270    : out std_logic
102
                );
103
        end component;
104
 
105
        component oddr2_2 is
106
                port(
107
                        Q  : out std_logic_vector(1 downto 0);
108
                        C0 : in  std_logic;
109
                        C1 : in  std_logic;
110
                        CE : in  std_logic;
111
                        D0 : in  std_logic_vector(1 downto 0);
112
                        D1 : in  std_logic_vector(1 downto 0);
113
                        R  : in  std_logic;
114
                        S  : in  std_logic );
115
        end component;
116
 
117
        component oddr2_3 is
118
                port(
119
                        Q  : out std_logic_vector(2 downto 0);
120
                        C0 : in  std_logic;
121
                        C1 : in  std_logic;
122
                        CE : in  std_logic;
123
                        D0 : in  std_logic_vector(2 downto 0);
124
                        D1 : in  std_logic_vector(2 downto 0);
125
                        R  : in  std_logic;
126
                        S  : in  std_logic );
127
        end component;
128
 
129
        component oddr2_13 is
130
                port(
131
                        Q  : out std_logic_vector(12 downto 0);
132
                        C0 : in  std_logic;
133
                        C1 : in  std_logic;
134
                        CE : in  std_logic;
135
                        D0 : in  std_logic_vector(12 downto 0);
136
                        D1 : in  std_logic_vector(12 downto 0);
137
                        R  : in  std_logic;
138
                        S  : in  std_logic );
139
        end component;
140
 
141
        component inout_switch_2 is
142
                port (
143
                        ioport : inout std_logic_vector(1 downto 0);
144
                                dir : in    std_logic;
145
                        data_i : in    std_logic_vector(1 downto 0)
146
                );
147
        end component;
148
 
149
        component inout_switch_16 is
150
                port (
151
                        ioport : inout std_logic_vector(15 downto 0);
152
                                dir : in    std_logic;
153
                        data_o : out   std_logic_vector(15 downto 0);
154
                        data_i : in    std_logic_vector(15 downto 0)
155
                );
156
        end component;
157
 
158
        component sdram_reader is
159
                port(
160
                        clk270 : in  std_logic;
161
                        rst    : in  std_logic;
162
                        dq     : in  std_logic_vector(15 downto 0);
163
                        data0  : out std_logic_vector(7 downto 0);
164
                        data1  : out std_logic_vector(7 downto 0)
165
                );
166
        end component;
167
 
168
        component sdram_writer is
169
                port(
170
                        clk    : in  std_logic;
171
                        clk090 : in  std_logic;
172
                        clk180 : in  std_logic;
173
                        clk270 : in  std_logic;
174
                        rst    : in  std_logic;
175
                        addr   : in  std_logic;
176
                        data_o : in  std_logic_vector(7 downto 0);
177
                        dqs    : out std_logic_vector(1 downto 0);
178
                        dm     : out std_logic_vector(1 downto 0);
179 6 lynn0p
                        dq     : out std_logic_vector(15 downto 0)
180 2 lynn0p
                );
181
        end component;
182
 
183
        component wait_counter is
184
                generic(
185
                        BITS : integer;
186
                        CLKS : integer
187
                );
188
                port(
189
                         clk : in std_logic;
190
                         rst : in std_logic;
191
                        done : out std_logic
192
                );
193
        end component;
194
 
195
        component sdram_init
196
                port(
197
                        clk_000 : in std_logic;
198
                        reset   : in std_logic;
199
 
200
                        clke  : out std_logic;
201
                        cmd   : out std_logic_vector(2 downto 0);
202
                        bank  : out std_logic_vector(1 downto 0);
203
                        addr  : out std_logic_vector(12 downto 0);
204
                        done  : out std_logic
205
                );
206
        end component;
207
 
208
        component cmd_bank_addr_switch is
209
                port(
210
                        sel      : in std_logic;
211
                        cmd0_in  : in std_logic_vector(2 downto 0);
212
                        bank0_in : in std_logic_vector(1 downto 0);
213
                        addr0_in : in std_logic_vector(12 downto 0);
214
                        cmd1_in  : in std_logic_vector(2 downto 0);
215
                        bank1_in : in std_logic_vector(1 downto 0);
216
                        addr1_in : in std_logic_vector(12 downto 0);
217
                        cmd_out  : out std_logic_vector(2 downto 0);
218
                        bank_out : out std_logic_vector(1 downto 0);
219
                        addr_out : out std_logic_vector(12 downto 0)
220
                );
221
        end component;
222
        -- component decls end here
223
 
224
        -- DRAM commands - <we,cas,ras>
225
        constant CMD_NOP        : std_logic_vector(2 downto 0)  := "111";
226
        constant CMD_ACTIVE     : std_logic_vector(2 downto 0)  := "110"; -- opens a row within a bank
227
        constant CMD_READ       : std_logic_vector(2 downto 0)  := "101";
228
        constant CMD_WRITE      : std_logic_vector(2 downto 0)  := "001";
229
        constant CMD_BURST_TERM : std_logic_vector(2 downto 0)  := "011";
230
        constant CMD_PRECHARGE  : std_logic_vector(2 downto 0)  := "010"; -- closes a row within a bank
231
        constant CMD_AUTO_REFR  : std_logic_vector(2 downto 0)  := "100";
232
        constant CMD_LOAD_MR    : std_logic_vector(2 downto 0)  := "000";
233
 
234
        -- various wait counter values
235
        constant AUTO_REFRESH_CLKS  : integer := 700; -- spec says 7.8us, which is 780 clocks @ 100Mhz, I'm setting it to 700
236
        constant WRITE_RECOVER_CLKS : integer := 5;   -- these are fudged a bit, you *might* be able to shave a clock or two off
237
        constant READ_DONE_CLKS     : integer := 5;
238
 
239
        type CMD_STATES is ( STATE_START, STATE_INIT, STATE_WAIT_INIT, STATE_IDLE, STATE_IDLE_AUTO_REFRESH, STATE_IDLE_WAIT_AR_CTR,
240
                                                                STATE_IDLE_WAIT_AUTO_REFRESH, STATE_WRITE_ROW_OPEN, STATE_WRITE_WAIT_ROW_OPEN, STATE_WRITE_ISSUE_CMD,
241
                                                                STATE_WRITE_WAIT_RECOVER, STATE_READ_ROW_OPEN, STATE_READ_WAIT_ROW_OPEN, STATE_READ_ISSUE_CMD,
242
                                                                STATE_READ_WAIT_CAPTURE );
243
 
244
        signal cmd_state : CMD_STATES := STATE_START;
245
 
246
        signal cmd_oddr2_rising   : std_logic_vector(2 downto 0) := CMD_NOP;
247
        signal bank_oddr2_rising  : std_logic_vector(1 downto 0) := "00";
248
        signal addr_oddr2_rising  : std_logic_vector(12 downto 0) := "0000000000000";
249
 
250
        signal dqs_out : std_logic_vector(1 downto 0);
251
        signal dqs_dir : std_logic;
252
 
253
        signal dq_in : std_logic_vector(15 downto 0);
254
        signal dq_out : std_logic_vector(15 downto 0);
255
        signal dq_dir : std_logic;
256
 
257
        signal reader_rst : std_logic := '1';
258
        signal writer_rst : std_logic := '1';
259
 
260
        signal dcm_locked   : std_logic;
261
        signal clk_000      : std_logic;
262
        signal clk_090      : std_logic;
263
        signal clk_180      : std_logic;
264
        signal clk_270      : std_logic;
265
 
266
        -- init module stuff
267
        signal init_reset : std_logic;
268
        signal init_cmd   : std_logic_vector(2 downto 0);
269
        signal init_bank  : std_logic_vector(1 downto 0);
270
        signal init_addr  : std_logic_vector(12 downto 0);
271
        signal init_done  : std_logic;
272
 
273
        -- main module stuff
274
        signal main_sel  : std_logic;
275
        signal main_cmd  : std_logic_vector(2 downto 0);
276
        signal main_bank : std_logic_vector(1 downto 0);
277
        signal main_addr : std_logic_vector(12 downto 0);
278
 
279
        -- wait counter stuff
280
        signal need_ar_rst : std_logic;
281
        signal need_ar     : std_logic;
282
 
283
        signal wait_ar_rst  : std_logic;
284
        signal wait_ar_done : std_logic;
285
 
286
        signal write_reco_rst  : std_logic;
287
        signal write_reco_done : std_logic;
288
 
289
        signal read_wait_rst : std_logic;
290
        signal read_wait_done : std_logic;
291
 
292
        signal data0_o : std_logic_vector(7 downto 0);
293
        signal data1_o : std_logic_vector(7 downto 0);
294
 
295
begin
296
 
297
        -- component instantiations begin here
298
        DRAM_DCM: sdram_dcm
299
        port map(
300
                reset           => reset,
301
                clk50mhz        => clk50mhz,
302
                locked          => dcm_locked,
303
                dram_clkp       => dram_clkp,
304
                dram_clkn       => dram_clkn,
305
                clk_000         => clk_000,
306
                clk_090         => clk_090,
307
                clk_180         => clk_180,
308
                clk_270         => clk_270
309
        );
310
 
311
        DRAM_INIT: sdram_init
312
        port map(
313
                clk_000 => clk_000,
314
                reset   => init_reset,
315
                clke    => dram_clke,
316
                cmd     => init_cmd,
317
                bank    => init_bank,
318
                addr    => init_addr,
319
                done    => init_done
320
        );
321
 
322
        CMD_BANK_ADDR_SEL: cmd_bank_addr_switch
323
        port map(
324
                sel      => main_sel,
325
                cmd0_in  => init_cmd,
326
                bank0_in => init_bank,
327
                addr0_in => init_addr,
328
                cmd1_in  => main_cmd,
329
                bank1_in => main_bank,
330
                addr1_in => main_addr,
331
                cmd_out  => cmd_oddr2_rising,
332
                bank_out => bank_oddr2_rising,
333
                addr_out => addr_oddr2_rising
334
        );
335
 
336
        DRAM_BANK_ODDR2: oddr2_2
337
        port map(
338
                Q  => dram_bank,
339
                C0 => clk_270,
340
                C1 => clk_090,
341
                CE => '1',
342
                D0 => bank_oddr2_rising,
343
                D1 => "00",
344
                R  => '0',
345
                S  => '0' );
346
 
347
        DRAM_CMD_ODDR2: oddr2_3
348
        port map(
349
                Q  => dram_cmd,
350
                C0 => clk_270,
351
                C1 => clk_090,
352
                CE => '1',
353
                D0 => cmd_oddr2_rising,
354
                D1 => CMD_NOP,
355
                R  => '0',
356
                S  => '0' );
357
 
358
        DRAM_ADDR_ODDR2: oddr2_13
359
        port map(
360
                Q  => dram_addr,
361
                C0 => clk_270,
362
                C1 => clk_090,
363
                CE => '1',
364
                D0 => addr_oddr2_rising,
365
                D1 => "0000000000000",
366
                R  => '0',
367
                S  => '0' );
368
 
369
        DQS_SWITCH: inout_switch_2
370
        port map(
371
                ioport => dram_dqs,
372
                dir    => dqs_dir,
373
                data_i => dqs_out
374
        );
375
 
376
        DQ_SWITCH: inout_switch_16
377
        port map(
378
                ioport => dram_dq,
379
                dir    => dq_dir,
380
                data_o => dq_in,
381
                data_i => dq_out
382
        );
383
 
384
        AR_NEEDED_CTR: wait_counter
385
        generic map(
386
                BITS => 10,
387
                CLKS => AUTO_REFRESH_CLKS
388
        )
389
        port map (
390
          clk => clk_000,
391
          rst => need_ar_rst,
392
         done => need_ar
393
        );
394
 
395
        WAIT_AR_CTR: wait_counter
396
        generic map(
397
                BITS => 4,
398
                CLKS => 11
399
        )
400
        port map(
401
                clk => clk_000,
402
                rst => wait_ar_rst,
403
                done => wait_ar_done
404
        );
405
 
406
        WRITE_RECOVER_CTR: wait_counter
407
        generic map(
408
                BITS => 2,
409
                CLKS => WRITE_RECOVER_CLKS
410
        )
411
        port map(
412
          clk => clk_000,
413
          rst => write_reco_rst,
414
         done => write_reco_done
415
        );
416
 
417
        READ_DONE_CTR: wait_counter
418
        generic map(
419
                BITS => 2,
420
                CLKS => READ_DONE_CLKS
421
        )
422
        port map(
423
          clk => clk_000,
424
          rst => read_wait_rst,
425
         done => read_wait_done
426
        );
427
 
428
        READER: sdram_reader
429
        port map(
430
      clk270 => clk_270,
431
      rst    => reader_rst,
432
      dq     => dq_in,
433
                data0  => data0_o,
434
                data1  => data1_o
435
        );
436
 
437
        WRITER: sdram_writer
438
        port map(
439
                clk    => clk_000,
440
                clk090 => clk_090,
441
                clk180 => clk_180,
442
                clk270 => clk_270,
443
                rst    => writer_rst,
444
                addr   => addr(0),
445
                data_o => data_i,
446
                dqs    => dqs_out,
447
                dm     => dram_dm,
448 6 lynn0p
                dq     => dq_out
449 2 lynn0p
        );
450
        -- end component allocs
451 6 lynn0p
 
452
        debug_reg <= x"00";
453 2 lynn0p
        dram_cs <= '0';
454
        data_o <= data1_o when addr(0) = '1' else data0_o;
455
 
456
        -- command state machine
457
        process (clk_000)
458
        begin
459
                if (rising_edge(clk_000)) then
460
                        if (dcm_locked = '1') then
461
                                case cmd_state is
462
                                        when STATE_START =>
463
                                                busy_n <= '0';
464
                                                op_ack <= '0';
465
                                                init_reset <= '1';
466
                                                main_sel <= '0';
467
                                                main_cmd <= CMD_NOP;
468
                                                main_bank <= "00";
469
                                                main_addr <= "0000000000000";
470
                                                cmd_state <= STATE_INIT;
471
 
472
                                        when STATE_INIT =>
473
                                                init_reset <= '0';
474
                                                cmd_state <= STATE_WAIT_INIT;
475
 
476
                                        when STATE_WAIT_INIT =>
477
                                                need_ar_rst <= '1';
478
                                                if (init_done = '1') then
479
                                                        cmd_state <= STATE_IDLE;
480
                                                else
481
                                                        cmd_state <= cmd_state;
482
                                                end if;
483
 
484
                                        when STATE_IDLE =>
485
                                                -- this is the main hub state
486
                                                -- this is where reads and writes return to after being completed
487
                                                busy_n <= '1';
488
                                                op_ack <= '0';
489
                                                need_ar_rst <= '0';
490
                                                main_sel <= '1';
491
                                                writer_rst <= '1';
492
                                                reader_rst <= '1';
493
                                                if (need_ar = '1') then
494
                                                        cmd_state <= STATE_IDLE_AUTO_REFRESH;
495 6 lynn0p
                                                elsif (op = "01" and en = '1') then
496 2 lynn0p
                                                        cmd_state <= STATE_READ_ROW_OPEN;
497 6 lynn0p
                                                elsif (op = "10" and en = '1') then
498 2 lynn0p
                                                        cmd_state <= STATE_WRITE_ROW_OPEN;
499
                                                else
500
                                                        cmd_state <= cmd_state;
501
                                                end if;
502
 
503
                                        when STATE_IDLE_AUTO_REFRESH =>
504
                                                need_ar_rst <= '1';
505
                                                wait_ar_rst <= '1';
506
                                                main_cmd <= CMD_AUTO_REFR;
507
                                                main_bank <= "00";
508
                                                main_addr <= "0000000000000";
509
                                                cmd_state <= STATE_IDLE_WAIT_AR_CTR;
510
 
511
                                        when STATE_IDLE_WAIT_AR_CTR =>
512
                                                wait_ar_rst <= '0';
513
                                                main_cmd <= CMD_NOP;
514
                                                main_bank <= "00";
515
                                                main_addr <= "0000000000000";
516
                                                cmd_state <= STATE_IDLE_WAIT_AUTO_REFRESH;
517
 
518
                                        when STATE_IDLE_WAIT_AUTO_REFRESH =>
519
                                                main_cmd <= CMD_NOP;
520
                                                main_bank <= "00";
521
                                                main_addr <= "0000000000000";
522
                                                if (wait_ar_done = '1') then
523
                                                        cmd_state <= STATE_IDLE;
524
                                                else
525
                                                        cmd_state <= cmd_state;
526
                                                end if;
527
 
528
                                        when STATE_WRITE_ROW_OPEN =>
529
                                                busy_n <= '0';
530
                                                dqs_dir <= '1';
531
                                                dq_dir <= '1';
532
                                                main_cmd <= CMD_ACTIVE;
533
                                                main_bank <= addr(25 downto 24);
534
                                                main_addr <= addr(23 downto 11);
535
                                                cmd_state <= STATE_WRITE_WAIT_ROW_OPEN;
536
 
537
                                        when STATE_WRITE_WAIT_ROW_OPEN =>
538
                                                main_cmd <= CMD_NOP;
539
                                                main_bank <= addr(25 downto 24); -- timing kludge
540
                                                main_addr <= "001" & addr(10 downto 1); -- last bit determines upper/lower byte in word
541
                                                cmd_state <= STATE_WRITE_ISSUE_CMD;
542
 
543
                                        when STATE_WRITE_ISSUE_CMD =>
544
                                                writer_rst <= '0';
545
                                                write_reco_rst <= '1';
546
                                                main_cmd <= CMD_WRITE;
547
                                                main_bank <= addr(25 downto 24);
548
                                                main_addr <= "001" & addr(10 downto 1); -- last bit determines upper/lower byte in word
549
                                                cmd_state <= STATE_WRITE_WAIT_RECOVER;
550
 
551
                                        when STATE_WRITE_WAIT_RECOVER =>
552
                                                op_ack <= '1';
553
                                                write_reco_rst <= '0';
554
                                                main_cmd <= CMD_NOP;
555
                                                main_bank <= "00";
556
                                                main_addr <= "0000000000000";
557
                                                if (write_reco_done = '1') then
558
                                                        cmd_state <= STATE_IDLE;
559
                                                else
560
                                                        cmd_state <= cmd_state;
561
                                                end if;
562
 
563
                                        when STATE_READ_ROW_OPEN =>
564
                                                busy_n <= '0';
565
                                                dqs_dir <= '0';
566
                                                dq_dir <= '0';
567
                                                main_cmd <= CMD_ACTIVE;
568
                                                main_bank <= addr(25 downto 24);
569
                                                main_addr <= addr(23 downto 11);
570
                                                cmd_state <= STATE_READ_WAIT_ROW_OPEN;
571
 
572
                                        when STATE_READ_WAIT_ROW_OPEN =>
573
                                                main_cmd <= CMD_NOP;
574
                                                main_bank <= addr(25 downto 24); -- timing kludge
575
                                                main_addr <= "001" & addr(10 downto 1); -- last bit determines upper/lower byte
576
                                                cmd_state <= STATE_READ_ISSUE_CMD;
577
 
578
                                        when STATE_READ_ISSUE_CMD =>
579
                                                read_wait_rst <= '1';
580
                                                main_cmd <= CMD_READ;
581
                                                main_bank <= addr(25 downto 24);
582
                                                main_addr <= "001" & addr(10 downto 1); -- last bit determines upper/lower byte
583
                                                cmd_state <= STATE_READ_WAIT_CAPTURE;
584
 
585
                                        when STATE_READ_WAIT_CAPTURE =>
586
                                                op_ack <= '1';
587
                                                read_wait_rst <= '0';
588
                                                reader_rst <= '0';
589
                                                main_cmd <= CMD_NOP;
590
                                                main_bank <= "00";
591
                                                main_addr <= "0000000000000";
592
                                                if (read_wait_done = '1') then
593
                                                        cmd_state <= STATE_IDLE;
594
                                                else
595
                                                        cmd_state <= cmd_state;
596
                                                end if;
597
                                end case;
598
                        end if;
599
                end if;
600
        end process;
601
 
602
end impl;
603
 
604
 

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.