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

Subversion Repositories embedded_risc

[/] [embedded_risc/] [trunk/] [Verilog/] [cmd_generator.v] - Blame information for rev 29

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

Line No. Rev Author Line
1 26 hosseinami
/*********************************************************
2
 MODULE:                Sub Level SDRAM Command Genrator
3
 
4
 FILE NAME:     cmd_generator.v
5
 VERSION:       1.0
6
 DATE:          April 28th, 2002
7
 AUTHOR:                Hossein Amidi
8
 COMPANY:
9
 CODE TYPE:     Register Transfer Level
10
 
11
 DESCRIPTION:   This module is the sub level RTL code of SDRAM Controller ASIC verilog
12
 code. It will generate the SDRAM control signals.
13
 
14
 
15
 Hossein Amidi
16
 (C) April 2002
17
 
18
*********************************************************/
19
 
20
// DEFINES
21
`timescale 1ns / 10ps
22
 
23
module cmd_generator(// Input
24
                                                        reset,
25
                                                        clk0,
26
                                                        do_reada,
27
                                                        do_writea,
28
                                                        do_preacharge,
29
                                                        do_rw,
30
                                                        rowaddr,
31
                                                        coladdr,
32
                                                        bankaddr,
33
                                                        page_mod,
34
                                                        do_load_mod,
35
                                                        do_refresh,
36
                                                        caddr,
37
                                                        do_nop,
38
                                                        rw_flag,
39
                                                        oe4,
40
                                                        // Output
41
                                                        sadd,
42
                                                        ba,
43
                                                        cs,
44
                                                        ras,
45
                                                        cas,
46
                                                        we,
47
                                                        cke
48
                                                        );
49
 
50
 
51
// Parameter
52
`include        "parameter.v"
53
 
54
// Input
55
input reset;
56
input clk0;
57
input do_reada;
58
input do_writea;
59
input do_preacharge;
60
input do_rw;
61
input [row_size - 1:0]        rowaddr;
62
input [col_size - 1:0]        coladdr;
63
input [bank_size - 1:0]       bankaddr;
64
input page_mod;
65
input do_load_mod;
66
input do_refresh;
67
input [padd_size - 1 : 0]caddr;
68
input do_nop;
69
input rw_flag;
70
input oe4;
71
 
72
// Output
73
output [add_size - 1 : 0]sadd;
74
output [ba_size - 1 : 0]ba;
75
output [cs_size - 1 : 0]cs;
76
output ras;
77
output cas;
78
output we;
79
output cke;
80
 
81
 
82
// Internal wire and reg signals
83
wire reset;
84
wire clk0;
85
wire do_reada;
86
wire do_writea;
87
wire do_preacharge;
88
wire do_rw;
89
wire [row_size - 1:0]        rowaddr;
90
wire [col_size - 1:0]        coladdr;
91
wire [bank_size - 1:0]       bankaddr;
92
wire page_mod;
93
wire do_load_mod;
94
wire do_refresh;
95
wire [padd_size - 1 : 0]caddr;
96
wire do_nop;
97
wire rw_flag;
98
wire oe4;
99
 
100
reg [add_size - 1 : 0]sadd;
101
reg [ba_size - 1 : 0]ba;
102
reg [cs_size - 1 : 0]cs;
103
reg ras;
104
reg cas;
105
reg we;
106
reg cke;
107
 
108
 
109
// Assignment
110
 
111
 
112
 
113
// This always block generates the address, cs, cke, and command signals(ras,cas,wen)
114
// 
115
always @(posedge reset or posedge clk0)
116
begin
117
        if (reset == 1'b1) begin
118
                sadd <= 0;
119
                ba   <= 0;
120
                cs   <= 1;
121
                ras  <= 1;
122
                cas  <= 1;
123
                we   <= 1;
124
                cke  <= 0;
125
        end
126
        else begin
127
                cke  <= 1;
128
 
129
// Generate sadd        
130
 
131
                if (do_writea == 1 | do_reada == 1)    // ACTIVATE command is being issued, so present the row address
132
                        sadd <= rowaddr;
133
                else if ((do_rw == 1) | (do_preacharge == 1))
134
                        sadd[10] <= !page_mod;              // set sadd[10] for autopreacharge read/write or for a preacharge all command
135
                else                                        // don't set it if the controller is in page mode.           
136
                        sadd <= coladdr;                 // else alway present column address
137
                if (do_preacharge == 1 | do_load_mod == 1)
138
                        ba <= 0;                       // Set ba=0 if performing a preacharge or load_mod command
139
                else
140
                        ba <= bankaddr[1:0];           // else set it with the appropriate address bits
141
 
142
                if (do_refresh == 1 | do_preacharge == 1 | do_load_mod == 1)
143
                        cs <= 0;                                    // Select both chip selects if performing
144
                else                                                  // refresh, preacharge(all) or load_mod
145
                begin
146
                        cs[0] <= caddr[padd_size - 1];                   // else set the chip selects based off of the
147
                        cs[1] <= ~caddr[padd_size - 1];                  // msb address bit
148
                end
149
 
150
 
151
//Generate the appropriate logic levels on ras, cas, and we
152
//depending on the issued command.
153
//              
154
                if (do_nop == 1) begin                                          // No Operation: RAS=1, CAS=1, WE=1
155
                        ras <= 1;
156
                        cas <= 1;
157
                        we  <= 1;
158
                end
159
                     else if (do_refresh == 1) begin                        // refresh: S=00, RAS=0, CAS=0, WE=1
160
                        ras <= 0;
161
                        cas <= 0;
162
                        we  <= 1;
163
                end
164
                else if ((do_preacharge == 1) & ((oe4 == 1) | (rw_flag == 1))) begin      // burst terminate if write is active
165
                        ras <= 1;
166
                        cas <= 1;
167
                        we  <= 0;
168
                end
169
                else if (do_preacharge == 1) begin                 // preacharge All: S=00, RAS=0, CAS=1, WE=0
170
                        ras <= 0;
171
                        cas <= 1;
172
                        we  <= 0;
173
                end
174
                else if (do_load_mod == 1) begin                 // Mode Write: S=00, RAS=0, CAS=0, WE=0
175
                        ras <= 0;
176
                        cas <= 0;
177
                        we  <= 0;
178
                end
179
                else if (do_reada == 1 | do_writea == 1) begin  // Activate: S=01 or 10, RAS=0, CAS=1, WE=1
180
                        ras <= 0;
181
                        cas <= 1;
182
                        we  <= 1;
183
                end
184
                else if (do_rw == 1) begin                      // Read/Write: S=01 or 10, RAS=1, CAS=0, WE=0 or 1
185
                        ras <= 1;
186
                        cas <= 0;
187
                        we  <= rw_flag;
188
                end
189
                else begin                                      // No Operation: RAS=1, CAS=1, WE=1
190
                        ras <= 1;
191
                        cas <= 1;
192
                        we  <= 1;
193
                end
194
        end
195
end
196
 
197
 
198
 
199
endmodule

powered by: WebSVN 2.1.0

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