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

Subversion Repositories yacc

[/] [yacc/] [trunk/] [rtl/] [yacc2.v] - Blame information for rev 5

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

Line No. Rev Author Line
1 2 tak.sugawa
//Jun.30.2004 blez bgtz bug fix
2
//Jul.7.2004 int bug fix
3
//Jul.11.2004 bgezQ,bltzQ
4
//Apr.2.2005 Change Port Address, change uart interface port
5
//Apr.3.2005 bgtz bug fix
6
//Apr.13.2005 Add stratix2 workaround
7
 
8
`include "define.h"
9
`ifdef RTL_SIMULATION
10
module yacc(clock,Async_Reset,MemoryWData,MWriteFF,data_port_address,
11
           RXD,TXD);
12
        input clock;
13
        input Async_Reset;
14
        output [31:0] MemoryWData;
15
        output [15:0] data_port_address;
16
 
17
 
18
 
19
 
20
        output MWriteFF;
21
        input RXD;
22
        output TXD;
23
`else
24
 
25
module yacc(clock,Async_Reset,     RXD,TXD);
26
        input clock;
27
        input Async_Reset;
28
        input RXD;
29
        output TXD;
30
 
31
`endif
32
 
33
        wire [31:0] MOUT,IRD1;
34
 
35
        wire RegWriteD2;
36
        wire [1:0] A_Right_SELD1;
37
        wire [1:0] RF_inputD2;
38
        wire M_signD1,M_signD2;
39
        wire [1:0] M_access_modeD1,M_access_modeD2;
40
        wire [3:0] ALU_FuncD2;
41
        wire [1:0] Shift_FuncD2;
42
        wire [25:0] IMMD2,IMMD1;
43
        wire [4:0] source_addrD2,target_addrD2;
44
        wire [4:0] source_addrD1,target_addrD1,Shift_amountD2;
45
        wire [4:0] RF_input_addr;
46
        wire [2:0] PC_commandD1;
47
        wire [7:0] uread_port;
48
        wire takenD2;//
49
 
50
`ifdef RAM4K
51
        wire [11:0] DAddress;//
52
        wire [11:0] PC;
53
        reg [11:0] int_address;//interim
54
        reg [11:0] PCD1,PCD2;
55
        reg [15:0] IRD2;
56
        reg [11:0] DAddrD;
57
        wire [11:0] PCCDD;
58
`else
59
        wire [25:0] PC;
60
        wire [25:0] DAddress;//
61
        reg [25:0] int_address;//interim
62
        reg [25:0] PCD1,PCD2;
63
        reg [25:0] IRD2;
64
        reg [25:0] DAddrD;
65
        wire [25:0] PCCDD;
66
`endif
67
 
68
        wire [31:0] memory_indata;//
69
        wire memory_sign;
70
        wire [1:0] memory_access_mode;
71
 
72
        wire [31:0] ea_reg_out;
73
        wire [31:0] regfile_indata,regfile_indata_temp;//
74
        wire reg_compare;
75
        wire beqQ,bneQ,blezQ,bgtzQ;
76
        wire [25:0] IMM;
77
        wire clear_int;
78
        wire jumpQ,branchQQ;
79
        wire [31:0] memory_wdata;
80
        wire [31:0] alu_source,alu_target;
81
        wire [1:0] RRegSelD1;
82
        wire A_Left_SELD1;
83
        wire [1:0] mul_alu_selD2;
84
        wire [3:0] mul_div_funcD2;
85
//registers
86
        reg sync_reset;
87
        wire [31:0] forward_source_reg,forward_target_reg;
88
//      reg [31:0] MOUT_ff;
89
        reg takenD3;
90
        reg int_req;
91
 
92
 
93
        reg beqQQ,bneQQ,blezQQ,bgtzQQ;
94
        reg bgezQQ,bltzQQ;
95
        reg MWriteFF;
96
        wire MWriteD2,MWriteD1;
97
        reg [31:0] MemoryWData;
98
        wire NOP_Signal;
99
 
100
        wire [7:0] control_state;
101
        wire [15:0] data_port_address=DAddrD;
102
        wire [3:0] mult_func;
103
        wire pause_out;
104
        wire Shift_Amount_selD2;
105
        wire source_zero;//Jun.30.2004
106
        wire int_req_uport;
107
        wire uart_write_req;
108
        wire uart_write_done,uart_write_busy;
109
        wire int_stateD1;
110
        wire bgezQ,bltzQ;
111
 
112
decoder d1(.clock(clock),.sync_reset(sync_reset),.MWriteD1(MWriteD1),
113
            .RegWriteD2(RegWriteD2),.A_Right_SELD1(A_Right_SELD1),.RF_inputD2(RF_inputD2),
114
            .RF_input_addr(RF_input_addr),.M_signD1( M_signD1),.M_signD2(M_signD2),
115
            .M_access_modeD1(M_access_modeD1),.M_access_modeD2(M_access_modeD2),
116
            .ALU_FuncD2(ALU_FuncD2),.Shift_FuncD2(Shift_FuncD2),
117
            .source_addrD1(source_addrD1),.target_addrD1(target_addrD1),.IMMD2(IMMD2),
118
            .source_addrD2(source_addrD2),.target_addrD2(target_addrD2),
119
            .Shift_amountD2(Shift_amountD2),.PC_commandD1(PC_commandD1),.IMMD1(IMMD1),.IRD1(IRD1),.takenD3(takenD3),.takenD2(takenD2),.beqQ(beqQ),.bneQ(bneQ),.blezQ(blezQ),.bgtzQ(bgtzQ),
120
            .DAddress(DAddress),.PC(PC),.memory_indata(memory_indata),.MOUT(MOUT),.IMM(IMM),
121
            .branchQQ(branchQQ),.jumpQ(jumpQ),.int_req(int_req),.clear_int(clear_int),
122
            .int_address(int_address),.A_Left_SELD1(A_Left_SELD1),.RRegSelD1(RRegSelD1),
123
            .MWriteD2(MWriteD2),.NOP_Signal(NOP_Signal),.mul_alu_selD2(mul_alu_selD2),
124
            .mul_div_funcD2(mul_div_funcD2),.pause_out(pause_out),.control_state(control_state),
125
            .Shift_Amount_selD2(Shift_Amount_selD2),
126
            .uread_port(uread_port),.int_stateD1(int_stateD1),.bgezQ(bgezQ),.bltzQ(bltzQ),.write_busy(uart_write_busy));
127
 
128
 
129
 
130
pc_module pc1(.clock(clock),.sync_reset(sync_reset),.pc_commandD1(PC_commandD1),.PCC(PC),
131
               .imm(IMM),.ea_reg_source(alu_source),.takenD2(takenD2),.takenD3(takenD3),
132
               .branchQQ(branchQQ),.jumpQ(jumpQ),.NOP_Signal(NOP_Signal),
133
               .control_state(control_state),.IMMD1(IMMD1),.PCCDD(PCCDD));
134
 
135
 
136
 
137
Pipelined_RegFile pipe(.clock(clock),.sync_reset(sync_reset),
138
        .dest_addrD2(RF_input_addr),.source_addr(IMM[25:21]),.target_addr(IMM[20:16]),
139
        .wren(RegWriteD2),.memory_wdata(memory_wdata),
140
        .A_Right_SELD1(A_Right_SELD1),.A_Left_SELD1(A_Left_SELD1),.PCD1(PCD1),
141
        .IMMD1(IMMD1[15:0]),.ALU_FuncD2(ALU_FuncD2),.Shift_FuncD2(Shift_FuncD2),
142
        .Shift_amountD2(Shift_amountD2),.RRegSelD1(RRegSelD1),.MOUT(MOUT),
143
        .RF_inputD2(RF_inputD2),.alu_source(alu_source),.alu_target(alu_target),
144
        .MWriteD2(MWriteD2),.MWriteD1(MWriteD1),.mul_alu_selD2(mul_alu_selD2),
145
        .mul_div_funcD2(mul_div_funcD2),.pause_out(pause_out),
146
        .Shift_Amount_selD2(Shift_Amount_selD2),.int_stateD1(int_stateD1),.PCCDD(PCCDD));
147
 
148
//sync_reset
149
`ifdef Stratix2
150
        always @(posedge clock ) begin//Workaround for stratix2 
151
                  sync_reset <=!Async_Reset;
152
        end
153
`else
154
        always @(posedge clock , negedge Async_Reset) begin
155
                if (!Async_Reset) sync_reset <=1'b1;
156
                else  sync_reset <=!Async_Reset;
157
        end
158
`endif
159
 
160
//PCD1,PCD2
161
        always @(posedge clock) begin
162
                PCD1 <=PC+4;
163
        end
164
 
165
        always @(posedge clock) begin
166
                PCD2 <=PCD1;
167
        end
168
 
169
//
170
        always @(posedge clock) begin
171
        IRD2 <=IRD1;
172
        end
173
 
174
        always @(posedge clock) begin
175
                if (sync_reset) MWriteFF<=1'b0;
176
                else    MWriteFF <=MWriteD2;
177
        end
178
 
179
        assign memory_access_mode=M_access_modeD1;
180
        assign memory_sign=M_signD1;
181
 
182
//Apr.14.2005   assign DAddress=alu_source[25:0]+{ {6{IRD2[15]}},IRD2[15:0]};
183
        assign DAddress=alu_source[25:0]+{ {10{IRD2[15]}},IRD2[15:0]};
184
 
185
//
186
        always @(posedge clock) begin
187
        DAddrD <=DAddress;
188
        end
189
//
190
always @(posedge clock) begin
191
        MemoryWData <=memory_wdata;
192
        end
193
 
194
        assign memory_indata=memory_wdata;
195
 
196
 
197
 
198
 
199
        assign reg_compare=( alu_source==alu_target);
200
 
201
 
202
 
203
        always @(posedge clock) begin
204
           if (!NOP_Signal) begin//Jun.29.2004
205
                              beqQQ<=beqQ;
206
                        bneQQ<=bneQ;
207
                        bgtzQQ<=bgtzQ;
208
                        blezQQ<=blezQ;
209
                              bgezQQ<=bgezQ;//Jul.11.2004
210
                        bltzQQ<=bltzQ;//Jul.11.2004
211
                end
212
        end
213
 
214
        always @( beqQQ ,bneQQ,bgtzQQ,blezQQ,bgezQQ,bltzQQ,reg_compare,alu_source) begin//Jul.11.2004
215
                takenD3=  ( beqQQ   && reg_compare) ||
216
                          ( bneQQ   && !reg_compare) ||
217
                          ( bgtzQQ  && !alu_source[31] && !reg_compare) || //Apr.3.2005 bug fix $s >0 Jun.30.2004
218
                          ( blezQQ  && (alu_source[31]  || reg_compare )) ||
219
                          ( bgezQQ  && (!alu_source[31] || reg_compare )) || //Jul.11.2004 
220
                          ( bltzQQ  && (alu_source[31]  )); //Jul.11.2004//$s <0=Jun.30.2004
221
        end
222
 
223
 
224
 
225
 
226
 
227
        uart_read  uread( .sync_reset(sync_reset),.clk(clock), .rxd(RXD),
228
        .buffer_reg(uread_port),.int_req(int_req_uport));
229
 
230
        uart_write uwite( .sync_reset(sync_reset), .clk(clock), .txd(TXD),.data_in(MemoryWData[7:0]) ,
231
        .write_request(uart_write_req),.write_done(uart_write_done),.write_busy(uart_write_busy));
232
 
233
`ifdef RAM4K
234
        assign uart_write_req= DAddrD[11:0]==12'hfff && MWriteFF;//`UART_WRITE_PORT_ADDRESS ;
235
        always @ (posedge clock) begin
236
                if (sync_reset) int_address<=0;
237
                else if (DAddrD[11:0]==12'h0ff8 & MWriteFF) int_address<=MemoryWData;
238
        end
239
`endif
240
 
241
`ifdef RAM16K
242
        assign uart_write_req= DAddrD==`UART_PORT_ADDRESS && MWriteFF  ;//`UART_WRITE_PORT_ADDRESS ;
243
                always @ (posedge clock) begin
244
                        if (sync_reset) int_address<=0;
245
                        else if (DAddrD==`INTERUPPT_ADDRESS & MWriteFF) int_address<=MemoryWData;
246
        end
247
`endif
248
 
249
`ifdef RAM32K
250
        assign uart_write_req= DAddrD[15:0]==16'h07fff && MWriteFF ;//`UART_WRITE_PORT_ADDRESS ;
251
                always @ (posedge clock) begin
252
                        if (sync_reset) int_address<=0;
253
                        else if (DAddrD==16'h7ff8 & MWriteFF) int_address<=MemoryWData;
254
        end
255
`endif
256
 
257
//state machine
258
//latch with one shot pulse 
259
//clear by clear_int
260
        always @(posedge clock) begin
261
                if (sync_reset) int_req <=1'b0;
262
                else if (clear_int) int_req <=1'b0;// assume one shot(1clk) pulse
263
                else if ( int_req_uport) int_req<=1'b1;//                       
264
        end
265
 
266
endmodule
267
 
268
 

powered by: WebSVN 2.1.0

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