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

Subversion Repositories sgmii

[/] [sgmii/] [trunk/] [build/] [OpenCore_MAC/] [MAC_rx_ctrl.v] - Blame information for rev 27

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

Line No. Rev Author Line
1 26 jefflieu
//////////////////////////////////////////////////////////////////////
2
////                                                              ////
3
////  MAC_rx_ctrl.v                                               ////
4
////                                                              ////
5
////  This file is part of the Ethernet IP core project           ////
6
////  http://www.opencores.org/projects.cgi/web/ethernet_tri_mode/////
7
////                                                              ////
8
////  Author(s):                                                  ////
9
////      - Jon Gao (gaojon@yahoo.com)                            ////
10
////                                                              ////
11
////                                                              ////
12
//////////////////////////////////////////////////////////////////////
13
////                                                              ////
14
//// Copyright (C) 2001 Authors                                   ////
15
////                                                              ////
16
//// This source file may be used and distributed without         ////
17
//// restriction provided that this copyright statement is not    ////
18
//// removed from the file and that any derivative work contains  ////
19
//// the original copyright notice and the associated disclaimer. ////
20
////                                                              ////
21
//// This source file is free software; you can redistribute it   ////
22
//// and/or modify it under the terms of the GNU Lesser General   ////
23
//// Public License as published by the Free Software Foundation; ////
24
//// either version 2.1 of the License, or (at your option) any   ////
25
//// later version.                                               ////
26
////                                                              ////
27
//// This source is distributed in the hope that it will be       ////
28
//// useful, but WITHOUT ANY WARRANTY; without even the implied   ////
29
//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      ////
30
//// PURPOSE.  See the GNU Lesser General Public License for more ////
31
//// details.                                                     ////
32
////                                                              ////
33
//// You should have received a copy of the GNU Lesser General    ////
34
//// Public License along with this source; if not, download it   ////
35
//// from http://www.opencores.org/lgpl.shtml                     ////
36
////                                                              ////
37
//////////////////////////////////////////////////////////////////////
38
//                                                                    
39
// CVS Revision History                                               
40
//                                                                    
41
// $Log: not supported by cvs2svn $
42
// Revision 1.3  2006/01/19 14:07:54  maverickist
43
// verification is complete.
44
//
45
// Revision 1.3  2005/12/16 06:44:17  Administrator
46
// replaced tab with space.
47
// passed 9.6k length frame test.
48
//
49
// Revision 1.2  2005/12/13 12:15:37  Administrator
50
// no message
51
//
52
// Revision 1.1.1.1  2005/12/13 01:51:45  Administrator
53
// no message
54
//                                           
55
// Jeff Changes #1
56
 
57
module MAC_rx_ctrl (
58
Reset   ,
59
Clk     ,
60
//RMII interface                                    
61
MCrs_dv ,       //
62
MRxD    ,       //  
63
MRxErr  ,       //  
64
//CRC_chk interface                                 
65
CRC_en    ,
66
CRC_init  ,
67
CRC_err  ,
68
//MAC_rx_add_chk interface                          
69
MAC_add_en          ,
70
MAC_rx_add_chk_err  ,
71
//broadcast_filter     
72
broadcast_ptr   ,
73
broadcast_drop  ,
74
//flow_control signals      
75
pause_quanta        ,
76
pause_quanta_val    ,
77
//MAC_rx_FF interface                               
78
Fifo_data       ,
79
Fifo_data_en    ,
80
Fifo_data_err   ,
81
Fifo_data_end   ,
82
Fifo_full       ,
83
//RMON interface                
84
Rx_pkt_type_rmon        ,
85
Rx_pkt_length_rmon      ,
86
Rx_apply_rmon           ,
87
Rx_pkt_err_type_rmon    ,
88
//CPU                                         
89
RX_IFG_SET    ,
90
RX_MAX_LENGTH,
91
RX_MIN_LENGTH
92
);
93
 
94
input           Reset   ;
95
input           Clk     ;
96
                //RMII interface  
97
input           MCrs_dv ;
98
input   [7:0]   MRxD    ;
99
input           MRxErr  ;
100
                //CRC_chk interface
101
output          CRC_en  ;
102
output          CRC_init;
103
input           CRC_err ;
104
                //MAC_rx_add_chk interface
105
output          MAC_add_en          ;
106
input           MAC_rx_add_chk_err  ;
107
                //broadcast_filter
108
output          broadcast_ptr           ;
109
input           broadcast_drop          ;
110
                //flow_control signals  
111
output  [15:0]  pause_quanta        ;
112
output          pause_quanta_val    ;
113
                //MAC_rx_FF interface
114
output  [7:0]   Fifo_data       ;
115
output          Fifo_data_en    ;
116
output          Fifo_data_err   ;
117
output          Fifo_data_end   ;
118
input           Fifo_full;
119
                //RMON interface
120
output  [15:0]  Rx_pkt_length_rmon      ;
121
output          Rx_apply_rmon           ;
122
output  [2:0]   Rx_pkt_err_type_rmon    ;
123
output  [2:0]   Rx_pkt_type_rmon        ;
124
                //CPU
125
input   [5:0]   RX_IFG_SET    ;
126
input   [15:0]  RX_MAX_LENGTH   ;// 1518
127
input   [6:0]   RX_MIN_LENGTH   ;// 64
128
 
129
//******************************************************************************
130
//internal signals
131
//******************************************************************************
132
parameter       State_idle          =4'd00;
133
parameter       State_preamble      =4'd01;
134
parameter       State_SFD           =4'd02;
135
parameter       State_data          =4'd03;
136
parameter       State_checkCRC      =4'd04;
137
parameter       State_OkEnd         =4'd07;
138
parameter       State_drop          =4'd08;
139
parameter       State_ErrEnd        =4'd09;
140
parameter       State_CRCErrEnd     =4'd10;
141
parameter       State_FFFullDrop    =4'd11;
142
parameter       State_FFFullErrEnd  =4'd12;
143
parameter       State_IFG           =4'd13;
144
 
145
parameter       Pause_idle          =4'd0;
146
parameter       Pause_pre_syn       =4'd1;
147
parameter       Pause_quanta_hi     =4'd2;
148
parameter       Pause_quanta_lo     =4'd3;
149
parameter       Pause_syn           =4'd4;
150
 
151
reg [3:0]       Current_state /* synthesis syn_keep=1 */;
152
reg [3:0]       Next_state;
153
reg [3:0]       Pause_current /* synthesis syn_keep=1 */;
154
reg [3:0]       Pause_next;
155
reg [5:0]       IFG_counter;
156
reg             Crs_dv  ;
157
reg [7:0]       RxD ;
158
reg [7:0]       RxD_dl1 ;
159
reg             RxErr   ;
160
reg [15:0]      Frame_length_counter;
161
reg             Too_long;
162
reg             Too_short;
163
reg             Fifo_data_en;
164
reg             Fifo_data_end;
165
reg             Fifo_data_err;
166
reg             CRC_en;
167
reg             CRC_init;
168
reg             Rx_apply_rmon;
169
reg             Rx_apply_rmon_tmp;
170
reg             Rx_apply_rmon_tmp_pl1;
171
reg [2:0]       Rx_pkt_err_type_rmon;
172
reg             MAC_add_en;
173
reg [2:0]       Rx_pkt_type_rmon;
174
reg [7:0]       pause_quanta_h      ;
175
reg [15:0]      pause_quanta        ;
176
reg             pause_quanta_val    ;
177
reg             pause_quanta_val_tmp;
178
reg             pause_frame_ptr     ;
179
reg             broadcast_ptr           ;
180
//******************************************************************************
181
//delay signals                                                          
182
//******************************************************************************
183
 
184
always @ (posedge Reset or posedge Clk)
185
    if (Reset)
186
        begin
187
            Crs_dv      <=0;
188
            RxD         <=0;
189
            RxErr       <=0;
190
        end
191
    else
192
        begin
193
            Crs_dv      <=MCrs_dv   ;
194
            RxD         <=MRxD      ;
195
            RxErr       <=MRxErr    ;
196
        end
197
 
198
always @ (posedge Reset or posedge Clk)
199
    if (Reset)
200
        RxD_dl1     <=0;
201
    else
202
        RxD_dl1     <=RxD;
203
 
204
//******************************************************************************
205
//State_machine                                                           
206
//******************************************************************************
207
 
208
always @ (posedge Reset or posedge Clk)
209
    if (Reset)
210
        Current_state   <=State_idle;
211
    else
212
        Current_state   <=Next_state;
213
 
214
always @ (*)
215
        case (Current_state)
216
            State_idle:
217
                    if (Crs_dv&&RxD==8'h55)
218
                        Next_state  =State_preamble;
219
                    else
220
                        Next_state  =Current_state;
221
            State_preamble:
222
                    if (!Crs_dv)
223
                        Next_state  =State_ErrEnd;
224
                    else if (RxErr)
225
                        Next_state  =State_drop;
226
                    else if (RxD==8'hd5)
227
                        Next_state  =State_SFD;
228
                    else if (RxD==8'h55)
229
                        Next_state  =Current_state;
230
                    else
231
                        Next_state  =State_drop;
232
            State_SFD:
233
                    if (!Crs_dv)
234
                        Next_state  =State_ErrEnd;
235
                    else if (RxErr)
236
                        Next_state  =State_drop;
237
                    else
238
                        Next_state  =State_data;
239
            State_data:
240
                    if (!Crs_dv&&!Too_short&&!Too_long)
241
                        Next_state  =State_checkCRC;
242
                    else if (!Crs_dv&&(Too_short||Too_long))
243
                        Next_state  =State_ErrEnd;
244
                    else if (Fifo_full)
245
                        Next_state  =State_FFFullErrEnd;
246
                    //else if (RxErr||MAC_rx_add_chk_err||Too_long||broadcast_drop) 
247
                                                  //Jeff Changes #1
248
                                                  else if ((Crs_dv&&RxErr)||MAC_rx_add_chk_err||Too_long||broadcast_drop)
249
                        Next_state  =State_drop;
250
                    else
251
                        Next_state  =State_data;
252
            State_checkCRC:
253
                     if (CRC_err)
254
                        Next_state  =State_CRCErrEnd;
255
                     else
256
                        Next_state  =State_OkEnd;
257
            State_drop:
258
                    if (!Crs_dv)
259
                        Next_state  =State_ErrEnd;
260
                    else
261
                        Next_state  =Current_state;
262
            State_OkEnd:
263
                        Next_state  =State_IFG;
264
            State_ErrEnd:
265
                        Next_state  =State_IFG;
266
 
267
            State_CRCErrEnd:
268
                        Next_state  =State_IFG;
269
            State_FFFullDrop:
270
                    if (!Crs_dv)
271
                        Next_state  =State_IFG;
272
                    else
273
                        Next_state  =Current_state;
274
            State_FFFullErrEnd:
275
                        Next_state  =State_FFFullDrop;
276
            State_IFG:
277
                    if (IFG_counter==RX_IFG_SET-4)   //remove some additional time     
278
                        Next_state  =State_idle;
279
                    else
280
                        Next_state  =Current_state;
281
 
282
            default:
283
                        Next_state  =State_idle;
284
        endcase
285
 
286
 
287
always @ (posedge Reset or posedge Clk)
288
    if (Reset)
289
        IFG_counter     <=0;
290
    else if (Current_state!=State_IFG)
291
        IFG_counter     <=0;
292
    else
293
        IFG_counter     <=IFG_counter + 1;
294
//******************************************************************************
295
//gen fifo interface signals                                                     
296
//******************************************************************************                     
297
 
298
assign  Fifo_data   =RxD_dl1;
299
 
300
always @(Current_state)
301
    if  (Current_state==State_data)
302
        Fifo_data_en        =1;
303
    else
304
        Fifo_data_en        =0;
305
 
306
always @(Current_state)
307
    if  (Current_state==State_ErrEnd||Current_state==State_OkEnd
308
         ||Current_state==State_CRCErrEnd||Current_state==State_FFFullErrEnd)
309
        Fifo_data_end       =1;
310
    else
311
        Fifo_data_end       =0;
312
 
313
always @(Current_state)
314
    if  (Current_state==State_ErrEnd||Current_state==State_CRCErrEnd||Current_state==State_FFFullErrEnd)
315
        Fifo_data_err       =1;
316
    else
317
        Fifo_data_err       =0;
318
 
319
//******************************************************************************
320
//CRC_chk interface                                               
321
//****************************************************************************** 
322
 
323
always @(Current_state)
324
    if (Current_state==State_data)
325
        CRC_en  =1;
326
    else
327
        CRC_en  =0;
328
 
329
always @(Current_state)
330
    if (Current_state==State_SFD)
331
        CRC_init    =1;
332
    else
333
        CRC_init    =0;
334
 
335
//******************************************************************************
336
//gen rmon signals                                         
337
//******************************************************************************    
338
always @ (posedge Clk or posedge Reset)
339
    if (Reset)
340
        Frame_length_counter        <=0;
341
    else if (Current_state==State_SFD)
342
        Frame_length_counter        <=1;
343
    else if (Current_state==State_data)
344
        Frame_length_counter        <=Frame_length_counter+ 1'b1;
345
 
346
always @ (Frame_length_counter or RX_MIN_LENGTH)
347
    if (Frame_length_counter<RX_MIN_LENGTH)
348
        Too_short   =1;
349
    else
350
        Too_short   =0;
351
 
352
always @ (*)
353
    if (Frame_length_counter>RX_MAX_LENGTH)
354
        Too_long    =1;
355
    else
356
        Too_long    =0;
357
 
358
assign Rx_pkt_length_rmon=Frame_length_counter-1'b1;
359
 
360
always @ (posedge Clk or posedge Reset)
361
    if (Reset)
362
        Rx_apply_rmon_tmp   <=0;
363
    else if (Current_state==State_OkEnd||Current_state==State_ErrEnd
364
        ||Current_state==State_CRCErrEnd||Current_state==State_FFFullErrEnd)
365
        Rx_apply_rmon_tmp   <=1;
366
    else
367
        Rx_apply_rmon_tmp   <=0;
368
 
369
always @ (posedge Clk or posedge Reset)
370
    if (Reset)
371
        Rx_apply_rmon_tmp_pl1   <=0;
372
    else
373
        Rx_apply_rmon_tmp_pl1   <=Rx_apply_rmon_tmp;
374
 
375
always @ (posedge Clk or posedge Reset)
376
    if (Reset)
377
        Rx_apply_rmon   <=0;
378
    else if (Current_state==State_OkEnd||Current_state==State_ErrEnd
379
        ||Current_state==State_CRCErrEnd||Current_state==State_FFFullErrEnd)
380
        Rx_apply_rmon   <=1;
381
    else if (Rx_apply_rmon_tmp_pl1)
382
        Rx_apply_rmon   <=0;
383
 
384
always @ (posedge Clk or posedge Reset)
385
    if (Reset)
386
        Rx_pkt_err_type_rmon    <=0;
387
    else if (Current_state==State_CRCErrEnd)
388
        Rx_pkt_err_type_rmon    <=3'b001    ;//
389
    else if (Current_state==State_FFFullErrEnd)
390
        Rx_pkt_err_type_rmon    <=3'b010    ;// 
391
    else if (Current_state==State_ErrEnd)
392
        Rx_pkt_err_type_rmon    <=3'b011    ;//
393
    else if(Current_state==State_OkEnd)
394
        Rx_pkt_err_type_rmon    <=3'b100    ;
395
 
396
 
397
 
398
always @ (posedge Clk or posedge Reset)
399
    if (Reset)
400
        Rx_pkt_type_rmon        <=0;
401
    else if (Current_state==State_OkEnd&&pause_frame_ptr)
402
        Rx_pkt_type_rmon        <=3'b100    ;//
403
    else if(Current_state==State_SFD&&Next_state==State_data)
404
        Rx_pkt_type_rmon        <={1'b0,MRxD[7:6]};
405
 
406
always @ (posedge Clk or posedge Reset)
407
    if (Reset)
408
        broadcast_ptr   <=0;
409
    else if(Current_state==State_IFG)
410
        broadcast_ptr   <=0;
411
    else if(Current_state==State_SFD&&Next_state==State_data&&MRxD[7:6]==2'b11)
412
        broadcast_ptr   <=1;
413
 
414
 
415
 
416
//******************************************************************************
417
//MAC add checker signals                                                              
418
//******************************************************************************
419
always @ (Frame_length_counter or Fifo_data_en)
420
    if(Frame_length_counter>=1&&Frame_length_counter<=6)
421
        MAC_add_en  <=Fifo_data_en;
422
    else
423
        MAC_add_en  <=0;
424
 
425
//******************************************************************************
426
//flow control signals                                                            
427
//******************************************************************************
428
always @ (posedge Clk or posedge Reset)
429
    if (Reset)
430
        Pause_current   <=Pause_idle;
431
    else
432
        Pause_current   <=Pause_next;
433
 
434
always @ (*)
435
    case (Pause_current)
436
        Pause_idle  :
437
            if(Current_state==State_SFD)
438
                Pause_next  =Pause_pre_syn;
439
            else
440
                Pause_next  =Pause_current;
441
        Pause_pre_syn:
442
            case (Frame_length_counter)
443
                16'd1:  if (RxD_dl1==8'h01)
444
                            Pause_next  =Pause_current;
445
                        else
446
                            Pause_next  =Pause_idle;
447
                16'd2:  if (RxD_dl1==8'h80)
448
                            Pause_next  =Pause_current;
449
                        else
450
                            Pause_next  =Pause_idle;
451
                16'd3:  if (RxD_dl1==8'hc2)
452
                            Pause_next  =Pause_current;
453
                        else
454
                            Pause_next  =Pause_idle;
455
                16'd4:  if (RxD_dl1==8'h00)
456
                            Pause_next  =Pause_current;
457
                        else
458
                            Pause_next  =Pause_idle;
459
                16'd5:  if (RxD_dl1==8'h00)
460
                            Pause_next  =Pause_current;
461
                        else
462
                            Pause_next  =Pause_idle;
463
                16'd6:  if (RxD_dl1==8'h01)
464
                            Pause_next  =Pause_current;
465
                        else
466
                            Pause_next  =Pause_idle;
467
                16'd13: if (RxD_dl1==8'h88)
468
                            Pause_next  =Pause_current;
469
                        else
470
                            Pause_next  =Pause_idle;
471
                16'd14: if (RxD_dl1==8'h08)
472
                            Pause_next  =Pause_current;
473
                        else
474
                            Pause_next  =Pause_idle;
475
                16'd15: if (RxD_dl1==8'h00)
476
                            Pause_next  =Pause_current;
477
                        else
478
                            Pause_next  =Pause_idle;
479
                16'd16: if (RxD_dl1==8'h01)
480
                            Pause_next  =Pause_quanta_hi;
481
                        else
482
                            Pause_next  =Pause_idle;
483
                default:    Pause_next  =Pause_current;
484
            endcase
485
        Pause_quanta_hi :
486
            Pause_next  =Pause_quanta_lo;
487
        Pause_quanta_lo :
488
            Pause_next  =Pause_syn;
489
        Pause_syn       :
490
            if (Current_state==State_IFG)
491
                Pause_next  =Pause_idle;
492
            else
493
                Pause_next  =Pause_current;
494
        default
495
            Pause_next  =Pause_idle;
496
    endcase
497
 
498
always @ (posedge Clk or posedge Reset)
499
    if (Reset)
500
        pause_quanta_h      <=0;
501
    else if(Pause_current==Pause_quanta_hi)
502
        pause_quanta_h      <=RxD_dl1;
503
 
504
always @ (posedge Clk or posedge Reset)
505
    if (Reset)
506
        pause_quanta        <=0;
507
    else if(Pause_current==Pause_quanta_lo)
508
        pause_quanta        <={pause_quanta_h,RxD_dl1};
509
 
510
always @ (posedge Clk or posedge Reset)
511
    if (Reset)
512
        pause_quanta_val_tmp    <=0;
513
    else if(Current_state==State_OkEnd&&Pause_current==Pause_syn)
514
        pause_quanta_val_tmp    <=1;
515
    else
516
        pause_quanta_val_tmp    <=0;
517
 
518
always @ (posedge Clk or posedge Reset)
519
    if (Reset)
520
        pause_quanta_val    <=0;
521
    else if(Current_state==State_OkEnd&&Pause_current==Pause_syn||pause_quanta_val_tmp)
522
        pause_quanta_val    <=1;
523
    else
524
        pause_quanta_val    <=0;
525
 
526
always @ (posedge Clk or posedge Reset)
527
    if (Reset)
528
        pause_frame_ptr     <=0;
529
    else if(Pause_current==Pause_syn)
530
        pause_frame_ptr     <=1;
531
    else
532
        pause_frame_ptr     <=0;
533
 
534
endmodule
535
 
536
 

powered by: WebSVN 2.1.0

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