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

Subversion Repositories sdr_ctrl

[/] [sdr_ctrl/] [trunk/] [verif/] [tb/] [tb_core.sv] - Blame information for rev 36

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

Line No. Rev Author Line
1 30 dinesha
//////////////////////////////////////////////////////////////////////
2
////                                                              ////
3
////                                                              ////
4
////  This file is part of the SDRAM Controller project           ////
5
////  http://www.opencores.org/cores/sdr_ctrl/                    ////
6
////                                                              ////
7
////  Description                                                 ////
8
////  SDRAM CTRL definitions.                                     ////
9
////                                                              ////
10
////  To Do:                                                      ////
11
////    nothing                                                   ////
12
////                                                              ////
13
////  Author(s):                                                  ////
14
////      - Dinesh Annayya, dinesha@opencores.org                 ////
15
////                                                              ////
16
//////////////////////////////////////////////////////////////////////
17
////                                                              ////
18
//// Copyright (C) 2000 Authors and OPENCORES.ORG                 ////
19
////                                                              ////
20
//// This source file may be used and distributed without         ////
21
//// restriction provided that this copyright statement is not    ////
22
//// removed from the file and that any derivative work contains  ////
23
//// the original copyright notice and the associated disclaimer. ////
24
////                                                              ////
25
//// This source file is free software; you can redistribute it   ////
26
//// and/or modify it under the terms of the GNU Lesser General   ////
27
//// Public License as published by the Free Software Foundation; ////
28
//// either version 2.1 of the License, or (at your option) any   ////
29
//// later version.                                               ////
30
////                                                              ////
31
//// This source is distributed in the hope that it will be       ////
32
//// useful, but WITHOUT ANY WARRANTY; without even the implied   ////
33
//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      ////
34
//// PURPOSE.  See the GNU Lesser General Public License for more ////
35
//// details.                                                     ////
36
////                                                              ////
37
//// You should have received a copy of the GNU Lesser General    ////
38
//// Public License along with this source; if not, download it   ////
39
//// from http://www.opencores.org/lgpl.shtml                     ////
40
////                                                              ////
41
//////////////////////////////////////////////////////////////////////
42
 
43
// This testbench stand-alone verify the sdram core
44
 
45
`timescale 1ns/1ps
46
 
47
module tb_core;
48
 
49
parameter P_SYS  = 10;     //    100MHz
50
 
51
// General
52
reg            RESETN;
53
reg            sdram_clk;
54
 
55
initial sdram_clk = 0;
56
 
57
always #(P_SYS/2) sdram_clk = !sdram_clk;
58
 
59
parameter      dw              = 32;  // data width
60
parameter      tw              = 8;   // tag id width
61
parameter      bl              = 5;   // burst_lenght_width
62
 
63
//-------------------------------------------
64
// Application Interface bus
65
//-------------------------------------------
66
reg                   app_req            ; // Application Request
67
reg  [8:0]            app_req_len        ; // Burst Request length
68
wire                  app_req_ack        ; // Application Request Ack
69
reg [29:0]            app_req_addr       ; // Application Address
70
reg                   app_req_wr_n       ; // 1 -> Read, 0 -> Write
71
reg [dw-1:0]          app_wr_data        ; // Write Data
72
reg [dw/8-1:0]        app_wr_en_n        ; // Write Enable, Active Low
73
wire                  app_rd_valid       ; // Read Valid
74
wire                  app_last_rd        ; // Last Read Valid
75
wire [dw-1:0]         app_rd_data        ; // Read Data
76
 
77
//--------------------------------------------
78
// SDRAM I/F
79
//--------------------------------------------
80
 
81
`ifdef SDR_32BIT
82
   wire [31:0]           Dq                 ; // SDRAM Read/Write Data Bus
83
   wire [31:0]           sdr_dout           ; // SDRAM Data Out
84
   wire [31:0]           pad_sdr_din        ; // SDRAM Data Input
85
   wire [3:0]            sdr_den_n          ; // SDRAM Data Enable
86
   wire [3:0]            sdr_dqm            ; // SDRAM DATA Mask
87
`elsif SDR_16BIT
88
   wire [15:0]           Dq                 ; // SDRAM Read/Write Data Bus
89
   wire [15:0]           sdr_dout           ; // SDRAM Data Out
90
   wire [15:0]           pad_sdr_din        ; // SDRAM Data Input
91
   wire [1:0]            sdr_den_n          ; // SDRAM Data Enable
92
   wire [1:0]            sdr_dqm            ; // SDRAM DATA Mask
93
`else
94
   wire [7:0]           Dq                 ; // SDRAM Read/Write Data Bus
95
   wire [7:0]           sdr_dout           ; // SDRAM Data Out
96
   wire [7:0]           pad_sdr_din        ; // SDRAM Data Input
97
   wire [0:0]           sdr_den_n          ; // SDRAM Data Enable
98
   wire [0:0]           sdr_dqm            ; // SDRAM DATA Mask
99
`endif
100
 
101
wire [1:0]            sdr_ba             ; // SDRAM Bank Select
102
wire [11:0]           sdr_addr           ; // SDRAM ADRESS
103
wire                  sdr_init_done      ; // SDRAM Init Done
104
 
105
// to fix the sdram interface timing issue
106
wire #(2.0) sdram_clk_d = sdram_clk;
107
wire #(1.0) pad_clk     = sdram_clk_d;
108
 
109
`ifdef SDR_32BIT
110
 
111
   sdrc_core #(.SDR_DW(32),.SDR_BW(4)) u_dut(
112
`elsif SDR_16BIT
113
   sdrc_core #(.SDR_DW(16),.SDR_BW(2)) u_dut(
114
`else  // 8 BIT SDRAM
115
   sdrc_core #(.SDR_DW(8),.SDR_BW(1)) u_dut(
116
`endif
117
      // System
118
          .clk                (sdram_clk          ),
119
          .reset_n            (RESETN             ),
120
          .pad_clk            (pad_clk            ),
121
`ifdef SDR_32BIT
122
          .sdr_width          (2'b00              ), // 32 BIT SDRAM
123
`elsif SDR_16BIT
124
          .sdr_width          (2'b01              ), // 16 BIT SDRAM
125
`else
126
          .sdr_width          (2'b10              ), // 8 BIT SDRAM
127
`endif
128
          .cfg_colbits        (2'b00              ), // 8 Bit Column Address
129
 
130
 
131
/* Request from app */
132
          .app_req            (app_req            ),    // Transfer Request
133
          .app_req_addr       (app_req_addr       ),    // SDRAM Address
134
          .app_req_addr_mask  (29'h1FFF_FFFF      ),    // Address mask for queue wrap
135
          .app_req_len        (app_req_len        ),    // Burst Length (in 16 bit words)
136
          .app_req_wrap       (1'b0               ),    // Wrap mode request (xfr_len = 4)
137
          .app_req_wr_n       (app_req_wr_n       ),    // 0 => Write request, 1 => read req
138
          .app_req_ack        (app_req_ack        ),    // Request has been accepted
139
          .sdr_core_busy_n    (                   ),    // OK to arbitrate next request
140
 
141
          .app_wr_data        (app_wr_data        ),
142
          .app_wr_en_n        (app_wr_en_n        ),
143
          .app_rd_data        (app_rd_data        ),
144
          .app_last_rd        (app_last_rd        ),
145
          .app_rd_valid       (app_rd_valid       ),
146
          .app_wr_next_req    (app_wr_next_req    ),
147
          .app_req_dma_last   (app_req            ),
148
 
149
/* Interface to SDRAMs */
150
          .sdr_cs_n           (sdr_cs_n           ),
151
          .sdr_cke            (sdr_cke            ),
152
          .sdr_ras_n          (sdr_ras_n          ),
153
          .sdr_cas_n          (sdr_cas_n          ),
154
          .sdr_we_n           (sdr_we_n           ),
155
          .sdr_dqm            (sdr_dqm            ),
156
          .sdr_ba             (sdr_ba             ),
157
          .sdr_addr           (sdr_addr           ),
158
          .pad_sdr_din        (Dq                 ),
159
          .sdr_dout           (sdr_dout           ),
160
          .sdr_den_n          (sdr_den_n          ),
161
 
162
    /* Parameters */
163
          .sdr_init_done      (sdr_init_done      ),
164
          .cfg_req_depth      (2'h2               ),            //how many req. buffer should hold
165
          .cfg_sdr_en         (1'b1               ),
166
          .cfg_sdr_mode_reg   (12'h033            ),
167
          .cfg_sdr_tras_d     (4'h4               ),
168
          .cfg_sdr_trp_d      (4'h2               ),
169
          .cfg_sdr_trcd_d     (4'h2               ),
170
          .cfg_sdr_cas        (3'h3               ),
171
          .cfg_sdr_trcar_d    (4'h7               ),
172
          .cfg_sdr_twr_d      (4'h1               ),
173
          .cfg_sdr_rfsh       (12'hC35            ),
174
          .cfg_sdr_rfmax      (3'h6               )
175
 
176
);
177
 
178
 
179
`ifdef SDR_32BIT
180
  assign Dq[7:0]    = (sdr_den_n[0] == 1'b0) ? sdr_dout[7:0]   : 8'hZZ;
181
  assign Dq[15:8]   = (sdr_den_n[1] == 1'b0) ? sdr_dout[15:8]  : 8'hZZ;
182
  assign Dq[23:16]  = (sdr_den_n[2] == 1'b0) ? sdr_dout[23:16] : 8'hZZ;
183
  assign Dq[31:24]  = (sdr_den_n[3] == 1'b0) ? sdr_dout[31:24] : 8'hZZ;
184
mt48lc2m32b2 #(.data_bits(32)) u_sdram32 (
185
          .Dq                 (Dq                 ) ,
186
          .Addr               (sdr_addr           ),
187
          .Ba                 (sdr_ba             ),
188
          .Clk                (sdram_clk_d        ),
189
          .Cke                (sdr_cke            ),
190
          .Cs_n               (sdr_cs_n           ),
191
          .Ras_n              (sdr_ras_n          ),
192
          .Cas_n              (sdr_cas_n          ),
193
          .We_n               (sdr_we_n           ),
194
          .Dqm                (sdr_dqm            )
195
     );
196
 
197
`elsif SDR_16BIT
198
 
199
assign Dq[7:0]  = (sdr_den_n[0] == 1'b0) ? sdr_dout[7:0]  : 8'hZZ;
200
assign Dq[15:8] = (sdr_den_n[1] == 1'b0) ? sdr_dout[15:8] : 8'hZZ;
201
 
202
   IS42VM16400K u_sdram16 (
203
          .dq                 (Dq                 ),
204
          .addr               (sdr_addr           ),
205
          .ba                 (sdr_ba             ),
206
          .clk                (sdram_clk_d        ),
207
          .cke                (sdr_cke            ),
208
          .csb                (sdr_cs_n           ),
209
          .rasb               (sdr_ras_n          ),
210
          .casb               (sdr_cas_n          ),
211
          .web                (sdr_we_n           ),
212
          .dqm                (sdr_dqm            )
213
    );
214
`else
215
 
216
assign Dq[7:0]  = (sdr_den_n[0] == 1'b0) ? sdr_dout[7:0]  : 8'hZZ;
217
 
218
mt48lc8m8a2 #(.data_bits(8)) u_sdram8 (
219
          .Dq                 (Dq                 ) ,
220
          .Addr               (sdr_addr           ),
221
          .Ba                 (sdr_ba             ),
222
          .Clk                (sdram_clk_d        ),
223
          .Cke                (sdr_cke            ),
224
          .Cs_n               (sdr_cs_n           ),
225
          .Ras_n              (sdr_ras_n          ),
226
          .Cas_n              (sdr_cas_n          ),
227
          .We_n               (sdr_we_n           ),
228
          .Dqm                (sdr_dqm            )
229
     );
230
`endif
231
 
232
//--------------------
233
// Write/Read Burst FIFO
234
//--------------------
235
int wrdfifo[$]; // write data fifo
236
int rddfifo[$]; // read data fifo
237
 
238
reg [31:0] read_data;
239
reg [31:0] ErrCnt;
240
int k;
241
reg [31:0] StartAddr;
242
/////////////////////////////////////////////////////////////////////////
243
// Test Case
244
/////////////////////////////////////////////////////////////////////////
245
 
246
initial begin //{
247
  ErrCnt          = 0;
248
   app_req_addr  = 0;
249
   app_wr_data    = 0;
250
   app_wr_en_n    = 4'hF;
251
   app_req_wr_n   = 0;
252
   app_req        = 0;
253
   app_req_len    = 0;
254
 
255
  RESETN    = 1'h1;
256
 
257
 #100
258
  // Applying reset
259
  RESETN    = 1'h0;
260
  #10000;
261
  // Releasing reset
262
  RESETN    = 1'h1;
263
  #1000;
264
  wait(u_dut.sdr_init_done == 1);
265
 
266
  #1000;
267
 
268
  wrdfifo.push_back(32'h11223344);
269
  wrdfifo.push_back(32'h22334455);
270
  wrdfifo.push_back(32'h33445566);
271
  wrdfifo.push_back(32'h44556677);
272
  wrdfifo.push_back(32'h55667788);
273
 
274
  burst_write(32'h40000);
275
 #1000;
276
  burst_read(32'h40000);
277
 
278
 #1000;
279
  burst_write(32'h7000_0000);
280
 #1000;
281
  burst_read(32'h7000_0000);
282
 
283
  for(k=0; k < 20; k++) begin
284
     StartAddr = $random & 32'h07FFFFFF;
285
     burst_write(StartAddr);
286
    #1000;
287
     burst_read(StartAddr);
288
  end
289
 
290
 
291
  #10000;
292
 
293
        $display("###############################");
294
    if(ErrCnt == 0)
295
        $display("STATUS: SDRAM Write/Read TEST PASSED");
296
    else
297
        $display("ERROR:  SDRAM Write/Read TEST FAILED");
298
        $display("###############################");
299
 
300
    $finish;
301
end
302
 
303
task burst_write;
304
input [31:0] Address;
305
int i;
306
begin
307
   @ (negedge sdram_clk);
308
   app_req        = 1;
309
   app_wr_en_n    = 0;
310
   app_req_wr_n   = 1'b0;
311
   $display("Write Address: %x, Burst Size: %d",Address,wrdfifo.size);
312
   app_req_addr  = Address[31:2];
313
   app_req_len    = wrdfifo.size;
314
 
315
   // wait for app_req_ack == 1
316
   do begin
317
       @ (posedge sdram_clk);
318
   end while(app_req_ack == 1'b0);
319
   @ (negedge sdram_clk);
320
   app_req           = 0;
321
 
322
   for(i=0; i < wrdfifo.size; i++) begin
323
      app_wr_data     = wrdfifo[i];
324
 
325
      do begin
326
          @ (posedge sdram_clk);
327
      end while(app_wr_next_req == 1'b0);
328
          @ (negedge sdram_clk);
329
 
330
       $display("Status: Burst-No: %d  Write Address: %x  WriteData: %x ",i,Address,app_wr_data);
331
   end
332
   app_req           = 0;
333
   app_wr_en_n       = 4'hF;
334
end
335
endtask
336
 
337
task burst_read;
338
input [31:0] Address;
339
 
340
int i,j;
341
reg [31:0]   rd_data;
342
begin
343
   @ (negedge sdram_clk);
344
 
345
      app_req        = 1;
346
      app_wr_en_n    = 0;
347
      app_req_wr_n   = 1;
348
      app_req_addr   = Address[29:2];
349
      app_req_len    = wrdfifo.size;
350
      // wait for app_req_ack == 1
351
      do begin
352
          @ (posedge sdram_clk);
353
      end while(app_req_ack == 1'b0);
354
      @ (negedge sdram_clk);
355
      app_req           = 0;
356
 
357
      for(j=0; j < wrdfifo.size; j++) begin
358
         wait(app_rd_valid == 1);
359
         if(app_rd_data !== wrdfifo[j]) begin
360
             $display("READ ERROR: Burst-No: %d Addr: %x Rxp: %x Exd: %x",j,Address+(j*2),app_rd_data,wrdfifo[j]);
361
             ErrCnt = ErrCnt+1;
362
         end else begin
363
             $display("READ STATUS: Burst-No: %d Addr: %x Rxd: %x",j,Address+(j*2),app_rd_data);
364
         end
365
         @ (posedge sdram_clk);
366
         @ (negedge sdram_clk);
367
      end
368
end
369
endtask
370
 
371
 
372
endmodule

powered by: WebSVN 2.1.0

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