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

Subversion Repositories openarty

[/] [openarty/] [trunk/] [rtl/] [eqspiflash.v] - Blame information for rev 12

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

Line No. Rev Author Line
1 3 dgisselq
////////////////////////////////////////////////////////////////////////////////
2
//
3
// Filename:    eqspiflash.v
4
//
5
// Project:     OpenArty, an entirely open SoC based upon the Arty platform
6
//
7
// Purpose:     Provide access to the flash device on an Arty, via the Extended
8
//              SPI interface.  Reads and writes will use the QuadSPI interface
9
//      (4-bits at a time) all other commands (register and otherwise) will use
10
//      the SPI interface (1 bit at a time).
11
//
12
// Registers:
13
//      0. Erase register control.  Provides status of pending writes, erases,
14
//              and commands (sub)sector erase operations.
15
//         Bit-Fields:
16
//              31. WIP (Write-In-Progress), write a '1' to this bit to command
17
//                      an erase sequence.
18
//              30. WriteEnabled -- set to a '1' to disable write protection and
19
//                      to write a WRITE-ENABLE to the device.  Set to a '0' to
20
//                      disable WRITE-ENABLE-LATCH.  (Key is required to enable
21
//                      writes)
22
//              29. Quad mode read/writes enabled.  (Rest of controller will use
23
//                      extended SPI mode, but reads and writes will use Quad
24
//                      mode.)
25
//              28. Subsector erase bit (set 1 to erase a subsector, 0 to 
26
//                      erase a full sector, maintains last value written from
27
//                      an erase command, starts at '0')
28
//              27. SD ID loaded
29
//              26. Write protect violation--cleared upon any valid write
30
//              25. XIP enabled.  (Leave read mode in XIP, so you can start
31
//                      next read faster.)
32
//              24. Unused
33
//              23..0: Address of erase sector upon erase command
34
//              23..14: Sector address (can only be changed w/ key)
35
//              23..10: Subsector address (can only be changed w/ key)
36
//               9.. 0: write protect KEY bits, always read a '0', write
37
//                      commands, such as WP disable or erase, must always
38
//                      write with a '1be' to activate.
39
//      0. WEL: All writes that do not command an erase will be used
40
//                      to set/clear the write enable latch.
41
//                      Send 0x06, return, if WP is clear (enable writes)
42
//                      Send 0x04, return
43
//      1. STATUS
44
//              Send 0x05, read  1-byte
45
//              Send 0x01, write 1-byte: i_wb_data[7:0]
46
//      2. NV-CONFIG (16-bits)
47
//              Send 0xB5, read  2-bytes
48
//              Send 0xB1, write 2-bytes: i_wb_data[15:0]
49
//      3. V-CONFIG (8-bits)
50
//              Send 0x85, read  1-byte
51
//              Send 0x81, write 1-byte: i_wb_data[7:0]
52
//      4. EV-CONFIG (8-bits)
53
//              Send 0x65, read  1-byte
54
//              Send 0x61, write 1-byte: i_wb_data[7:0]
55
//      5. Lock (send 32-bits, rx 1 byte)
56
//              Send 0xE8, last-sector-addr (3b), read  1-byte
57
//              Send 0xE5, last-sector-addr (3b), write 1-byte: i_wb_data[7:0]
58
//      6. Flag Status
59
//              Send 0x70, read  1-byte
60
//              Send 0x50, to clear, no bytes to write
61
//      7. Asynch Read-ID: Write here to cause controller to read ID into buffer
62
//      8.-12.  ID buffer (20 bytes, 5 words)
63
//              Attempted reads before buffer is full will stall bus until 
64
//              buffer is read.  Writes act like the asynch-Read-ID command,
65
//              and will cause the controller to read the buffer.
66
//      13.-14. Unused, mapped to Asynch-read-ID
67
//      15.     OTP control word
68
//                      Write zero to permanently lock OTP
69
//                      Read to determine if OTP is permanently locked
70
//      16.-31. OTP (64-bytes, 16 words, buffered until write)
71
//              (Send DWP before writing to clear write enable latch)
72
//
73
//
74
// Creator:     Dan Gisselquist, Ph.D.
75
//              Gisselquist Technology, LLC
76
//
77
////////////////////////////////////////////////////////////////////////////////
78
//
79
// Copyright (C) 2015-2016, Gisselquist Technology, LLC
80
//
81
// This program is free software (firmware): you can redistribute it and/or
82
// modify it under the terms of  the GNU General Public License as published
83
// by the Free Software Foundation, either version 3 of the License, or (at
84
// your option) any later version.
85
//
86
// This program is distributed in the hope that it will be useful, but WITHOUT
87
// ANY WARRANTY; without even the implied warranty of MERCHANTIBILITY or
88
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
89
// for more details.
90
//
91
// You should have received a copy of the GNU General Public License along
92
// with this program.  (It's in the $(ROOT)/doc directory, run make with no
93
// target there if the PDF file isn't present.)  If not, see
94
// <http://www.gnu.org/licenses/> for a copy.
95
//
96
// License:     GPL, v3, as defined and found on www.gnu.org,
97
//              http://www.gnu.org/licenses/gpl.html
98
//
99
//
100
////////////////////////////////////////////////////////////////////////////////
101
//
102
//
103
// `define      QSPI_READ_ONLY
104
module  eqspiflash(i_clk_200mhz, i_rst,
105
                // Incoming wishbone connection(s)
106
                //      The two strobe lines allow the data to live on a
107
                //      separate part of the master bus from the control 
108
                //      registers.  Only one strobe will ever be active at any
109
                //      time, no strobes will ever be active unless i_wb_cyc
110
                //      is also active.
111
                i_wb_cyc, i_wb_data_stb, i_wb_ctrl_stb, i_wb_we,
112
                i_wb_addr, i_wb_data,
113
                // Outgoing wishbone data
114
                o_wb_ack, o_wb_stall, o_wb_data,
115
                // Quad SPI connections
116
                o_qspi_sck, o_qspi_cs_n, o_qspi_mod, o_qspi_dat, i_qspi_dat,
117
                // Interrupt the CPU
118
                o_interrupt, o_cmd_accepted,
119
                // Debug the interface
120
                o_dbg);
121
 
122
        input                   i_clk_200mhz, i_rst;
123
        // Wishbone bus inputs
124
        input                   i_wb_cyc, i_wb_data_stb, i_wb_ctrl_stb, i_wb_we;
125
        input           [21:0]   i_wb_addr;      // 24 bits of addr space
126
        input           [31:0]   i_wb_data;
127
        // Wishbone bus outputs
128
        output  reg             o_wb_ack;
129
        output  wire            o_wb_stall;
130
        output  reg     [31:0]   o_wb_data;
131
        // Quad SPI connections
132
        output  wire            o_qspi_sck, o_qspi_cs_n;
133
        output  wire    [1:0]    o_qspi_mod;
134
        output  wire    [3:0]    o_qspi_dat;
135
        input   wire    [3:0]    i_qspi_dat;
136
        //
137
        output  reg             o_interrupt;
138
        //
139
        output  reg             o_cmd_accepted;
140
        //
141
        output  wire    [31:0]   o_dbg;
142
 
143
        initial o_cmd_accepted = 1'b0;
144
        always @(posedge i_clk_200mhz)
145
                o_cmd_accepted=((i_wb_data_stb)||(i_wb_ctrl_stb))&&(~o_wb_stall);
146
        //
147
        // lleqspi
148
        //
149
        //      Providing the low-level SPI interface
150
        //
151
        reg     spi_wr, spi_hold, spi_spd, spi_dir, spi_recycle;
152
        reg     [31:0]   spi_word;
153
        reg     [1:0]    spi_len;
154
        wire    [31:0]   spi_out;
155
        wire            spi_valid, spi_busy, spi_stopped;
156
        lleqspi lowlvl(i_clk_200mhz, spi_wr, spi_hold, spi_word, spi_len,
157
                        spi_spd, spi_dir, spi_recycle, spi_out, spi_valid, spi_busy,
158
                o_qspi_sck, o_qspi_cs_n, o_qspi_mod, o_qspi_dat, i_qspi_dat);
159
        assign  spi_stopped = (o_qspi_cs_n)&&(~spi_busy)&&(~spi_wr);
160
 
161
 
162
        //
163
        // Bus module
164
        //
165
        //      Providing a shared interface to the WB bus
166
        //
167
        // Wishbone data (returns)
168
        wire            bus_wb_ack, bus_wb_stall;
169
        wire    [31:0]   bus_wb_data;
170
        // Latched request data
171
        wire            bus_wr;
172
        wire    [21:0]   bus_addr;
173
        wire    [31:0]   bus_data;
174
        wire    [21:0]   bus_sector;
175
        // Strobe commands
176
        wire    bus_ack;
177
        wire    bus_readreq, bus_piperd, bus_ereq, bus_wreq,
178
                        bus_pipewr, bus_endwr, bus_ctreq, bus_idreq,
179
                        bus_other_req,
180
        // Live parameters
181
                        w_xip, w_quad, w_idloaded;
182
        reg             bus_wip;
183
        qspibus preproc(i_clk_200mhz, i_rst,
184
                        i_wb_cyc, i_wb_data_stb, i_wb_ctrl_stb,
185
                                i_wb_we, i_wb_addr, i_wb_data,
186
                                bus_wb_ack, bus_wb_stall, bus_wb_data,
187
                        bus_wr, bus_addr, bus_data, bus_sector,
188
                                bus_readreq, bus_piperd,
189
                                        bus_wreq, bus_ereq,
190
                                        bus_pipewr, bus_endwr,
191
                                bus_ctreq, bus_idreq, bus_other_req, bus_ack,
192
                        w_xip, w_quad, w_idloaded, bus_wip, spi_stopped);
193
 
194
        //
195
        // Read flash module
196
        //
197
        //      Providing a means of (and the logic to support) reading from
198
        //      the flash
199
        //
200
        wire            rd_data_ack;
201
        wire    [31:0]   rd_data;
202
        //
203
        wire            rd_bus_ack;
204
        //
205
        wire            rd_qspi_req;
206
        wire            rd_qspi_grant;
207
        //
208
        wire            rd_spi_wr, rd_spi_hold, rd_spi_spd, rd_spi_dir,
209
                        rd_spi_recycle;
210
        wire    [31:0]   rd_spi_word;
211
        wire    [1:0]    rd_spi_len;
212
        //
213
        readqspi        rdproc(i_clk_200mhz, bus_readreq, bus_piperd,
214
                                        bus_other_req,
215
                                bus_addr, rd_bus_ack,
216
                                rd_qspi_req, rd_qspi_grant,
217
                                rd_spi_wr, rd_spi_hold, rd_spi_word, rd_spi_len,
218
                                rd_spi_spd, rd_spi_dir, rd_spi_recycle,
219
                                        spi_out, spi_valid,
220
                                        spi_busy, spi_stopped, rd_data_ack, rd_data,
221
                                        w_quad, w_xip);
222
 
223
        //
224
        // Write/Erase flash module
225
        //
226
        //      Logic to write (program) and erase the flash.
227
        //
228
        // Wishbone bus return
229
        wire            ew_data_ack;
230
        wire    [31:0]   ew_data;
231
        // Arbiter interaction
232
        wire            ew_qspi_req;
233
        wire            ew_qspi_grant;
234
        // Bus controller return
235
        wire            ew_bus_ack;
236
        // SPI control wires
237
        wire            ew_spi_wr, ew_spi_hold, ew_spi_spd, ew_spi_dir;
238
        wire    [31:0]   ew_spi_word;
239
        wire    [1:0]    ew_spi_len;
240
        //
241
        wire            w_ew_wip;
242
        //
243
        writeqspi       ewproc(i_clk_200mhz, bus_wreq,bus_ereq,
244
                                        bus_pipewr, bus_endwr,
245
                                        bus_addr, bus_data,
246
                                ew_bus_ack, ew_qspi_req, ew_qspi_grant,
247
                                ew_spi_wr, ew_spi_hold, ew_spi_word, ew_spi_len,
248
                                        ew_spi_spd, ew_spi_dir,
249
                                        spi_out, spi_valid, spi_busy, spi_stopped,
250
                                ew_data_ack, w_quad, w_ew_wip);
251
 
252
        //
253
        // Control module
254
        //
255
        //      Logic to read/write status and configuration registers
256
        //
257
        // Wishbone bus return
258
        wire            ct_data_ack;
259
        wire    [31:0]   ct_data;
260
        // Arbiter interaction
261
        wire            ct_qspi_req;
262
        wire            ct_grant;
263
        // Bus controller return
264
        wire            ct_ack;
265
        // SPI control wires
266
        wire            ct_spi_wr, ct_spi_hold, ct_spi_spd, ct_spi_dir;
267
        wire    [31:0]   ct_spi_word;
268
        wire    [1:0]    ct_spi_len;
269
        //
270
        ctrlspi         ctproc(i_clk_200mhz,
271
                                bus_ctreq, bus_wr, bus_addr[2:0], bus_data, bus_sector,
272
                                ct_qspi_req, ct_grant,
273
                                ct_spi_wr, ct_spi_hold, ct_spi_word, ct_spi_len,
274
                                        ct_spi_spd, ct_spi_dir,
275
                                        spi_out, spi_valid, spi_busy, spi_stopped,
276
                                ct_ack, ct_data_ack, ct_data, w_xip, w_quad);
277
        assign  ct_spi_hold = 1'b0;
278
        assign  ct_spi_spd  = 1'b0;
279
 
280
        //
281
        // ID/OTP module
282
        //
283
        //      Access to ID and One-Time-Programmable registers, but to read
284
        //      and to program (the OTP), and to finally lock (OTP) registers.
285
        //
286
        // Wishbone bus return
287
        wire            id_data_ack;
288
        wire    [31:0]   id_data;
289
        // Arbiter interaction
290
        wire            id_qspi_req;
291
        wire            id_qspi_grant;
292
        // Bus controller return
293
        wire            id_bus_ack;
294
        // SPI control wires
295
        wire            id_spi_wr, id_spi_hold, id_spi_spd, id_spi_dir;
296
        wire    [31:0]   id_spi_word;
297
        wire    [1:0]    id_spi_len;
298
        //
299
        wire            w_id_wip;
300
        //
301
        idotpqspi       idotp(i_clk_200mhz, bus_idreq,
302
                                bus_wr, bus_pipewr, bus_addr[4:0], bus_data, id_bus_ack,
303
                                id_qspi_req, id_qspi_grant,
304
                                id_spi_wr, id_spi_hold, id_spi_word, id_spi_len,
305
                                        id_spi_spd, id_spi_dir,
306
                                        spi_out, spi_valid, spi_busy, spi_stopped,
307
                                id_data_ack, id_data, w_idloaded, w_id_wip);
308
 
309
        // Arbitrator
310
        reg             owned;
311
        reg     [1:0]    owner;
312
        initial         owned = 1'b0;
313
        always @(posedge i_clk_200mhz) // 7 inputs (spi_stopped is the CE)
314
                if ((~owned)&&(spi_stopped))
315
                begin
316
                        casez({rd_qspi_req,ew_qspi_req,id_qspi_req,ct_qspi_req})
317
                        4'b1???: begin owned<= 1'b1; owner <= 2'b00; end
318
                        4'b01??: begin owned<= 1'b1; owner <= 2'b01; end
319
                        4'b001?: begin owned<= 1'b1; owner <= 2'b10; end
320
                        4'b0001: begin owned<= 1'b1; owner <= 2'b11; end
321
                        default: begin owned<= 1'b0; owner <= 2'b00; end
322
                        endcase
323
                end else if ((owned)&&(spi_stopped))
324
                begin
325
                        casez({rd_qspi_req,ew_qspi_req,id_qspi_req,ct_qspi_req,owner})
326
                        6'b0???00: owned<= 1'b0;
327
                        6'b?0??01: owned<= 1'b0;
328
                        6'b??0?10: owned<= 1'b0;
329
                        6'b???011: owned<= 1'b0;
330
                        default: begin ; end
331
                        endcase
332
                end
333
 
334
        assign  rd_qspi_grant = (owned)&&(owner == 2'b00);
335
        assign  ew_qspi_grant = (owned)&&(owner == 2'b01);
336
        assign  id_qspi_grant = (owned)&&(owner == 2'b10);
337
        assign  ct_grant      = (owned)&&(owner == 2'b11);
338
 
339
        // Module controller
340
        always @(posedge i_clk_200mhz)
341
        case(owner)
342
        2'b00: begin
343
                spi_wr      <= (owned)&&(rd_spi_wr);
344
                spi_hold    <= rd_spi_hold;
345
                spi_word    <= rd_spi_word;
346
                spi_len     <= rd_spi_len;
347
                spi_spd     <= rd_spi_spd;
348
                spi_dir     <= rd_spi_dir;
349
                spi_recycle <= rd_spi_recycle;
350
                end
351
        2'b01: begin
352
                spi_wr      <= (owned)&&(ew_spi_wr);
353
                spi_hold    <= ew_spi_hold;
354
                spi_word    <= ew_spi_word;
355
                spi_len     <= ew_spi_len;
356
                spi_spd     <= ew_spi_spd;
357
                spi_dir     <= ew_spi_dir;
358
                spi_recycle <= 1'b1; // Long recycle time
359
                end
360
        2'b10: begin
361
                spi_wr      <= (owned)&&(id_spi_wr);
362
                spi_hold    <= id_spi_hold;
363
                spi_word    <= id_spi_word;
364
                spi_len     <= id_spi_len;
365
                spi_spd     <= id_spi_spd;
366
                spi_dir     <= id_spi_dir;
367
                spi_recycle <= 1'b1; // Long recycle time
368
                end
369
        2'b11: begin
370
                spi_wr      <= (owned)&&(ct_spi_wr);
371
                spi_hold    <= ct_spi_hold;
372
                spi_word    <= ct_spi_word;
373
                spi_len     <= ct_spi_len;
374
                spi_spd     <= ct_spi_spd;
375
                spi_dir     <= ct_spi_dir;
376
                spi_recycle <= 1'b1; // Long recycle time
377
                end
378
        endcase
379
 
380
        reg     last_wip;
381
        initial bus_wip = 1'b0;
382
        initial last_wip = 1'b0;
383
        initial o_interrupt = 1'b0;
384
        always @(posedge i_clk_200mhz)
385
        begin
386
                bus_wip <= w_ew_wip || w_id_wip;
387
                last_wip <= bus_wip;
388
                o_interrupt <= ((~bus_wip)&&(last_wip));
389
        end
390
 
391
 
392
        // Now, let's return values onto the wb bus
393
        always @(posedge i_clk_200mhz)
394
        begin
395
                // Ack our internal bus controller.  This means the command was
396
                // accepted, and the bus can go on to looking for the next 
397
                // command.  It controls the i_wb_stall line, just not the
398
                // i_wb_ack line.
399
 
400
                // Ack the wishbone with any response
401
                o_wb_ack <= (bus_wb_ack)|(rd_data_ack)|(ew_data_ack)|(id_data_ack)|(ct_data_ack);
402
                o_wb_data <= (bus_wb_ack)?bus_wb_data
403
                        : (id_data_ack) ? id_data : spi_out;
404
        end
405
 
406
        assign  o_wb_stall = bus_wb_stall;
407
        assign  bus_ack = (rd_bus_ack|ew_bus_ack|id_bus_ack|ct_ack);
408
 
409
        assign  o_dbg = {
410
                i_wb_cyc, i_wb_ctrl_stb, i_wb_data_stb, o_wb_ack, bus_ack, //5
411
                //
412
                (spi_wr)&&(~spi_busy), spi_valid, spi_word[31:25],
413
                spi_out[7:2],
414
                //
415
                o_qspi_cs_n, o_qspi_sck, o_qspi_mod,    // 4 bits
416
                o_qspi_dat, i_qspi_dat                  // 8 bits
417
                };
418
endmodule
419
 
420
module  qspibus(i_clk, i_rst, i_cyc, i_data_stb, i_ctrl_stb,
421
                i_we, i_addr, i_data,
422
                        o_wb_ack, o_wb_stall, o_wb_data,
423
                o_wr, o_addr, o_data, o_sector,
424
                o_readreq, o_piperd, o_wrreq, o_erreq, o_pipewr, o_endwr,
425
                        o_ctreq, o_idreq, o_other,
426
                i_ack, i_xip, i_quad, i_idloaded, i_wip, i_spi_stopped);
427
        //
428
        input                   i_clk, i_rst;
429
        // Wishbone bus inputs
430
        input                   i_cyc, i_data_stb, i_ctrl_stb, i_we;
431
        input           [21:0]   i_addr;
432
        input           [31:0]   i_data;
433
        // Wishbone bus outputs
434
        output  reg             o_wb_ack;
435
        output  reg             o_wb_stall;
436
        output  wire    [31:0]   o_wb_data;
437
        // Internal signals to the QSPI flash interface
438
        output  reg             o_wr;
439
        output  reg     [21:0]   o_addr;
440
        output  reg     [31:0]   o_data;
441
        output  wire    [21:0]   o_sector;
442
        output  reg             o_readreq, o_piperd, o_wrreq, o_erreq,
443
                                o_pipewr, o_endwr,
444
                                o_ctreq, o_idreq;
445
        output  wire            o_other;
446
        input                   i_ack, i_xip, i_quad, i_idloaded;
447
        input                   i_wip, i_spi_stopped;
448
 
449
 
450
        //
451
        reg     pending, lcl_wrreq, lcl_ctreq, lcl_ack, ack, wp_err, wp;
452
        reg     lcl_reg;
453
        reg     [14:0]   esector;
454
        reg     [21:0]   next_addr;
455
 
456
 
457
        reg     pipeable;
458
        reg     same_page;
459
        always @(posedge i_clk)
460
                same_page <= (i_data_stb)&&(i_we)
461
                        &&(i_addr[21:6] == o_addr[21:6])
462
                        &&(i_addr[5:0] == o_addr[5:0] + 6'h1);
463
 
464
        initial pending = 1'b0;
465
        initial o_readreq = 1'b0;
466
        initial lcl_wrreq = 1'b0;
467
        initial lcl_ctreq = 1'b0;
468
        initial o_ctreq   = 1'b0;
469
        initial o_idreq   = 1'b0;
470
 
471
        initial ack = 1'b0;
472
        always @(posedge i_clk)
473
                ack <= (i_ack)||(lcl_ack);
474
 
475
        // wire [9:0]   key;
476
        // assign       key = 10'h1be;
477
        reg     lcl_key, set_sector, ctreg_stb;
478
        initial lcl_key = 1'b0;
479
        always @(posedge i_clk)
480
                // Write protect "key" to enable the disabling of write protect
481
                lcl_key<= (i_ctrl_stb)&&(~wp)&&(i_we)&&(i_addr[5:0]==6'h00)
482
                                &&(i_data[9:0] == 10'h1be)&&(i_data[31:30]==2'b11);
483
        initial set_sector = 1'b0;
484
        always @(posedge i_clk)
485
                set_sector <= (i_ctrl_stb)&&(~o_wb_stall)
486
                                &&(i_we)&&(i_addr[5:0]==6'h00)
487
                                &&(i_data[9:0] == 10'h1be);
488
 
489
        always @(posedge i_clk)
490
                if (i_ctrl_stb)
491
                        lcl_reg <= (i_addr[3:0] == 4'h00);
492
 
493
        initial ctreg_stb = 1'b0;
494
        initial o_wb_stall = 1'b0;
495
        always @(posedge i_clk)
496
        begin // Inputs: rst, stb, stb, stall, ack, addr[4:0] -- 9
497
                if (i_rst)
498
                        o_wb_stall <= 1'b0;
499
                else
500
                        o_wb_stall <= (((i_data_stb)||(i_ctrl_stb))&&(~o_wb_stall))
501
                                ||((pending)&&(~ack));
502
 
503
                ctreg_stb <= (i_ctrl_stb)&&(~o_wb_stall)&&(i_addr[4:0]==5'h00)&&(~pending)
504
                                ||(pending)&&(ctreg_stb)&&(~lcl_ack)&&(~i_ack);
505
                if (~o_wb_stall)
506
                begin // Bus command accepted!
507
                        if ((i_data_stb)||(i_ctrl_stb))
508
                        begin
509
                                pending <= 1'b1;
510
                                o_addr <= i_addr;
511
                                o_data <= i_data;
512
                                o_wr   <= i_we;
513
                                next_addr <= i_addr + 22'h1;
514
                        end
515
 
516
                        if ((i_data_stb)&&(~i_we))
517
                                o_readreq <= 1'b1;
518
 
519
                        if ((i_data_stb)&&(i_we))
520
                                lcl_wrreq <= 1'b1;
521
                        if ((i_ctrl_stb)&&(~i_addr[4]))
522
                        begin
523
                                casez(i_addr[4:0])
524
                                5'h0: lcl_ctreq<= 1'b1;
525
                                5'h1: lcl_ctreq <= 1'b1;
526
                                5'h2: lcl_ctreq <= 1'b1;
527
                                5'h3: lcl_ctreq <= 1'b1;
528
                                5'h4: lcl_ctreq <= 1'b1;
529
                                5'h5: lcl_ctreq <= 1'b1;
530
                                5'h6: lcl_ctreq <= 1'b1;
531
                                5'h7: lcl_ctreq <= 1'b1;
532
                                5'h8: o_idreq <= 1'b1;  // ID[0]
533
                                5'h9: o_idreq <= 1'b1;  // ID[1]
534
                                5'ha: o_idreq <= 1'b1;  // ID[2]
535
                                5'hb: o_idreq <= 1'b1;  // ID[3]
536
                                5'hc: o_idreq <= 1'b1;  // ID[4]
537
                                5'hd: o_idreq <= 1'b1;  //
538
                                5'he: o_idreq <= 1'b1;
539
                                5'hf: o_idreq <= 1'b1; // Program OTP register
540
                                default: begin o_idreq <= 1'b1; end
541
                                endcase
542
                        end else if (i_ctrl_stb)
543
                                o_idreq <= 1'b1;
544
                end else if (ack)
545
                begin
546
                        pending <= 1'b0;
547
                        o_readreq <= 1'b0;
548
                        o_idreq <= 1'b0;
549
                        lcl_ctreq <= 1'b0;
550
                        lcl_wrreq <= 1'b0;
551
                end
552
 
553
                if(i_rst)
554
                begin
555
                        pending <= 1'b0;
556
                        o_readreq <= 1'b0;
557
                        o_idreq <= 1'b0;
558
                        lcl_ctreq <= 1'b0;
559
                        lcl_wrreq <= 1'b0;
560
                end
561
 
562
                if ((i_data_stb)&&(~o_wb_stall))
563
                        o_piperd <= ((~i_we)&&(~o_wb_stall)&&(pipeable)&&(i_addr == next_addr));
564
                else if ((i_ack)||(((i_ctrl_stb)||(i_data_stb))&&(~o_wb_stall)))
565
                        o_piperd <= 1'b0;
566
                if ((i_data_stb)&&(~o_wb_stall))
567
                        pipeable <= (~i_we);
568
                else if ((i_ctrl_stb)&&(~o_wb_stall))
569
                        pipeable <= 1'b0;
570
 
571
                o_pipewr <= (same_page)||(pending)&&(o_pipewr);
572
        end
573
 
574
        reg     r_other, last_wip;
575
 
576
        reg     last_pending;
577
        always @(posedge i_clk)
578
                last_pending <= pending;
579
        always @(posedge i_clk)
580
                last_wip <= i_wip;
581
        wire    new_req;
582
        assign  new_req = (pending)&&(~last_pending);
583
 
584
        initial o_wrreq   = 1'b0;
585
        initial o_erreq   = 1'b0;
586
        initial wp_err    = 1'b0;
587
        initial lcl_ack   = 1'b0;
588
        initial r_other   = 1'b0;
589
        initial o_endwr   = 1'b1;
590
        initial wp        = 1'b1;
591
        always @(posedge i_clk)
592
        begin
593
                if (i_ack)
594
                begin
595
                        o_erreq <= 1'b0;
596
                        o_wrreq <= 1'b0;
597
                        o_ctreq <= 1'b0;
598
                        r_other <= 1'b0;
599
                end
600
 
601
                if ((last_wip)&&(~i_wip))
602
                        wp <= 1'b1;
603
 
604
                // o_endwr  <= ((~i_cyc)||(~o_wr)||(o_pipewr))
605
                                // ||(~new_req)&&(o_endwr);
606
                o_endwr <= ((pending)&&(~o_pipewr))||((~pending)&&(~i_cyc));
607
 
608
                // Default ACK is always set to zero, unless the following ...
609
                o_wb_ack <= 1'b0;
610
 
611
                if (set_sector)
612
                begin
613
                        esector[13:0] <= { o_data[23:14], 4'h0 };
614
                        wp <= (o_data[30])&&(new_req)||(wp)&&(~new_req);
615
                        if (o_data[28])
616
                        begin
617
                                esector[14] <= o_data[28];
618
                                esector[3:0] <= o_data[13:10];
619
                        end
620
                end
621
 
622
                lcl_ack <= 1'b0;
623
                if ((i_wip)&&(new_req)&&(~same_page))
624
                begin
625
                        o_wb_ack <= 1'b1;
626
                        lcl_ack <= 1'b1;
627
                end else if ((ctreg_stb)&&(new_req))
628
                begin // A request of the status register
629
                        // Always ack control register, even on failed attempts
630
                        // to erase.
631
                        o_wb_ack <= 1'b1;
632
                        lcl_ack <= 1'b1;
633
 
634
                        if (lcl_key)
635
                        begin
636
                                o_ctreq <= 1'b0;
637
                                o_erreq <= 1'b1;
638
                                r_other <= 1'b1;
639
                                lcl_ack <= 1'b0;
640
                        end else if ((o_wr)&&(~o_data[31]))
641
                        begin // WEL or WEL disable
642
                                o_ctreq <= (wp == o_data[30]);
643
                                r_other <= (wp == o_data[30]);
644
                                lcl_ack <= (wp != o_data[30]);
645
                                wp <= !o_data[30];
646
                        end else if (~o_wr)
647
                                lcl_ack <= 1'b1;
648
                        wp_err <= (o_data[31])&&(~lcl_key);
649
                end else if ((lcl_ctreq)&&(new_req))
650
                begin
651
                        o_ctreq <= 1'b1;
652
                        r_other <= 1'b1;
653
                end else if ((lcl_wrreq)&&(new_req))
654
                begin
655
                        if (~wp)
656
                        begin
657
                                o_wrreq <= 1'b1;
658
                                r_other <= 1'b1;
659
                                o_endwr  <= 1'b0;
660
                                lcl_ack <= 1'b0;
661
                        end else begin
662
                                o_wb_ack <= 1'b1;
663
                                wp_err <= 1'b1;
664
                                lcl_ack <= 1'b1;
665
                        end
666
                end
667
 
668
                if (i_rst)
669
                begin
670
                        o_ctreq <= 1'b0;
671
                        o_erreq <= 1'b0;
672
                        o_wrreq <= 1'b0;
673
                        r_other <= 1'b0;
674
                end
675
 
676
        end
677
 
678
 
679
        assign o_wb_data[31:0] = { i_wip, ~wp, i_quad, esector[14],
680
                        i_idloaded, wp_err, i_xip, i_spi_stopped,
681
                        esector[13:0], 10'h00 };
682
        assign  o_sector = { esector[13:0], 8'h00 }; // 22 bits
683
        assign  o_other = (r_other)||(o_idreq);
684
 
685
endmodule
686
 
687
 
688
`define RD_IDLE                 4'h0
689
`define RD_IDLE_GET_PORT        4'h1
690
`define RD_SLOW_DUMMY           4'h2
691
`define RD_SLOW_READ_DATA       4'h3
692
`define RD_QUAD_READ_DATA       4'h4
693
`define RD_QUAD_DUMMY           4'h5
694
`define RD_QUAD_ADDRESS         4'h6
695
`define RD_XIP                  4'h7
696
`define RD_GO_TO_IDLE           4'h8
697
`define RD_GO_TO_XIP            4'h9
698
 
699
module  readqspi(i_clk, i_readreq, i_piperd, i_other_req, i_addr, o_bus_ack,
700
                o_qspi_req, i_grant,
701
                        o_spi_wr, o_spi_hold, o_spi_word, o_spi_len,
702
                                o_spi_spd, o_spi_dir, o_spi_recycle,
703
                        i_spi_data, i_spi_valid, i_spi_busy, i_spi_stopped,
704
                        o_data_ack, o_data, i_quad, i_xip);
705
        input                   i_clk;
706
        input                   i_readreq, i_piperd, i_other_req;
707
        input           [21:0]   i_addr;
708
        output  reg             o_bus_ack, o_qspi_req;
709
        input   wire            i_grant;
710
        output  reg             o_spi_wr;
711
        output  wire            o_spi_hold;
712
        output  reg     [31:0]   o_spi_word;
713
        output  reg     [1:0]    o_spi_len;
714
        output  reg             o_spi_spd, o_spi_dir, o_spi_recycle;
715
        input           [31:0]   i_spi_data;
716
        input                   i_spi_valid, i_spi_busy, i_spi_stopped;
717
        output  reg             o_data_ack;
718
        output  reg     [31:0]   o_data;
719
        input                   i_quad, i_xip;
720
 
721
        reg     accepted;
722
        initial accepted = 1'b0;
723
        always @(posedge i_clk)
724
                accepted <= (~i_spi_busy)&&(i_grant)&&(o_spi_wr)&&(~accepted);
725
 
726
        reg     [3:0]    rd_state;
727 12 dgisselq
        reg             r_leave_xip, r_xip, r_quad, r_requested, ack_valid;
728 3 dgisselq
        initial rd_state = `RD_IDLE;
729
        initial o_data_ack = 1'b0;
730
        initial o_bus_ack  = 1'b0;
731
        initial o_qspi_req = 1'b0;
732
        always @(posedge i_clk)
733
        begin
734
                o_data_ack <= 1'b0;
735
                o_bus_ack <= 1'b0;
736
                o_spi_recycle <= 1'b0;
737
                if (i_spi_valid)
738
                        o_data <= i_spi_data;
739
                case(rd_state)
740
                `RD_IDLE: begin
741 12 dgisselq
                        ack_valid <= 1'b0;
742 3 dgisselq
                        r_requested <= 1'b0;
743
                        o_qspi_req <= 1'b0;
744
                        o_spi_word <= { ((i_quad)? 8'h6B: 8'h0b), i_addr, 2'b00 };
745
                        o_spi_wr <= 1'b0;
746
                        o_spi_dir <= 1'b0;
747
                        o_spi_spd <= 1'b0;
748
                        o_spi_len <= 2'b11;
749
                        r_xip <= (i_xip)&&(i_quad);
750
                        r_leave_xip <= 1'b0; // Not in it, so can't leave it
751
                        r_quad <= i_quad;
752
                        if (i_readreq)
753
                        begin
754
                                rd_state <= `RD_IDLE_GET_PORT;
755
                                o_bus_ack <= 1'b1;
756
                        end end
757
                `RD_IDLE_GET_PORT: begin
758
                        o_spi_wr <= 1'b1; // Write the address
759
                        o_qspi_req <= 1'b1;
760 12 dgisselq
                        ack_valid <= 1'b0;
761 3 dgisselq
                        if (accepted)
762
                                rd_state <= `RD_SLOW_DUMMY;
763
                        end
764
                `RD_SLOW_DUMMY: begin
765
                        o_spi_wr <= 1'b1; // Write 8 dummy clocks
766
                        o_qspi_req <= 1'b1;
767
                        o_spi_dir <= 1'b0;
768
                        o_spi_spd <= 1'b0;
769
                        o_spi_word[31:24] <= (r_xip) ? 8'h00 : 8'hff;
770
                        o_spi_len  <= 2'b00; // 8 clocks = 8-bits
771 12 dgisselq
                        ack_valid <= 1'b0;
772 3 dgisselq
                        if (accepted)
773
                                rd_state <= (r_quad)?`RD_QUAD_READ_DATA
774
                                                : `RD_SLOW_READ_DATA;
775
                        end
776
                `RD_SLOW_READ_DATA: begin
777
                        o_qspi_req <= 1'b1;
778
                        o_spi_dir <= 1'b1;
779
                        o_spi_spd <= 1'b0;
780
                        o_spi_len <= 2'b11;
781
                        o_spi_wr <= (~r_requested)||(i_piperd);
782
                        // if (accepted)
783
                                // o_spi_wr <= (i_piperd);
784 12 dgisselq
                        o_data_ack <=  (ack_valid)&&(i_spi_valid);
785 3 dgisselq
                        o_bus_ack <=   (r_requested)&&(accepted)&&(i_piperd);
786
                        r_requested <= (r_requested)||(accepted);
787 12 dgisselq
                        ack_valid <= (accepted)?(r_requested):ack_valid;
788 3 dgisselq
                        if ((i_spi_valid)&&(~o_spi_wr))
789
                                rd_state <= `RD_GO_TO_IDLE;
790
                        end
791
                `RD_QUAD_READ_DATA: begin
792
                        o_qspi_req <= 1'b1;
793
                        o_spi_dir <= 1'b1;
794
                        o_spi_spd <= 1'b1;
795
                        o_spi_len <= 2'b11;
796
                        o_spi_recycle <= (r_leave_xip)? 1'b1: 1'b0;
797
                        r_requested <= (r_requested)||(accepted);
798 12 dgisselq
                        ack_valid <= (r_requested);
799
                        o_data_ack <= (ack_valid)&&(i_spi_valid)&&(~r_leave_xip);
800 3 dgisselq
                        o_bus_ack  <= (r_requested)&&(accepted)&&(i_piperd)&&(~r_leave_xip);
801
                        o_spi_wr <= (~r_requested)||(i_piperd);
802
                        // if (accepted)
803
                                // o_spi_wr <= (i_piperd);
804 12 dgisselq
                        if (accepted) // only happens if (o_spi_wr)
805 3 dgisselq
                                o_data <= i_spi_data;
806
                        if ((i_spi_valid)&&(~o_spi_wr))
807
                                rd_state <= ((r_leave_xip)||(~r_xip))?`RD_GO_TO_IDLE:`RD_GO_TO_XIP;
808
                        end
809
                `RD_QUAD_ADDRESS: begin
810
                        o_qspi_req <= 1'b1;
811
                        o_spi_wr <= 1'b1;
812
                        o_spi_dir <= 1'b0; // Write the address
813
                        o_spi_spd <= 1'b1; // High speed
814
                        o_spi_word[31:0] <= { i_addr, 2'b00, 8'h00 };
815
                        o_spi_len  <= 2'b10; // 24 bits, High speed, 6 clocks
816
                        if (accepted)
817
                                rd_state <= `RD_QUAD_DUMMY;
818
                        end
819
                `RD_QUAD_DUMMY: begin
820
                        o_qspi_req <= 1'b1;
821
                        o_spi_wr <= 1'b1;
822
                        o_spi_dir <= 1'b0; // Write the dummy
823
                        o_spi_spd <= 1'b1; // High speed
824
                        o_spi_word[31:0] <= (r_xip)? 32'h00 : 32'hffffffff;
825
                        o_spi_len  <= 2'b11; // 8 clocks = 32-bits, quad speed
826
                        if (accepted)
827
                                rd_state <= (r_quad)?`RD_QUAD_READ_DATA
828
                                                : `RD_SLOW_READ_DATA;
829
                        end
830
                `RD_XIP: begin
831
                        r_requested <= 1'b0;
832
                        o_qspi_req <= 1'b1;
833
                        o_spi_word <= { i_addr, 2'b00, 8'h00 };
834
                        o_spi_wr <= 1'b0;
835
                        o_spi_dir <= 1'b0; // Write to SPI
836
                        o_spi_spd <= 1'b1; // High speed
837
                        o_spi_len <= 2'b11;
838
                        r_leave_xip <= i_other_req;
839
                        r_xip <= (~i_other_req);
840
                        o_bus_ack <= 1'b0;
841
                        if ((i_readreq)||(i_other_req))
842
                        begin
843
                                rd_state <= `RD_QUAD_ADDRESS;
844
                                o_bus_ack <= i_readreq;
845
                        end end
846
                `RD_GO_TO_IDLE: begin
847 12 dgisselq
                        r_requested <= 1'b0;
848
                        ack_valid <= 1'b0;
849
                        o_spi_wr   <= 1'b0;
850 3 dgisselq
                        o_qspi_req <= 1'b0;
851
                        if ((i_spi_stopped)&&(~i_grant))
852
                                rd_state <= `RD_IDLE;
853
                        end
854
                `RD_GO_TO_XIP: begin
855 12 dgisselq
                        r_requested <= 1'b0;
856
                        ack_valid <= 1'b0;
857 3 dgisselq
                        o_qspi_req <= 1'b1;
858
                        o_spi_wr   <= 1'b0;
859
                        if (i_spi_stopped)
860
                                rd_state <= `RD_XIP;
861
                        end
862
                default: begin
863
                        // rd_state <= (i_grant)?`RD_BREAK;
864
                        o_qspi_req <= 1'b0;
865
                        o_spi_wr <= 1'b0;
866
                        if ((i_spi_stopped)&&(~i_grant))
867
                                rd_state <= `RD_IDLE;
868
                        end
869
                endcase
870
        end
871
 
872
        assign  o_spi_hold = 1'b0;
873
 
874
endmodule
875
 
876
module  writeqspi(i_clk, i_wreq, i_ereq, i_pipewr, i_endpipe, i_addr, i_data,
877
                        o_bus_ack, o_qspi_req, i_qspi_grant,
878
                                o_spi_wr, o_spi_hold, o_spi_word, o_spi_len,
879
                                o_spi_spd, o_spi_dir, i_spi_data, i_spi_valid,
880
                                        i_spi_busy, i_spi_stopped,
881
                                o_data_ack, i_quad, o_wip);
882
        input           i_clk;
883
        //
884
        input           i_wreq, i_ereq, i_pipewr, i_endpipe;
885
        input           [21:0]   i_addr;
886
        input           [31:0]   i_data;
887
        output  reg             o_bus_ack, o_qspi_req;
888
        input                   i_qspi_grant;
889
        output  reg             o_spi_wr, o_spi_hold;
890
        output  reg     [31:0]   o_spi_word;
891
        output  reg     [1:0]    o_spi_len;
892
        output  reg             o_spi_spd, o_spi_dir;
893
        input           [31:0]   i_spi_data;
894
        input                   i_spi_valid;
895
        input                   i_spi_busy, i_spi_stopped;
896
        output  reg             o_data_ack;
897
        input                   i_quad;
898
        output  reg             o_wip;
899
 
900
`ifdef  QSPI_READ_ONLY
901
        always @(posedge i_clk)
902
                o_data_ack <= (i_wreq)||(i_ereq);
903
        always @(posedge i_clk)
904
                o_bus_ack <= (i_wreq)||(i_ereq);
905
 
906
        always @(posedge i_clk)
907
        begin
908
                o_qspi_req <= 1'b0;
909
                o_spi_wr   <= 1'b0;
910
                o_spi_hold <= 1'b0;
911
                o_spi_dir  <= 1'b1; // Read
912
                o_spi_spd  <= i_quad;
913
                o_spi_len  <= 2'b00;
914
                o_spi_word <= 32'h00;
915
                o_wip <= 1'b0;
916
        end
917
`else
918
 
919
`define WR_IDLE                         4'h0
920
`define WR_START_WRITE                  4'h1
921
`define WR_START_QWRITE                 4'h2
922
`define WR_PROGRAM                      4'h3
923
`define WR_PROGRAM_GETNEXT              4'h4
924
`define WR_START_ERASE                  4'h5
925
`define WR_WAIT_ON_STOP                 4'h6
926
`define WR_REQUEST_STATUS               4'h7
927
`define WR_REQUEST_STATUS_NEXT          4'h8
928
`define WR_READ_STATUS                  4'h9
929
`define WR_WAIT_ON_FINAL_STOP           4'ha
930
 
931
        reg     accepted;
932
        initial accepted = 1'b0;
933
        always @(posedge i_clk)
934
                accepted <= (~i_spi_busy)&&(i_qspi_grant)&&(o_spi_wr)&&(~accepted);
935
 
936
 
937 12 dgisselq
        reg             cyc, chk_wip, valid_status;
938 3 dgisselq
        reg     [3:0]    wr_state;
939
        initial wr_state = `WR_IDLE;
940
        initial cyc = 1'b0;
941
        always @(posedge i_clk)
942
        begin
943
                chk_wip <= 1'b0;
944
                o_bus_ack  <= 1'b0;
945
                o_data_ack <= 1'b0;
946
                cyc <= (cyc)&&(~i_endpipe);
947
                case(wr_state)
948
                `WR_IDLE: begin
949 12 dgisselq
                        valid_status <= 1'b0;
950 3 dgisselq
                        o_qspi_req <= 1'b0;
951
                        cyc <= 1'b0;
952
                        if (i_ereq)
953
                                wr_state <= `WR_START_ERASE;
954
                        else if (i_wreq)
955
                                wr_state <= (i_quad)?`WR_START_QWRITE
956
                                        : `WR_START_WRITE;
957
                        end
958
                `WR_START_WRITE: begin
959
                        o_wip      <= 1'b1;
960
                        o_qspi_req <= 1'b1;
961
                        o_spi_wr   <= 1'b1;
962
                        o_spi_dir  <= 1'b0;
963
                        o_spi_len  <= 2'b11;
964
                        o_spi_spd  <= 1'b0;
965
                        o_spi_hold <= 1'b1;
966
                        o_spi_word <= { 8'h02, i_addr, 2'b00 };
967
                        cyc <= 1'b1;
968
                        if (accepted)
969
                        begin
970
                                o_bus_ack  <= 1'b1;
971
                                o_data_ack <= 1'b1;
972
                                wr_state <= `WR_PROGRAM;
973
                                o_spi_word <= i_data;
974
                        end end
975
                `WR_START_QWRITE: begin
976
                        o_wip      <= 1'b1;
977
                        o_qspi_req <= 1'b1;
978
                        o_spi_wr   <= 1'b1;
979
                        o_spi_dir  <= 1'b0;
980
                        o_spi_len  <= 2'b11;
981
                        o_spi_spd  <= 1'b0;
982
                        o_spi_hold <= 1'b1;
983
                        o_spi_word <= { 8'h32, i_addr, 2'b00 };
984
                        cyc <= 1'b1;
985
                        if (accepted)
986
                        begin
987
                                o_bus_ack  <= 1'b1;
988
                                o_data_ack <= 1'b1;
989
                                wr_state <= `WR_PROGRAM;
990
                                o_spi_word <= i_data;
991
                        end end
992
                `WR_PROGRAM: begin
993
                        o_wip     <= 1'b1;
994
                        o_qspi_req <= 1'b1;
995
                        o_spi_wr   <= 1'b1;
996
                        o_spi_dir  <= 1'b0;
997
                        o_spi_len  <= 2'b11;
998
                        o_spi_spd  <= i_quad;
999
                        o_spi_hold <= 1'b1;
1000
                        // o_spi_word <= i_data;
1001
                        if (accepted)
1002
                                wr_state <= `WR_PROGRAM_GETNEXT;
1003
                        end
1004
                `WR_PROGRAM_GETNEXT: begin
1005
                        o_wip      <= 1'b1;
1006
                        o_qspi_req <= 1'b1;
1007
                        o_spi_wr   <= 1'b0;
1008
                        o_spi_dir  <= 1'b0;
1009
                        o_spi_len  <= 2'b11;
1010
                        o_spi_spd  <= i_quad;
1011
                        o_spi_hold <= 1'b1;
1012
                        o_spi_word <= i_data;
1013
                        if (~cyc)
1014
                                wr_state <= `WR_WAIT_ON_STOP;
1015
                        else if (i_pipewr)
1016
                        begin
1017
                                o_bus_ack  <= 1'b1;
1018
                                o_data_ack <= 1'b1;
1019
                                wr_state <= `WR_PROGRAM;
1020
                        end end
1021
                `WR_START_ERASE: begin
1022
                        o_wip <= 1'b1;
1023
                        o_qspi_req <= 1'b1;
1024
                        o_spi_wr  <= 1'b1;
1025
                        o_spi_dir <= 1'b0;
1026
                        o_spi_spd <= 1'b0;
1027
                        o_spi_len <= 2'b11;
1028
                        if (i_data[28])
1029
                                // Subsector erase
1030
                                o_spi_word[31:24] <= 8'h20;
1031
                        else
1032
                                // Sector erase
1033
                                o_spi_word[31:24] <= 8'hd8;
1034
                        o_spi_word[23:0] <= { i_data[21:10], 12'h0 };
1035
                        // Data has already been ack'd, so no need to ack
1036
                        // it again.  However, we can now free the QSPI
1037
                        // bus processor to accept another command from the
1038
                        // bus.
1039
                        o_bus_ack <= accepted;
1040
                        if (accepted)
1041
                                wr_state <= `WR_WAIT_ON_STOP;
1042
                        end
1043
                `WR_WAIT_ON_STOP: begin
1044
                        o_wip <= 1'b1;
1045
                        o_qspi_req <= 1'b0;
1046
                        o_spi_wr   <= 1'b0;
1047
                        o_spi_hold <= 1'b0;
1048
                        if (i_spi_stopped)
1049
                                wr_state <= `WR_REQUEST_STATUS;
1050
                        end
1051
                `WR_REQUEST_STATUS: begin
1052
                        o_wip <= 1'b1;
1053
                        o_qspi_req <= 1'b1;
1054
                        o_spi_hold <= 1'b0;
1055
                        o_spi_wr   <= 1'b1;
1056
                        o_spi_spd  <= 1'b0; // Slow speed
1057
                        o_spi_len  <= 2'b00; // 8 bytes
1058
                        o_spi_dir  <= 1'b0; // Write
1059
                        o_spi_word <= { 8'h05, 24'h00 };
1060
                        if (accepted)
1061
                                wr_state <= `WR_REQUEST_STATUS_NEXT;
1062
                        end
1063
                `WR_REQUEST_STATUS_NEXT: begin
1064
                        o_wip <= 1'b1;
1065
                        o_qspi_req <= 1'b1;
1066
                        o_spi_hold <= 1'b0;
1067
                        o_spi_wr   <= 1'b1;
1068
                        o_spi_spd  <= 1'b0; // Slow speed
1069
                        o_spi_len  <= 2'b00; // 8 bytes
1070
                        o_spi_dir  <= 1'b1; // Read
1071
                        o_spi_word <= 32'h00;
1072
                        if (accepted)
1073
                                wr_state <= `WR_READ_STATUS;
1074 12 dgisselq
                        valid_status <= 1'b0;
1075 3 dgisselq
                        end
1076
                `WR_READ_STATUS: begin
1077
                        o_wip <= 1'b1;
1078
                        o_qspi_req <= 1'b1;
1079
                        o_spi_hold <= 1'b0;
1080
                        o_spi_wr   <= 1'b1;
1081
                        o_spi_spd  <= 1'b0; // Slow speed
1082
                        o_spi_len  <= 2'b00; // 8 bytes
1083
                        o_spi_dir  <= 1'b1; // Read
1084
                        o_spi_word <= 32'h00;
1085
                        if (i_spi_valid)
1086 12 dgisselq
                                valid_status <= 1'b1;
1087
                        if ((i_spi_valid)&&(valid_status))
1088 3 dgisselq
                                chk_wip <= 1'b1;
1089
                        if ((chk_wip)&&(~i_spi_data[0]))
1090
                                wr_state <= `WR_WAIT_ON_FINAL_STOP;
1091
                        end
1092
                // `WR_WAIT_ON_FINAL_STOP: // Same as the default
1093
                default: begin
1094
                        o_qspi_req <= 1'b0;
1095
                        o_spi_wr <= 1'b0;
1096
                        o_wip <= 1'b0;
1097
                        if (i_spi_stopped)
1098
                                wr_state <= `WR_IDLE;
1099
                        end
1100
                endcase
1101
        end
1102
`endif
1103
 
1104
endmodule
1105
 
1106
 
1107
`define CT_SAFE
1108
`define CT_IDLE                 3'h0
1109
`define CT_NEXT                 3'h1
1110
`define CT_GRANTED              3'h2
1111
`define CT_DATA                 3'h3
1112
`define CT_READ_DATA            3'h4
1113
`define CT_WAIT_FOR_IDLE        3'h5
1114
 
1115
// CTRL commands:
1116
//      WEL (write-enable latch)
1117
//      Read Status
1118
module  ctrlspi(i_clk, i_req, i_wr, i_addr, i_data, i_sector_address,
1119
                                o_spi_req, i_grant,
1120
                                o_spi_wr, o_spi_hold, o_spi_word, o_spi_len,
1121
                                        o_spi_spd, o_spi_dir,
1122
                                i_spi_data, i_spi_valid, i_spi_busy,
1123
                                        i_spi_stopped,
1124
                                o_bus_ack, o_data_ack, o_data, o_xip, o_quad);
1125
        input           i_clk;
1126
        // From the WB bus controller
1127
        input                   i_req;
1128
        input                   i_wr;
1129
        input           [2:0]    i_addr;
1130
        input           [31:0]   i_data;
1131
        input           [21:0]   i_sector_address;
1132
        // To/from the arbiter
1133
        output  reg             o_spi_req;
1134
        input                   i_grant;
1135
        // To/from the low-level SPI driver
1136
        output  reg             o_spi_wr;
1137
        output  wire            o_spi_hold;
1138
        output  reg     [31:0]   o_spi_word;
1139
        output  reg     [1:0]    o_spi_len;
1140
        output  wire            o_spi_spd;
1141
        output  reg             o_spi_dir;
1142
        input           [31:0]   i_spi_data;
1143
        input                   i_spi_valid;
1144
        input                   i_spi_busy, i_spi_stopped;
1145
        // Return data to the bus controller, and the wishbone bus
1146
        output  reg             o_bus_ack, o_data_ack;
1147
        output  reg     [31:0]   o_data;
1148
        // Configuration items that we may have configured.
1149
        output  reg             o_xip;
1150
        output  wire            o_quad;
1151
 
1152
        // Command registers
1153
        reg     [1:0]    ctcmd_len;
1154
        reg     [31:0]   ctcmd_word;
1155
        // Data stage registers
1156
        reg             ctdat_skip, // Skip the data phase?
1157
                        ctdat_wr;       // Write during data? (or not read)
1158
        wire    [1:0]    ctdat_len;
1159
        reg     [31:0]   ctdat_word;
1160
 
1161
        reg     [2:0]    ctstate;
1162
        reg             accepted;
1163
 
1164
 
1165
        initial accepted = 1'b0;
1166
        always @(posedge i_clk)
1167
                accepted <= (~i_spi_busy)&&(i_grant)&&(o_spi_wr)&&(~accepted);
1168
 
1169 12 dgisselq
        reg     r_ctdat_len, ctbus_ack, first_valid;
1170 3 dgisselq
        assign  ctdat_len = { 1'b0, r_ctdat_len };
1171
 
1172
        // First step, calculate the values for our state machine
1173
        initial o_xip = 1'b0;
1174
        // initial o_quad = 1'b0;
1175
        always @(posedge i_clk)
1176
        if (i_req) // A request for us to act from the bus controller
1177
        begin
1178
                ctdat_skip <= 1'b0;
1179
                ctbus_ack  <= 1'b1;
1180
                ctcmd_word[23:0] <= { i_sector_address, 2'b00 };
1181
                ctdat_word <= { i_data[7:0], 24'h00 };
1182
                ctcmd_len <= 2'b00; // 8bit command (for all but Lock regs)
1183
                r_ctdat_len <= 1'b0; // 8bit data (read or write)
1184
                ctdat_wr <= i_wr;
1185
                casez({ i_addr[2:0], i_wr, i_data[30] })
1186
                5'b00010: begin // Write Disable
1187
                        ctcmd_word[31:24] <= 8'h04;
1188
                        ctdat_skip <= 1'b1;
1189
                        ctbus_ack  <= 1'b0;
1190
                        end
1191
                5'b00011: begin // Write enable
1192
                        ctcmd_word[31:24] <= 8'h06;
1193
                        ctdat_skip <= 1'b1;
1194
                        ctbus_ack  <= 1'b0;
1195
                        end
1196
                // 4'b0010?: begin // Read Status register
1197
                //      Moved to defaults section
1198
                5'b0011?: begin // Write Status register (Requires WEL)
1199
                        ctcmd_word[31:24] <= 8'h01;
1200
`ifdef  CT_SAFE
1201
                        ctdat_word <= { 6'h00, i_data[1:0], 24'h00 };
1202
`else
1203
                        ctdat_word <= { i_data[7:0], 24'h00 };
1204
`endif
1205
                        end
1206
                5'b0100?: begin // Read NV-Config register (two bytes)
1207
                        ctcmd_word[31:24] <= 8'hB5;
1208
                        r_ctdat_len <= 1'b1; // 16-bit data
1209
                        end
1210
                5'b0101?: begin // Write NV-Config reg (2 bytes, Requires WEL)
1211
                        ctcmd_word[31:24] <= 8'hB1;
1212
                        r_ctdat_len <= 1'b1; // 16-bit data
1213
`ifdef  CT_SAFE
1214
                        ctdat_word <= { 4'h8, 3'h7, 3'h7, i_data[5:1], 1'b1, 16'h00 };
1215
`else
1216
                        ctdat_word <= { i_data[15:0], 16'h00 };
1217
`endif
1218
                        end
1219
                5'b0110?: begin // Read V-Config register
1220
                        ctcmd_word[31:24] <= 8'h85;
1221
                        end
1222
                5'b0111?: begin // Write V-Config register (Requires WEL)
1223
                        ctcmd_word[31:24] <= 8'h81;
1224
                        r_ctdat_len <= 1'b0; // 8-bit data
1225
`ifdef  CT_SAFE
1226
                        ctdat_word <= { 4'h8, i_data[3:2], 2'b11, 24'h00 };
1227
`else
1228
                        ctdat_word <= { i_data[7:0], 24'h00 };
1229
`endif
1230
                        o_xip <= i_data[3];
1231
                        end
1232
                5'b1000?: begin // Read EV-Config register
1233
                        ctcmd_word[31:24] <= 8'h65;
1234
                        end
1235
                5'b1001?: begin // Write EV-Config register (Requires WEL)
1236
                        ctcmd_word[31:24] <= 8'h61;
1237
                        // o_quad <= (~i_data[7]);
1238
`ifdef  CT_SAFE
1239
                        ctdat_word <= { 1'b1, 3'h5, 4'hf, 24'h00 };
1240
`else
1241
                        ctdat_word <= { i_data[7:0], 24'h00 };
1242
`endif
1243
                        end
1244
                5'b1010?: begin // Read Lock register
1245
                        ctcmd_word[31:0] <= { 8'he8,  i_sector_address, 2'b00 };
1246
                        ctcmd_len <= 2'b11;
1247
                        ctdat_wr  <= 1'b0;  // Read, not write
1248
                        end
1249
                5'b1011?: begin // Write Lock register (Requires WEL)
1250
                        ctcmd_word[31:0] <= { 8'he5, i_sector_address, 2'b00 };
1251
                        ctcmd_len <= 2'b11;
1252
                        ctdat_wr  <= 1'b1;  // Write
1253
                        end
1254
                5'b1100?: begin // Read Flag Status register
1255
                        ctcmd_word[31:24] <= 8'h70;
1256
                        ctdat_wr  <= 1'b0;  // Read, not write
1257
                        end
1258
                5'b1101?: begin // Write/Clear Flag Status register (No WEL required)
1259
                        ctcmd_word[31:24] <= 8'h50;
1260
                        ctdat_skip <= 1'b1;
1261
                        end
1262
                default: begin // Default to reading the status register
1263
                        ctcmd_word[31:24] <= 8'h05;
1264
                        ctdat_wr  <= 1'b0;  // Read, not write
1265
                        r_ctdat_len <= 1'b0; // 8-bit data
1266
                        end
1267
                endcase
1268
        end
1269
 
1270
        assign  o_quad = 1'b1;
1271
 
1272
        reg     nxt_data_ack;
1273
 
1274
        // Second step, actually drive the state machine
1275
        initial ctstate = `CT_IDLE;
1276
        always @(posedge i_clk)
1277
        begin
1278
                o_spi_wr <= 1'b1;
1279
                o_bus_ack <= 1'b0;
1280
                o_data_ack <= 1'b0;
1281
                if (i_spi_valid)
1282
                        o_data <= i_spi_data;
1283
                case(ctstate)
1284
                `CT_IDLE: begin
1285
                        o_spi_req <= 1'b0;
1286
                        o_spi_wr  <= 1'b0;
1287
                        if (i_req) // Need a clock to let the digestion
1288
                                ctstate <= `CT_NEXT; // process complete
1289
                        end
1290
                `CT_NEXT: begin
1291
                        o_spi_wr <= 1'b1;
1292
                        o_spi_req <= 1'b1;
1293
                        o_spi_word <= ctcmd_word;
1294
                        o_spi_len <= ctcmd_len;
1295
                        o_spi_dir <= 1'b0; // Write
1296
                        if (accepted)
1297
                        begin
1298
                                ctstate <= (ctdat_skip)?`CT_WAIT_FOR_IDLE:`CT_DATA;
1299
                                o_bus_ack <= (ctdat_skip);
1300
                                o_data_ack <= (ctdat_skip)&&(ctbus_ack);
1301
                        end end
1302
                `CT_GRANTED: begin
1303
                        o_spi_wr <= 1'b1;
1304
                        if ((accepted)&&(ctdat_skip))
1305
                                ctstate <= `CT_WAIT_FOR_IDLE;
1306
                        else if (accepted)//&&(~ctdat_skip)
1307
                                ctstate <= `CT_DATA;
1308
                        end
1309
                `CT_DATA: begin
1310
                        o_spi_wr   <= 1'b1;
1311
                        o_spi_len  <= ctdat_len;
1312
                        o_spi_dir  <= ~ctdat_wr;
1313
                        o_spi_word <= ctdat_word;
1314
                        if (accepted)
1315
                                o_bus_ack <= 1'b1;
1316
                        if (accepted)
1317
                                ctstate <= (ctdat_wr)?`CT_WAIT_FOR_IDLE:`CT_READ_DATA;
1318
                        if ((accepted)&&(ctdat_wr))
1319
                                o_data_ack <= 1'b1;
1320 12 dgisselq
                        first_valid <= 1'b0;
1321 3 dgisselq
                        end
1322
                `CT_READ_DATA: begin
1323
                        o_spi_wr <= 1'b0; // No more words to go, just to wait
1324
                        o_spi_req <= 1'b1;
1325 12 dgisselq
                        if (i_spi_valid)
1326
                                first_valid <= 1'b1;
1327
                        if ((i_spi_valid)&&(first_valid)) // for a value to read
1328 3 dgisselq
                        begin
1329
                                o_data_ack <= 1'b1;
1330
                                o_data <= i_spi_data;
1331
                                ctstate <= `CT_WAIT_FOR_IDLE;
1332
                        end end
1333
                default: begin // `CT_WAIT_FOR_IDLE
1334
                        o_spi_wr <= 1'b0;
1335
                        o_spi_req <= 1'b0;
1336
                        if (i_spi_stopped)
1337
                                ctstate <= `CT_IDLE;
1338
                        end
1339
                endcase
1340
        end
1341
 
1342
        // All of this is done in straight SPI mode, so our speed will always be zero
1343
        assign  o_spi_hold = 1'b0;
1344
        assign  o_spi_spd  = 1'b0;
1345
 
1346
endmodule
1347
 
1348
`define ID_IDLE                         5'h00
1349
`define ID_WAIT_ON_START_ID             5'h01
1350
`define ID_WAIT_ON_START_OTP            5'h02
1351
`define ID_WAIT_ON_START_OTP_WRITE      5'h03
1352
`define ID_READ_DATA_COMMAND            5'h04
1353
`define ID_GET_DATA                     5'h05
1354
`define ID_LOADED                       5'h06
1355
`define ID_LOADED_NEXT                  5'h07
1356
`define ID_OTP_SEND_DUMMY               5'h08
1357
`define ID_OTP_CLEAR                    5'h09
1358
`define ID_OTP_GET_DATA                 5'h0a
1359
`define ID_OTP_WRITE                    5'h0b
1360
`define ID_WAIT_ON_STOP                 5'h0c
1361
`define ID_REQ_STATUS                   5'h0d
1362
`define ID_REQ_STATUS_NEXT              5'h0e
1363
`define ID_READ_STATUS                  5'h0f
1364
//
1365
`define ID_FINAL_STOP                   5'h10
1366
 
1367
module  idotpqspi(i_clk, i_req, i_wr, i_pipewr, i_addr, i_data, o_bus_ack,
1368
                o_qspi_req, i_qspi_grant,
1369
                o_spi_wr, o_spi_hold, o_spi_word, o_spi_len,
1370
                o_spi_spd, o_spi_dir, i_spi_data, i_spi_valid,
1371
                i_spi_busy, i_spi_stopped, o_data_ack, o_data, o_loaded,
1372
                o_wip);
1373
        input                   i_clk;
1374
        input                   i_req, i_wr, i_pipewr;
1375
        input           [4:0]    i_addr;
1376
        input           [31:0]   i_data;
1377
        output  reg             o_bus_ack, o_qspi_req;
1378
        input                   i_qspi_grant;
1379
        output  reg             o_spi_wr, o_spi_hold;
1380
        output  reg     [31:0]   o_spi_word;
1381
        output  reg     [1:0]    o_spi_len;
1382
        output  wire            o_spi_spd;
1383
        output  reg             o_spi_dir;
1384
        input           [31:0]   i_spi_data;
1385
        input                   i_spi_valid, i_spi_busy, i_spi_stopped;
1386
        output  reg             o_data_ack;
1387
        output  reg     [31:0]   o_data;
1388
        output  wire            o_loaded;
1389
        output  reg             o_wip;
1390
 
1391
        reg     id_loaded;
1392
        initial id_loaded = 1'b0;
1393
        assign  o_loaded= id_loaded;
1394
 
1395
/*
1396
        // Only the ID register will be kept in memory, OTP will be read
1397
        // or written upon request
1398
        always @(posedge i_clk)
1399
                if (i_addr[4])
1400
                        o_data <= otpmem[i_addr[3:0]];
1401
                else
1402
                        o_data <= idmem[i_addr[2:0]];
1403
 
1404
        always @(posedge i_clk)
1405
                if ((otp_loaded)&&(i_req)&&(i_addr[4]))
1406
                        o_data_ack <= 1'b1;
1407
                else if ((id_loaded)&&(i_req)&&(~i_addr[4]))
1408
                        o_data_ack <= idmem[i_addr[2:0]];
1409
                else
1410
                        o_data_ack <= 1'b0;
1411
*/
1412
 
1413
        reg     otp_read_request, id_read_request, accepted, otp_wr_request,
1414
                id_read_device, last_id_read;
1415
        reg     [4:0]    req_addr;
1416
        reg     [2:0]    lcl_id_addr;
1417
        reg     [4:0]    id_state;
1418
        always @(posedge i_clk)
1419
        begin
1420
                otp_read_request <= (i_req)&&(~i_wr)&&((i_addr[4])||(i_addr[3:0]==4'hf));
1421
                last_id_read     <= (i_req)&&(~i_addr[4])&&(i_addr[3:0]!=4'hf);
1422
                id_read_request  <= (i_req)&&(~i_addr[4])&&(i_addr[3:0]!=4'hf)&&(~last_id_read);
1423
                id_read_device   <= (i_req)&&(~i_addr[4])&&(i_addr[3:0]!=4'hf)&&(~id_loaded);
1424
                accepted <= (~i_spi_busy)&&(i_qspi_grant)&&(o_spi_wr)&&(~accepted);
1425
 
1426
                otp_wr_request <= (i_req)&&(i_wr)&&((i_addr[4])||(i_addr[3:0]==4'hf));
1427
 
1428
                if (id_state == `ID_IDLE)
1429
                        req_addr <= (i_addr[4:0]==5'h0f) ? 5'h10
1430
                                : { 1'b0, i_addr[3:0] };
1431
        end
1432
 
1433
        reg     last_addr;
1434
        always @(posedge i_clk)
1435
                last_addr <= (lcl_id_addr >= 3'h4);
1436
 
1437
        reg     [31:0]   idmem[0:5];
1438
        reg     [31:0]   r_data;
1439
 
1440
        // Now, quickly, let's deal with the fact that the data from the
1441
        // bus comes one clock later ...
1442
        reg     nxt_data_ack, nxt_data_spi;
1443
        reg     [31:0]   nxt_data;
1444
 
1445 12 dgisselq
        reg     set_val, chk_wip, first_valid, valid_status;
1446 3 dgisselq
        reg     [2:0]    set_addr;
1447
 
1448
        always @(posedge i_clk)
1449
        begin // Depends upon state[4], otp_rd, otp_wr, otp_pipe, id_req, accepted, last_addr
1450
                o_bus_ack <= 1'b0;
1451
                // o_data_ack <= 1'b0;
1452
                o_spi_hold <= 1'b0;
1453
                nxt_data_ack <= 1'b0;
1454
                nxt_data_spi <= 1'b0;
1455
                chk_wip      <= 1'b0;
1456
                set_val <= 1'b0;
1457
                if ((id_loaded)&&(id_read_request))
1458
                begin
1459
                        nxt_data_ack <= 1'b1;
1460
                        o_bus_ack  <= 1'b1;
1461
                end
1462
                nxt_data <= idmem[i_addr[2:0]];
1463
                o_spi_wr <= 1'b0; // By default, we send nothing
1464
                case(id_state)
1465
                `ID_IDLE: begin
1466
                        o_qspi_req <= 1'b0;
1467
                        o_spi_dir <= 1'b0; // Write to SPI
1468
                        lcl_id_addr <= 3'h0;
1469
                        o_spi_word[23:7] <= 17'h00;
1470
                        o_spi_word[6:0] <= { req_addr[4:0], 2'b00 };
1471
                        r_data <= i_data;
1472
                        o_wip <= 1'b0;
1473 12 dgisselq
                        first_valid <= 1'b0;
1474 3 dgisselq
                        if (otp_read_request)
1475
                        begin
1476
                                // o_spi_word <= { 8'h48, 8'h00, 8'h00, 8'h00 };
1477
                                id_state <= `ID_WAIT_ON_START_OTP;
1478
                                o_bus_ack <= 1'b1;
1479
                        end else if (otp_wr_request)
1480
                        begin
1481
                                o_bus_ack <= 1'b1;
1482
                                // o_data_ack <= 1'b1;
1483
                                nxt_data_ack <= 1'b1;
1484
                                id_state <= `ID_WAIT_ON_START_OTP_WRITE;
1485
                        end else if (id_read_device)
1486
                        begin
1487
                                id_state <= `ID_WAIT_ON_START_ID;
1488
                                o_bus_ack <= 1'b0;
1489
                                o_spi_word[31:24] <= 8'h9f;
1490
                        end end
1491
                `ID_WAIT_ON_START_ID: begin
1492
                        o_spi_wr <= 1'b1;
1493
                        o_qspi_req <= 1'b1;
1494
                        o_spi_len <= 2'b0; // 8 bits
1495
                        if (accepted)
1496
                                id_state <= `ID_READ_DATA_COMMAND;
1497
                        end
1498
                `ID_WAIT_ON_START_OTP: begin
1499
                        o_spi_wr <= 1'b1;
1500
                        o_spi_word[31:24] <= 8'h4B;
1501
                        o_qspi_req <= 1'b1;
1502
                        o_spi_len <= 2'b11; // 32 bits
1503
                        o_spi_word[6:0] <= { req_addr[4:0], 2'b00 };
1504
                        if (accepted) // Read OTP command was just sent
1505
                                id_state <= `ID_OTP_SEND_DUMMY;
1506
                        end
1507
                `ID_WAIT_ON_START_OTP_WRITE: begin
1508
                        o_spi_wr <= 1'b1;
1509
                        o_qspi_req <= 1'b1;
1510
                        o_wip <= 1'b1;
1511
                        o_spi_len <= 2'b11; // 32 bits
1512
                        o_spi_word[31:24] <= 8'h42;
1513
                        if (accepted) // Read OTP command was just sent
1514
                                id_state <= `ID_OTP_WRITE;
1515
                        end
1516
                `ID_READ_DATA_COMMAND: begin
1517
                        o_spi_len <= 2'b11; // 32-bits
1518 12 dgisselq
                        o_spi_wr <= 1'b1; // Still transmitting
1519 3 dgisselq
                        o_spi_dir <= 1'b1; // Read from SPI
1520
                        o_qspi_req <= 1'b1;
1521
                        if (accepted)
1522
                                id_state <= `ID_GET_DATA;
1523 12 dgisselq
                        first_valid <= 1'b0;
1524 3 dgisselq
                        end
1525
                `ID_GET_DATA: begin
1526
                        o_spi_len <= 2'b11; // 32-bits
1527
                        o_spi_wr <= (~last_addr); // Still transmitting
1528
                        o_spi_dir <= 1'b1; // Read from SPI
1529
                        o_qspi_req <= 1'b1;
1530 12 dgisselq
                        if (i_spi_valid) // two clocks after accepted
1531
                                first_valid <= 1'b1;
1532
                        if((i_spi_valid)&&(first_valid))
1533 3 dgisselq
                        begin
1534
                                set_val <= 1'b1;
1535
                                set_addr <= lcl_id_addr[2:0];
1536
                                // idmem[lcl_id_addr[2:0]] <= i_spi_data;
1537
                                lcl_id_addr <= lcl_id_addr + 3'h1;
1538
                                if (last_addr)
1539
                                        id_state <= `ID_LOADED;
1540
                        end end
1541
                `ID_LOADED: begin
1542
                        id_loaded <= 1'b1;
1543
                        o_bus_ack  <= 1'b1;
1544
                        o_spi_wr   <= 1'b0;
1545
                        nxt_data_ack <= 1'b1;
1546
                        id_state   <= `ID_LOADED_NEXT;
1547
                        end
1548
                `ID_LOADED_NEXT: begin
1549
                        o_spi_len <= 2'b11; // 32-bits
1550
                        o_bus_ack  <= 1'b0;
1551
                        o_spi_wr   <= 1'b0;
1552
                        nxt_data_ack <= 1'b1;
1553
                        id_state   <= `ID_IDLE;
1554
                        end
1555
                `ID_OTP_SEND_DUMMY: begin
1556
                        o_spi_len <= 2'b00; // 1 byte
1557
                        o_spi_wr  <= 1'b1; // Still writing
1558
                        o_spi_dir <= 1'b0; // Write to SPI
1559
                        if (accepted) // Wait for the command to be accepted
1560
                                id_state <= `ID_OTP_CLEAR;
1561
                        end
1562
                `ID_OTP_CLEAR: begin
1563
                        o_spi_wr  <= 1'b1; // Still writing
1564
                        o_spi_dir <= 1'b1; // Read from SPI
1565 12 dgisselq
                        o_spi_len <= 2'b11; // Read 32 bits
1566 3 dgisselq
                        if (accepted)
1567
                                id_state <= `ID_OTP_GET_DATA;
1568
                        end
1569
                `ID_OTP_GET_DATA: begin
1570
                        if (i_spi_valid)
1571 12 dgisselq
                                first_valid <= 1'b1;
1572
                        if ((i_spi_valid)&&(first_valid))
1573 3 dgisselq
                        begin
1574
                                id_state <= `ID_FINAL_STOP;
1575
                                nxt_data_ack <= 1'b1;
1576
                                nxt_data_spi <= 1'b1;
1577
                        end end
1578
                `ID_OTP_WRITE: begin
1579
                        o_spi_wr  <= 1'b1;
1580
                        o_spi_len <= 2'b11;
1581
                        o_spi_dir <= 1'b0; // Write to SPI
1582
                        o_spi_word <= r_data;
1583
                        // o_bus_ack  <= (otp_wr_request)&&(accepted)&&(i_pipewr);
1584
                        // o_data_ack <= (otp_wr_request)&&(accepted);
1585
                        if (accepted) // &&(~i_pipewr)
1586
                                id_state <= `ID_WAIT_ON_STOP;
1587
                        else if(accepted)
1588
                        begin
1589
                                o_spi_word <= i_data;
1590
                                r_data <= i_data;
1591
                        end end
1592
                `ID_WAIT_ON_STOP: begin
1593
                        o_spi_wr <= 1'b0;
1594
                        if (i_spi_stopped)
1595
                                id_state <= `ID_REQ_STATUS;
1596
                        end
1597
                `ID_REQ_STATUS: begin
1598
                        o_spi_wr <= 1'b1;
1599
                        o_spi_hold <= 1'b0;
1600
                        o_spi_word[31:24] <= 8'h05;
1601
                        o_spi_dir <= 1'b0;
1602
                        o_spi_len <= 2'b00;
1603
                        if (accepted)
1604
                                id_state <= `ID_REQ_STATUS_NEXT;
1605
                        end
1606
                `ID_REQ_STATUS_NEXT: begin
1607
                        o_spi_wr <= 1'b1;
1608
                        o_spi_hold <= 1'b0;
1609
                        o_spi_dir <= 1'b1; // Read
1610
                        o_spi_len <= 2'b00; // 8 bits
1611
                        // o_spi_word <= dont care
1612 12 dgisselq
                        valid_status <= 1'b0;
1613 3 dgisselq
                        if (accepted)
1614
                                id_state <= `ID_READ_STATUS;
1615
                        end
1616
                `ID_READ_STATUS: begin
1617
                        o_spi_wr <= 1'b1;
1618
                        o_spi_hold <= 1'b0;
1619
                        o_spi_dir <= 1'b1; // Read
1620
                        o_spi_len <= 2'b00; // 8 bits
1621
                        // o_spi_word <= dont care
1622
                        if (i_spi_valid)
1623 12 dgisselq
                                valid_status <= 1'b1;
1624
                        if ((i_spi_valid)&&(valid_status))
1625 3 dgisselq
                                chk_wip <= 1'b1;
1626
                        if ((chk_wip)&&(~i_spi_data[0]))
1627
                        begin
1628
                                o_wip <= 1'b0;
1629
                                id_state <= `ID_FINAL_STOP;
1630
                        end end
1631
                default: begin // ID_FINAL_STOP
1632
                        o_bus_ack <= 1'b0;
1633
                        nxt_data_ack <= 1'b0;
1634
                        o_qspi_req <= 1'b0;
1635
                        o_spi_wr <= 1'b0;
1636
                        o_spi_hold <= 1'b0;
1637
                        o_spi_dir <= 1'b1; // Read
1638
                        o_spi_len <= 2'b00; // 8 bits
1639
                        // o_spi_word <= dont care
1640
                        if (i_spi_stopped)
1641
                                id_state <= `ID_IDLE;
1642
                        end
1643
                endcase
1644
        end
1645
 
1646
        always @(posedge i_clk)
1647
        begin
1648
                if (nxt_data_ack)
1649
                        o_data <= (nxt_data_spi)?i_spi_data : nxt_data;
1650
                o_data_ack <= nxt_data_ack;
1651
        end
1652
 
1653
        always @(posedge i_clk)
1654
                if (set_val)
1655
                        idmem[set_addr] <= i_spi_data;
1656
 
1657
        assign  o_spi_spd = 1'b0; // Slow, 1-bit at a time
1658
 
1659
endmodule
1660
 
1661
 
1662
 

powered by: WebSVN 2.1.0

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