1 |
26 |
jefflieu |
module Reg_int (
|
2 |
|
|
input Reset ,
|
3 |
|
|
input Clk_reg ,
|
4 |
|
|
input CSB ,
|
5 |
|
|
input WRB ,
|
6 |
|
|
input [15:0] CD_in ,
|
7 |
|
|
output reg [15:0] CD_out ,
|
8 |
|
|
input [7:0] CA ,
|
9 |
|
|
//Tx host interface
|
10 |
|
|
output [4:0] Tx_Hwmark ,
|
11 |
|
|
output [4:0] Tx_Lwmark ,
|
12 |
|
|
output pause_frame_send_en ,
|
13 |
|
|
output [15:0] pause_quanta_set ,
|
14 |
|
|
output MAC_tx_add_en ,
|
15 |
|
|
output FullDuplex ,
|
16 |
|
|
output [3:0] MaxRetry ,
|
17 |
|
|
output [5:0] IFGset ,
|
18 |
|
|
output [7:0] MAC_tx_add_prom_data ,
|
19 |
|
|
output [2:0] MAC_tx_add_prom_add ,
|
20 |
|
|
output MAC_tx_add_prom_wr ,
|
21 |
|
|
output tx_pause_en ,
|
22 |
|
|
output xoff_cpu ,
|
23 |
|
|
output xon_cpu ,
|
24 |
|
|
//Rx host interface
|
25 |
|
|
output MAC_rx_add_chk_en ,
|
26 |
|
|
output [7:0] MAC_rx_add_prom_data ,
|
27 |
|
|
output [2:0] MAC_rx_add_prom_add ,
|
28 |
|
|
output MAC_rx_add_prom_wr ,
|
29 |
|
|
output broadcast_filter_en ,
|
30 |
|
|
output [15:0] broadcast_bucket_depth ,
|
31 |
|
|
output [15:0] broadcast_bucket_interval ,
|
32 |
|
|
output RX_APPEND_CRC ,
|
33 |
|
|
output [4:0] Rx_Hwmark ,
|
34 |
|
|
output [4:0] Rx_Lwmark ,
|
35 |
|
|
output CRC_chk_en ,
|
36 |
|
|
output [5:0] RX_IFG_SET ,
|
37 |
|
|
output [15:0] RX_MAX_LENGTH ,// 1518
|
38 |
|
|
output [6:0] RX_MIN_LENGTH ,// 64
|
39 |
|
|
//RMON host interface
|
40 |
|
|
output [5:0] CPU_rd_addr ,
|
41 |
|
|
output CPU_rd_apply ,
|
42 |
|
|
input CPU_rd_grant ,
|
43 |
|
|
input [31:0] CPU_rd_dout ,
|
44 |
|
|
//Phy int host interface
|
45 |
|
|
output Line_loop_en ,
|
46 |
|
|
output [2:0] Speed ,
|
47 |
|
|
//MII to CPU
|
48 |
|
|
output [7:0] Divider ,// Divider for the host clock
|
49 |
|
|
output [15:0] CtrlData ,// Control Data (to be written to the PHY reg.)
|
50 |
|
|
output [4:0] Rgad ,// Register Address (within the PHY)
|
51 |
|
|
output [4:0] Fiad ,// PHY Address
|
52 |
|
|
output NoPre ,// No Preamble (no 32-bit preamble)
|
53 |
|
|
output WCtrlData ,// Write Control Data operation
|
54 |
|
|
output RStat ,// Read Status operation
|
55 |
|
|
output ScanStat ,// Scan Status operation
|
56 |
|
|
input Busy ,// Busy Signal
|
57 |
|
|
input LinkFail ,// Link Integrity Signal
|
58 |
|
|
input Nvalid ,// Invalid Status (qualifier for the valid scan result)
|
59 |
|
|
input [15:0] Prsd ,// Read Status Data (data read from the PHY)
|
60 |
|
|
input WCtrlDataStart ,// This signals resets the WCTRLDATA bit in the MIIM Command register
|
61 |
|
|
input RStatStart ,// This signal resets the RSTAT BIT in the MIIM Command register
|
62 |
|
|
input UpdateMIIRX_DATAReg // Updates MII RX_DATA register with read data
|
63 |
|
|
);
|
64 |
|
|
|
65 |
|
|
RegCPUData U_0_000(Tx_Hwmark ,7'd000,16'h0009,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
66 |
|
|
RegCPUData U_0_001(Tx_Lwmark ,7'd001,16'h0008,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
67 |
|
|
RegCPUData U_0_002(pause_frame_send_en ,7'd002,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
68 |
|
|
RegCPUData U_0_003(pause_quanta_set ,7'd003,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
69 |
|
|
RegCPUData U_0_004(IFGset ,7'd004,16'h000c,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
70 |
|
|
RegCPUData U_0_005(FullDuplex ,7'd005,16'h0001,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
71 |
|
|
RegCPUData U_0_006(MaxRetry ,7'd006,16'h0002,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
72 |
|
|
RegCPUData U_0_007(MAC_tx_add_en ,7'd007,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
73 |
|
|
RegCPUData U_0_008(MAC_tx_add_prom_data ,7'd008,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
74 |
|
|
RegCPUData U_0_009(MAC_tx_add_prom_add ,7'd009,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
75 |
|
|
RegCPUData U_0_010(MAC_tx_add_prom_wr ,7'd010,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
76 |
|
|
RegCPUData U_0_011(tx_pause_en ,7'd011,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
77 |
|
|
RegCPUData U_0_012(xoff_cpu ,7'd012,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
78 |
|
|
RegCPUData U_0_013(xon_cpu ,7'd013,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
79 |
|
|
RegCPUData U_0_014(MAC_rx_add_chk_en ,7'd014,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
80 |
|
|
RegCPUData U_0_015(MAC_rx_add_prom_data ,7'd015,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
81 |
|
|
RegCPUData U_0_016(MAC_rx_add_prom_add ,7'd016,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
82 |
|
|
RegCPUData U_0_017(MAC_rx_add_prom_wr ,7'd017,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
83 |
|
|
RegCPUData U_0_018(broadcast_filter_en ,7'd018,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
84 |
|
|
RegCPUData U_0_019(broadcast_bucket_depth ,7'd019,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
85 |
|
|
RegCPUData U_0_020(broadcast_bucket_interval,7'd020,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
86 |
|
|
RegCPUData U_0_021(RX_APPEND_CRC ,7'd021,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
87 |
|
|
RegCPUData U_0_022(Rx_Hwmark ,7'd022,16'h001a,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
88 |
|
|
RegCPUData U_0_023(Rx_Lwmark ,7'd023,16'h0010,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
89 |
|
|
RegCPUData U_0_024(CRC_chk_en ,7'd024,16'h0001,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
90 |
|
|
RegCPUData U_0_025(RX_IFG_SET ,7'd025,16'h000c,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
91 |
|
|
RegCPUData U_0_026(RX_MAX_LENGTH ,7'd026,16'h2710,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
92 |
|
|
RegCPUData U_0_027(RX_MIN_LENGTH ,7'd027,16'h0040,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
93 |
|
|
RegCPUData U_0_028(CPU_rd_addr ,7'd028,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
94 |
|
|
RegCPUData U_0_029(CPU_rd_apply ,7'd029,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
95 |
|
|
// RegCPUData U_0_030(CPU_rd_grant ,7'd030,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
96 |
|
|
// RegCPUData U_0_031(CPU_rd_dout_l ,7'd031,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
97 |
|
|
// RegCPUData U_0_032(CPU_rd_dout_h ,7'd032,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
98 |
|
|
RegCPUData U_0_033(Line_loop_en ,7'd033,16'h0000,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
99 |
|
|
RegCPUData U_0_034(Speed ,7'd034,16'h0004,Reset,Clk_reg,!WRB,CSB,CA,CD_in);
|
100 |
|
|
|
101 |
|
|
always @ (posedge Clk_reg or posedge Reset)
|
102 |
|
|
if (Reset)
|
103 |
|
|
CD_out <=0;
|
104 |
|
|
else if (!CSB&&WRB)
|
105 |
|
|
case (CA[7:1])
|
106 |
|
|
7'd00: CD_out<=Tx_Hwmark ;
|
107 |
|
|
7'd01: CD_out<=Tx_Lwmark ;
|
108 |
|
|
7'd02: CD_out<=pause_frame_send_en ;
|
109 |
|
|
7'd03: CD_out<=pause_quanta_set ;
|
110 |
|
|
7'd04: CD_out<=IFGset ;
|
111 |
|
|
7'd05: CD_out<=FullDuplex ;
|
112 |
|
|
7'd06: CD_out<=MaxRetry ;
|
113 |
|
|
7'd07: CD_out<=MAC_tx_add_en ;
|
114 |
|
|
7'd08: CD_out<=MAC_tx_add_prom_data ;
|
115 |
|
|
7'd09: CD_out<=MAC_tx_add_prom_add ;
|
116 |
|
|
7'd10: CD_out<=MAC_tx_add_prom_wr ;
|
117 |
|
|
7'd11: CD_out<=tx_pause_en ;
|
118 |
|
|
7'd12: CD_out<=xoff_cpu ;
|
119 |
|
|
7'd13: CD_out<=xon_cpu ;
|
120 |
|
|
7'd14: CD_out<=MAC_rx_add_chk_en ;
|
121 |
|
|
7'd15: CD_out<=MAC_rx_add_prom_data ;
|
122 |
|
|
7'd16: CD_out<=MAC_rx_add_prom_add ;
|
123 |
|
|
7'd17: CD_out<=MAC_rx_add_prom_wr ;
|
124 |
|
|
7'd18: CD_out<=broadcast_filter_en ;
|
125 |
|
|
7'd19: CD_out<=broadcast_bucket_depth ;
|
126 |
|
|
7'd20: CD_out<=broadcast_bucket_interval ;
|
127 |
|
|
7'd21: CD_out<=RX_APPEND_CRC ;
|
128 |
|
|
7'd22: CD_out<=Rx_Hwmark ;
|
129 |
|
|
7'd23: CD_out<=Rx_Lwmark ;
|
130 |
|
|
7'd24: CD_out<=CRC_chk_en ;
|
131 |
|
|
7'd25: CD_out<=RX_IFG_SET ;
|
132 |
|
|
7'd26: CD_out<=RX_MAX_LENGTH ;
|
133 |
|
|
7'd27: CD_out<=RX_MIN_LENGTH ;
|
134 |
|
|
7'd28: CD_out<=CPU_rd_addr ;
|
135 |
|
|
7'd29: CD_out<=CPU_rd_apply ;
|
136 |
|
|
7'd30: CD_out<=CPU_rd_grant ;
|
137 |
|
|
7'd31: CD_out<=CPU_rd_dout[15:0] ;
|
138 |
|
|
7'd32: CD_out<=CPU_rd_dout[31:16] ;
|
139 |
|
|
7'd33: CD_out<=Line_loop_en ;
|
140 |
|
|
7'd34: CD_out<=Speed ;
|
141 |
|
|
default: CD_out<=0 ;
|
142 |
|
|
endcase
|
143 |
|
|
|
144 |
|
|
|
145 |
|
|
endmodule
|
146 |
|
|
|
147 |
|
|
module RegCPUData(
|
148 |
|
|
RegOut,
|
149 |
|
|
CA_reg_set,
|
150 |
|
|
RegInit,
|
151 |
|
|
|
152 |
|
|
Reset,
|
153 |
|
|
Clk,
|
154 |
|
|
CWR_pulse,
|
155 |
|
|
CCSB,
|
156 |
|
|
CA_reg,
|
157 |
|
|
CD_in_reg
|
158 |
|
|
);
|
159 |
|
|
output[15:0] RegOut;
|
160 |
|
|
input[6:0] CA_reg_set;
|
161 |
|
|
input[15:0] RegInit;
|
162 |
|
|
//
|
163 |
|
|
input Reset;
|
164 |
|
|
input Clk;
|
165 |
|
|
input CWR_pulse;
|
166 |
|
|
input CCSB;
|
167 |
|
|
input[7:0] CA_reg;
|
168 |
|
|
input[15:0] CD_in_reg;
|
169 |
|
|
//
|
170 |
|
|
reg[15:0] RegOut;
|
171 |
|
|
|
172 |
|
|
always @(posedge Reset or posedge Clk)
|
173 |
|
|
if(Reset)
|
174 |
|
|
RegOut <=RegInit;
|
175 |
|
|
else if (CWR_pulse && !CCSB && CA_reg[7:1] ==CA_reg_set[6:0])
|
176 |
|
|
RegOut <=CD_in_reg;
|
177 |
|
|
|
178 |
|
|
endmodule
|