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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [orpsocv2/] [rtl/] [verilog/] [usbhostslave/] [getPacket.v] - Blame information for rev 507

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

Line No. Rev Author Line
1 408 julius
 
2
// File        : ../RTL/hostController/getpacket.v
3
// Generated   : 11/10/06 05:37:20
4
// From        : ../RTL/hostController/getpacket.asf
5
// By          : FSM2VHDL ver. 5.0.0.9
6
 
7
//////////////////////////////////////////////////////////////////////
8
////                                                              ////
9
//// getpacket
10
////                                                              ////
11
//// This file is part of the usbhostslave opencores effort.
12
//// http://www.opencores.org/cores/usbhostslave/                 ////
13
////                                                              ////
14
//// Module Description:                                          ////
15
//// 
16
////                                                              ////
17
//// To Do:                                                       ////
18
//// 
19
////                                                              ////
20
//// Author(s):                                                   ////
21
//// - Steve Fielding, sfielding@base2designs.com                 ////
22
////                                                              ////
23
//////////////////////////////////////////////////////////////////////
24
////                                                              ////
25
//// Copyright (C) 2004 Steve Fielding and OPENCORES.ORG          ////
26
////                                                              ////
27
//// This source file may be used and distributed without         ////
28
//// restriction provided that this copyright statement is not    ////
29
//// removed from the file and that any derivative work contains  ////
30
//// the original copyright notice and the associated disclaimer. ////
31
////                                                              ////
32
//// This source file is free software; you can redistribute it   ////
33
//// and/or modify it under the terms of the GNU Lesser General   ////
34
//// Public License as published by the Free Software Foundation; ////
35
//// either version 2.1 of the License, or (at your option) any   ////
36
//// later version.                                               ////
37
////                                                              ////
38
//// This source is distributed in the hope that it will be       ////
39
//// useful, but WITHOUT ANY WARRANTY; without even the implied   ////
40
//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      ////
41
//// PURPOSE. See the GNU Lesser General Public License for more  ////
42
//// details.                                                     ////
43
////                                                              ////
44
//// You should have received a copy of the GNU Lesser General    ////
45
//// Public License along with this source; if not, download it   ////
46
//// from http://www.opencores.org/lgpl.shtml                     ////
47
////                                                              ////
48
//////////////////////////////////////////////////////////////////////
49
//
50
`include "timescale.v"
51
 
52
`include "usbhostslave_serialinterfaceengine_h.v"
53
`include "usbhostslave_constants_h.v"
54
 
55
module getPacket (RXDataIn, RXDataValid, RXFifoData, RXFifoFull, RXFifoWEn, RXPacketRdy, RXPktStatus, RXStreamStatusIn, RxPID, SIERxTimeOut, SIERxTimeOutEn, clk, getPacketEn, rst);
56
input   [7:0] RXDataIn;
57
input   RXDataValid;
58
input   RXFifoFull;
59
input   [7:0] RXStreamStatusIn;
60
input   SIERxTimeOut;           // Single cycle pulse
61
input   clk;
62
input   getPacketEn;
63
input   rst;
64
output  [7:0] RXFifoData;
65
output  RXFifoWEn;
66
output  RXPacketRdy;
67
output  [7:0] RXPktStatus;
68
output  [3:0] RxPID;
69
output  SIERxTimeOutEn;
70
 
71
wire    [7:0] RXDataIn;
72
wire    RXDataValid;
73
reg     [7:0] RXFifoData, next_RXFifoData;
74
wire    RXFifoFull;
75
reg     RXFifoWEn, next_RXFifoWEn;
76
reg     RXPacketRdy, next_RXPacketRdy;
77
reg     [7:0] RXPktStatus;
78
wire    [7:0] RXStreamStatusIn;
79
reg     [3:0] RxPID, next_RxPID;
80
wire    SIERxTimeOut;
81
reg     SIERxTimeOutEn, next_SIERxTimeOutEn;
82
wire    clk;
83
wire    getPacketEn;
84
wire    rst;
85
 
86
// diagram signals declarations
87
reg  ACKRxed, next_ACKRxed;
88
reg  CRCError, next_CRCError;
89
reg  NAKRxed, next_NAKRxed;
90
reg  [7:0]RXByteOld, next_RXByteOld;
91
reg  [7:0]RXByteOldest, next_RXByteOldest;
92
reg  [7:0]RXByte, next_RXByte;
93
reg  RXOverflow, next_RXOverflow;
94
reg  [7:0]RXStreamStatus, next_RXStreamStatus;
95
reg  RXTimeOut, next_RXTimeOut;
96
reg  bitStuffError, next_bitStuffError;
97
reg  dataSequence, next_dataSequence;
98
reg  stallRxed, next_stallRxed;
99
 
100
// BINARY ENCODED state machine: getPkt
101
// State codes definitions:
102
`define PROC_PKT_CHK_PID 5'b00000
103
`define PROC_PKT_HS 5'b00001
104
`define PROC_PKT_DATA_W_D1 5'b00010
105
`define PROC_PKT_DATA_CHK_D1 5'b00011
106
`define PROC_PKT_DATA_W_D2 5'b00100
107
`define PROC_PKT_DATA_FIN 5'b00101
108
`define PROC_PKT_DATA_CHK_D2 5'b00110
109
`define PROC_PKT_DATA_W_D3 5'b00111
110
`define PROC_PKT_DATA_CHK_D3 5'b01000
111
`define PROC_PKT_DATA_LOOP_CHK_FIFO 5'b01001
112
`define PROC_PKT_DATA_LOOP_FIFO_FULL 5'b01010
113
`define PROC_PKT_DATA_LOOP_W_D 5'b01011
114
`define START_GP 5'b01100
115
`define WAIT_PKT 5'b01101
116
`define CHK_PKT_START 5'b01110
117
`define WAIT_EN 5'b01111
118
`define PKT_RDY 5'b10000
119
`define PROC_PKT_DATA_LOOP_DELAY 5'b10001
120
 
121
reg [4:0] CurrState_getPkt;
122
reg [4:0] NextState_getPkt;
123
 
124
// Diagram actions (continuous assignments allowed only: assign ...)
125
 
126
always @
127
(CRCError or bitStuffError or
128
  RXOverflow or RXTimeOut or
129
  NAKRxed or stallRxed or
130
  ACKRxed or dataSequence)
131
begin
132
    RXPktStatus <= {
133
    dataSequence, ACKRxed,
134
    stallRxed, NAKRxed,
135
    RXTimeOut, RXOverflow,
136
    bitStuffError, CRCError};
137
end
138
 
139
//--------------------------------------------------------------------
140
// Machine: getPkt
141
//--------------------------------------------------------------------
142
//----------------------------------
143
// Next State Logic (combinatorial)
144
//----------------------------------
145
always @ (RXDataIn or RXStreamStatusIn or RXByte or RXByteOldest or RXByteOld or SIERxTimeOut or RXDataValid or RXStreamStatus or getPacketEn or RXFifoFull or CRCError or bitStuffError or RXOverflow or RXTimeOut or NAKRxed or stallRxed or ACKRxed or dataSequence or SIERxTimeOutEn or RxPID or RXPacketRdy or RXFifoWEn or RXFifoData or CurrState_getPkt)
146
begin : getPkt_NextState
147
  NextState_getPkt <= CurrState_getPkt;
148
  // Set default values for outputs and signals
149
  next_CRCError <= CRCError;
150
  next_bitStuffError <= bitStuffError;
151
  next_RXOverflow <= RXOverflow;
152
  next_RXTimeOut <= RXTimeOut;
153
  next_NAKRxed <= NAKRxed;
154
  next_stallRxed <= stallRxed;
155
  next_ACKRxed <= ACKRxed;
156
  next_dataSequence <= dataSequence;
157
  next_SIERxTimeOutEn <= SIERxTimeOutEn;
158
  next_RXByte <= RXByte;
159
  next_RXStreamStatus <= RXStreamStatus;
160
  next_RxPID <= RxPID;
161
  next_RXPacketRdy <= RXPacketRdy;
162
  next_RXByteOldest <= RXByteOldest;
163
  next_RXByteOld <= RXByteOld;
164
  next_RXFifoWEn <= RXFifoWEn;
165
  next_RXFifoData <= RXFifoData;
166
  case (CurrState_getPkt)
167
    `START_GP:
168
      NextState_getPkt <= `WAIT_EN;
169
    `WAIT_PKT:
170
    begin
171
      next_CRCError <= 1'b0;
172
      next_bitStuffError <= 1'b0;
173
      next_RXOverflow <= 1'b0;
174
      next_RXTimeOut <= 1'b0;
175
      next_NAKRxed <= 1'b0;
176
      next_stallRxed <= 1'b0;
177
      next_ACKRxed <= 1'b0;
178
      next_dataSequence <= 1'b0;
179
      next_SIERxTimeOutEn <= 1'b1;
180
      if (SIERxTimeOut == 1'b1)
181
      begin
182
        NextState_getPkt <= `PKT_RDY;
183
        next_RXTimeOut <= 1'b1;
184
      end
185
      else if (RXDataValid == 1'b1)
186
      begin
187
        NextState_getPkt <= `CHK_PKT_START;
188
        next_RXByte <= RXDataIn;
189
        next_RXStreamStatus <= RXStreamStatusIn;
190
      end
191
    end
192
    `CHK_PKT_START:
193
      if (RXStreamStatus == `RX_PACKET_START)
194
      begin
195
        NextState_getPkt <= `PROC_PKT_CHK_PID;
196
        next_RxPID <= RXByte[3:0];
197
      end
198
      else
199
      begin
200
        NextState_getPkt <= `PKT_RDY;
201
        next_RXTimeOut <= 1'b1;
202
      end
203
    `WAIT_EN:
204
    begin
205
      next_RXPacketRdy <= 1'b0;
206
      next_SIERxTimeOutEn <= 1'b0;
207
      if (getPacketEn == 1'b1)
208
        NextState_getPkt <= `WAIT_PKT;
209
    end
210
    `PKT_RDY:
211
    begin
212
      next_RXPacketRdy <= 1'b1;
213
      NextState_getPkt <= `WAIT_EN;
214
    end
215
    `PROC_PKT_CHK_PID:
216
      if (RXByte[1:0] == `HANDSHAKE)
217
        NextState_getPkt <= `PROC_PKT_HS;
218
      else if (RXByte[1:0] == `DATA)
219
        NextState_getPkt <= `PROC_PKT_DATA_W_D1;
220
      else
221
        NextState_getPkt <= `PKT_RDY;
222
    `PROC_PKT_HS:
223
      if (RXDataValid == 1'b1)
224
      begin
225
        NextState_getPkt <= `PKT_RDY;
226
        next_RXOverflow <= RXDataIn[`RX_OVERFLOW_BIT];
227
        next_NAKRxed <= RXDataIn[`NAK_RXED_BIT];
228
        next_stallRxed <= RXDataIn[`STALL_RXED_BIT];
229
        next_ACKRxed <= RXDataIn[`ACK_RXED_BIT];
230
      end
231
    `PROC_PKT_DATA_W_D1:
232
      if (RXDataValid == 1'b1)
233
      begin
234
        NextState_getPkt <= `PROC_PKT_DATA_CHK_D1;
235
        next_RXByte <= RXDataIn;
236
        next_RXStreamStatus <= RXStreamStatusIn;
237
      end
238
    `PROC_PKT_DATA_CHK_D1:
239
      if (RXStreamStatus == `RX_PACKET_STREAM)
240
      begin
241
        NextState_getPkt <= `PROC_PKT_DATA_W_D2;
242
        next_RXByteOldest <= RXByte;
243
      end
244
      else
245
        NextState_getPkt <= `PROC_PKT_DATA_FIN;
246
    `PROC_PKT_DATA_W_D2:
247
      if (RXDataValid == 1'b1)
248
      begin
249
        NextState_getPkt <= `PROC_PKT_DATA_CHK_D2;
250
        next_RXByte <= RXDataIn;
251
        next_RXStreamStatus <= RXStreamStatusIn;
252
      end
253
    `PROC_PKT_DATA_FIN:
254
    begin
255
      next_CRCError <= RXByte[`CRC_ERROR_BIT];
256
      next_bitStuffError <= RXByte[`BIT_STUFF_ERROR_BIT];
257
      next_dataSequence <= RXByte[`DATA_SEQUENCE_BIT];
258
      NextState_getPkt <= `PKT_RDY;
259
    end
260
    `PROC_PKT_DATA_CHK_D2:
261
      if (RXStreamStatus == `RX_PACKET_STREAM)
262
      begin
263
        NextState_getPkt <= `PROC_PKT_DATA_W_D3;
264
        next_RXByteOld <= RXByte;
265
      end
266
      else
267
        NextState_getPkt <= `PROC_PKT_DATA_FIN;
268
    `PROC_PKT_DATA_W_D3:
269
      if (RXDataValid == 1'b1)
270
      begin
271
        NextState_getPkt <= `PROC_PKT_DATA_CHK_D3;
272
        next_RXByte <= RXDataIn;
273
        next_RXStreamStatus <= RXStreamStatusIn;
274
      end
275
    `PROC_PKT_DATA_CHK_D3:
276
      if (RXStreamStatus == `RX_PACKET_STREAM)
277
        NextState_getPkt <= `PROC_PKT_DATA_LOOP_CHK_FIFO;
278
      else
279
        NextState_getPkt <= `PROC_PKT_DATA_FIN;
280
    `PROC_PKT_DATA_LOOP_CHK_FIFO:
281
      if (RXFifoFull == 1'b1)
282
      begin
283
        NextState_getPkt <= `PROC_PKT_DATA_LOOP_FIFO_FULL;
284
        next_RXOverflow <= 1'b1;
285
      end
286
      else
287
      begin
288
        NextState_getPkt <= `PROC_PKT_DATA_LOOP_W_D;
289
        next_RXFifoWEn <= 1'b1;
290
        next_RXFifoData <= RXByteOldest;
291
        next_RXByteOldest <= RXByteOld;
292
        next_RXByteOld <= RXByte;
293
      end
294
    `PROC_PKT_DATA_LOOP_FIFO_FULL:
295
      NextState_getPkt <= `PROC_PKT_DATA_LOOP_W_D;
296
    `PROC_PKT_DATA_LOOP_W_D:
297
    begin
298
      next_RXFifoWEn <= 1'b0;
299
      if ((RXDataValid == 1'b1) && (RXStreamStatusIn == `RX_PACKET_STREAM))
300
      begin
301
        NextState_getPkt <= `PROC_PKT_DATA_LOOP_DELAY;
302
        next_RXByte <= RXDataIn;
303
        next_RXStreamStatus <= RXStreamStatusIn;
304
      end
305
      else if (RXDataValid == 1'b1)
306
      begin
307
        NextState_getPkt <= `PROC_PKT_DATA_FIN;
308
        next_RXByte <= RXDataIn;
309
        next_RXStreamStatus <= RXStreamStatusIn;
310
      end
311
    end
312
    `PROC_PKT_DATA_LOOP_DELAY:
313
      NextState_getPkt <= `PROC_PKT_DATA_LOOP_CHK_FIFO;
314
  endcase
315
end
316
 
317
//----------------------------------
318
// Current State Logic (sequential)
319
//----------------------------------
320
always @ (posedge clk)
321
begin : getPkt_CurrentState
322
  if (rst)
323
    CurrState_getPkt <= `START_GP;
324
  else
325
    CurrState_getPkt <= NextState_getPkt;
326
end
327
 
328
//----------------------------------
329
// Registered outputs logic
330
//----------------------------------
331
always @ (posedge clk)
332
begin : getPkt_RegOutput
333
  if (rst)
334
  begin
335
    RXByteOld <= 8'h00;
336
    RXByteOldest <= 8'h00;
337
    CRCError <= 1'b0;
338
    bitStuffError <= 1'b0;
339
    RXOverflow <= 1'b0;
340
    RXTimeOut <= 1'b0;
341
    NAKRxed <= 1'b0;
342
    stallRxed <= 1'b0;
343
    ACKRxed <= 1'b0;
344
    dataSequence <= 1'b0;
345
    RXByte <= 8'h00;
346
    RXStreamStatus <= 8'h00;
347
    RXPacketRdy <= 1'b0;
348
    RXFifoWEn <= 1'b0;
349
    RXFifoData <= 8'h00;
350
    RxPID <= 4'h0;
351
    SIERxTimeOutEn <= 1'b0;
352
  end
353
  else
354
  begin
355
    RXByteOld <= next_RXByteOld;
356
    RXByteOldest <= next_RXByteOldest;
357
    CRCError <= next_CRCError;
358
    bitStuffError <= next_bitStuffError;
359
    RXOverflow <= next_RXOverflow;
360
    RXTimeOut <= next_RXTimeOut;
361
    NAKRxed <= next_NAKRxed;
362
    stallRxed <= next_stallRxed;
363
    ACKRxed <= next_ACKRxed;
364
    dataSequence <= next_dataSequence;
365
    RXByte <= next_RXByte;
366
    RXStreamStatus <= next_RXStreamStatus;
367
    RXPacketRdy <= next_RXPacketRdy;
368
    RXFifoWEn <= next_RXFifoWEn;
369
    RXFifoData <= next_RXFifoData;
370
    RxPID <= next_RxPID;
371
    SIERxTimeOutEn <= next_SIERxTimeOutEn;
372
  end
373
end
374
 
375
endmodule

powered by: WebSVN 2.1.0

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