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

Subversion Repositories mblite

[/] [mblite/] [trunk/] [hw/] [core/] [decode.vhd] - Blame information for rev 9

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

Line No. Rev Author Line
1 2 takar
----------------------------------------------------------------------------------------------
2
--
3
--      Input file         : decode.vhd
4
--      Design name        : decode
5
--      Author             : Tamar Kranenburg
6
--      Company            : Delft University of Technology
7
--                         : Faculty EEMCS, Department ME&CE
8
--                         : Systems and Circuits group
9
--
10
--      Description        : This combined register file and decoder uses three Dual Port
11
--                           read after write Random Access Memory components. Every clock
12
--                           cycle three data values can be read (ra, rb and rd) and one value
13
--                           can be stored.
14
--
15
----------------------------------------------------------------------------------------------
16
 
17 8 takar
library ieee;
18
use ieee.std_logic_1164.all;
19
use ieee.std_logic_unsigned.all;
20 2 takar
 
21 8 takar
library mblite;
22
use mblite.config_Pkg.all;
23
use mblite.core_Pkg.all;
24
use mblite.std_Pkg.all;
25 2 takar
 
26 8 takar
entity decode is generic
27 2 takar
(
28
    G_INTERRUPT  : boolean := CFG_INTERRUPT;
29
    G_USE_HW_MUL : boolean := CFG_USE_HW_MUL;
30
    G_USE_BARREL : boolean := CFG_USE_BARREL;
31
    G_DEBUG      : boolean := CFG_DEBUG
32
);
33 8 takar
port
34 2 takar
(
35 8 takar
    decode_o : out decode_out_type;
36
    gprf_o   : out gprf_out_type;
37
    decode_i : in decode_in_type;
38
    ena_i    : in std_logic;
39
    rst_i    : in std_logic;
40
    clk_i    : in std_logic
41 2 takar
);
42 8 takar
end decode;
43 2 takar
 
44 8 takar
architecture arch of decode is
45 2 takar
 
46 8 takar
    type decode_reg_type is record
47
        instruction          : std_logic_vector(CFG_IMEM_WIDTH - 1 downto 0);
48
        program_counter      : std_logic_vector(CFG_IMEM_SIZE - 1 downto 0);
49
        immediate            : std_logic_vector(15 downto 0);
50
        is_immediate         : std_logic;
51 6 takar
        msr_interrupt_enable : std_logic;
52 8 takar
        interrupt            : std_logic;
53
        delay_interrupt      : std_logic;
54
    end record;
55 2 takar
 
56 8 takar
    signal r, rin     : decode_out_type;
57
    signal reg, regin : decode_reg_type;
58 2 takar
 
59 8 takar
    signal wb_dat_d : std_logic_vector(CFG_DMEM_WIDTH - 1 downto 0);
60 2 takar
 
61 8 takar
begin
62 2 takar
 
63
    decode_o.imm <= r.imm;
64
 
65
    decode_o.ctrl_ex <= r.ctrl_ex;
66
    decode_o.ctrl_mem <= r.ctrl_mem;
67 8 takar
    decode_o.ctrl_wrb <= r.ctrl_wrb;
68 2 takar
 
69
    decode_o.reg_a <= r.reg_a;
70
    decode_o.reg_b <= r.reg_b;
71
    decode_o.hazard <= r.hazard;
72
    decode_o.program_counter <= r.program_counter;
73
 
74
    decode_o.fwd_dec_result <= r.fwd_dec_result;
75
    decode_o.fwd_dec <= r.fwd_dec;
76
 
77 8 takar
    decode_comb: process(decode_i,decode_i.ctrl_wrb,
78
                         decode_i.ctrl_mem_wrb,
79
                         decode_i.instruction,
80
                         decode_i.ctrl_mem_wrb.transfer_size,
81 2 takar
                         r,r.ctrl_ex,r.ctrl_mem,
82 8 takar
                         r.ctrl_mem.transfer_size,r.ctrl_wrb,
83
                         r.ctrl_wrb.reg_d,
84 2 takar
                         r.fwd_dec,reg)
85
 
86 8 takar
        variable v : decode_out_type;
87
        variable v_reg : decode_reg_type;
88
        variable opcode : std_logic_vector(5 downto 0);
89
        variable instruction : std_logic_vector(CFG_IMEM_WIDTH - 1 downto 0);
90
        variable program_counter : std_logic_vector(CFG_IMEM_SIZE - 1 downto 0);
91
        variable mem_result : std_logic_vector(CFG_DMEM_WIDTH - 1 downto 0);
92 2 takar
 
93 8 takar
    begin
94 2 takar
        v := r;
95
        v_reg := reg;
96
 
97
        -- Default register values (NOP)
98 8 takar
        v_reg.immediate := (others => '0');
99 2 takar
        v_reg.is_immediate := '0';
100
        v_reg.program_counter := decode_i.program_counter;
101
        v_reg.instruction := decode_i.instruction;
102
 
103 8 takar
        if decode_i.ctrl_mem_wrb.mem_read = '1' then
104
            mem_result := align_mem_load(decode_i.mem_result, decode_i.ctrl_mem_wrb.transfer_size, decode_i.alu_result(1 downto 0));
105
        else
106 2 takar
            mem_result := decode_i.alu_result;
107 8 takar
        end if;
108 2 takar
 
109
        wb_dat_d <= mem_result;
110
 
111 8 takar
        if G_INTERRUPT = true then
112 2 takar
            v_reg.delay_interrupt := '0';
113 8 takar
        end if;
114 2 takar
 
115 8 takar
        if CFG_REG_FWD_WRB = true then
116 2 takar
            v.fwd_dec_result    := mem_result;
117 8 takar
            v.fwd_dec           := decode_i.ctrl_wrb;
118
        else
119
            v.fwd_dec_result    := (others => '0');
120
            v.fwd_dec.reg_d     := (others => '0');
121 2 takar
            v.fwd_dec.reg_write := '0';
122 8 takar
        end if;
123 2 takar
 
124 8 takar
        if (not decode_i.flush_id and r.ctrl_mem.mem_read and (compare(decode_i.instruction(20 downto 16), r.ctrl_wrb.reg_d) or compare(decode_i.instruction(15 downto 11), r.ctrl_wrb.reg_d))) = '1' then
125 2 takar
        -- A hazard occurred on register a or b
126
 
127
            -- set current instruction and program counter to 0
128 8 takar
            instruction := (others => '0');
129
            program_counter := (others => '0');
130 2 takar
 
131
            v.hazard := '1';
132
 
133 8 takar
        elsif CFG_MEM_FWD_WRB = false and (not decode_i.flush_id and r.ctrl_mem.mem_read and compare(decode_i.instruction(25 downto 21), r.ctrl_wrb.reg_d)) = '1' then
134 2 takar
        -- A hazard occurred on register d
135
 
136
            -- set current instruction and program counter to 0
137 8 takar
            instruction := (others => '0');
138
            program_counter := (others => '0');
139 2 takar
 
140
            v.hazard := '1';
141
 
142 8 takar
        elsif r.hazard = '1' then
143 2 takar
        -- Recover from hazard. Insert latched instruction
144
 
145
            instruction := reg.instruction;
146
            program_counter := reg.program_counter;
147
            v.hazard := '0';
148
 
149 8 takar
        else
150 2 takar
 
151
            instruction := decode_i.instruction;
152
            program_counter := decode_i.program_counter;
153
            v.hazard := '0';
154
 
155 8 takar
        end if;
156 2 takar
 
157
        v.program_counter := program_counter;
158 8 takar
        opcode := instruction(31 downto 26);
159
        v.ctrl_wrb.reg_d := instruction(25 downto 21);
160
        v.reg_a := instruction(20 downto 16);
161
        v.reg_b := instruction(15 downto 11);
162 2 takar
 
163
        -- SET IMM value
164 8 takar
        if reg.is_immediate = '1' then
165
            v.imm := reg.immediate & instruction(15 downto 0);
166
        else
167
            v.imm := sign_extend(instruction(15 downto 0), instruction(15), 32);
168
        end if;
169 2 takar
 
170
        -- Register if an interrupt occurs
171 8 takar
        if G_INTERRUPT = true then
172
            if v_reg.msr_interrupt_enable = '1' and decode_i.interrupt = '1' then
173 2 takar
                v_reg.interrupt := '1';
174
                v_reg.msr_interrupt_enable := '0';
175 8 takar
            end if;
176
        end if;
177 2 takar
 
178
        v.ctrl_ex.alu_op := ALU_ADD;
179
        v.ctrl_ex.alu_src_a := ALU_SRC_REGA;
180
        v.ctrl_ex.alu_src_b := ALU_SRC_REGB;
181
        v.ctrl_ex.operation := '0';
182
        v.ctrl_ex.carry := CARRY_ZERO;
183 8 takar
        v.ctrl_ex.carry_keep := CARRY_KEEP;
184 2 takar
        v.ctrl_ex.delay := '0';
185
        v.ctrl_ex.branch_cond := NOP;
186
        v.ctrl_mem.mem_write := '0';
187
        v.ctrl_mem.transfer_size := WORD;
188
        v.ctrl_mem.mem_read := '0';
189 8 takar
        v.ctrl_wrb.reg_write := '0';
190 2 takar
 
191 8 takar
        if G_INTERRUPT = true and (v_reg.interrupt = '1' and reg.delay_interrupt = '0' and decode_i.flush_id = '0' and v.hazard = '0' and r.ctrl_ex.delay = '0' and reg.is_immediate = '0') then
192 2 takar
        -- IF an interrupt occured
193
        --    AND the current instruction is not a branch or return instruction,
194
        --    AND the current instruction is not in a delay slot,
195
        --    AND this is instruction is not preceded by an IMM instruction, than handle the interrupt.
196
            v_reg.msr_interrupt_enable := '0';
197
            v_reg.interrupt := '0';
198
 
199 8 takar
            v.reg_a := (others => '0');
200
            v.reg_b := (others => '0');
201 2 takar
 
202
            v.imm   := X"00000010";
203 8 takar
            v.ctrl_wrb.reg_d := "01110";
204 2 takar
 
205
            v.ctrl_ex.branch_cond := BNC;
206
            v.ctrl_ex.alu_src_a := ALU_SRC_ZERO;
207
            v.ctrl_ex.alu_src_b := ALU_SRC_IMM;
208 8 takar
            v.ctrl_wrb.reg_write := '1';
209 2 takar
 
210 8 takar
        elsif (decode_i.flush_id or v.hazard) = '1' then
211 2 takar
            -- clearing these registers is not necessary, but facilitates debugging.
212
            -- On the other hand performance improves when disabled.
213 8 takar
            if G_DEBUG = true then
214
                v.program_counter := (others => '0');
215
                v.ctrl_wrb.reg_d  := (others => '0');
216
                v.reg_a           := (others => '0');
217
                v.reg_b           := (others => '0');
218
                v.imm             := (others => '0');
219
            end if;
220 2 takar
 
221 8 takar
        elsif is_zero(opcode(5 downto 4)) = '1' then
222 2 takar
        -- ADD, SUBTRACT OR COMPARE
223
 
224
            -- Alu operation
225
            v.ctrl_ex.alu_op := ALU_ADD;
226
 
227
            -- Source operand A
228 8 takar
            if opcode(0) = '1' then
229 2 takar
                v.ctrl_ex.alu_src_a := ALU_SRC_NOT_REGA;
230 8 takar
            else
231 2 takar
                v.ctrl_ex.alu_src_a := ALU_SRC_REGA;
232 8 takar
            end if;
233 2 takar
 
234
            -- Source operand B
235 8 takar
            if opcode(3) = '1' then
236 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_IMM;
237 8 takar
            else
238 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_REGB;
239 8 takar
            end if;
240 2 takar
 
241 8 takar
            if (compare(opcode, "000101") and instruction(1)) = '1' then
242 2 takar
                v.ctrl_ex.operation := '1';
243 8 takar
            end if;
244 2 takar
 
245
            -- Carry
246 8 takar
            case opcode(1 downto 0) is
247
                when "00" => v.ctrl_ex.carry := CARRY_ZERO;
248
                when "01" => v.ctrl_ex.carry := CARRY_ONE;
249
                when others => v.ctrl_ex.carry := CARRY_ALU;
250
            end case;
251 2 takar
 
252
            -- Carry keep
253 8 takar
            if opcode(2) = '1' then
254 2 takar
                v.ctrl_ex.carry_keep := CARRY_KEEP;
255 8 takar
            else
256 2 takar
                v.ctrl_ex.carry_keep := CARRY_NOT_KEEP;
257 8 takar
            end if;
258 2 takar
 
259
            -- Flag writeback if reg_d != 0
260 8 takar
            v.ctrl_wrb.reg_write := is_not_zero(v.ctrl_wrb.reg_d);
261 2 takar
 
262 8 takar
        elsif (compare(opcode(5 downto 2), "1000") or compare(opcode(5 downto 2), "1010")) = '1' then
263 2 takar
        -- OR, AND, XOR, ANDN
264
        -- ORI, ANDI, XORI, ANDNI
265 8 takar
            case opcode(1 downto 0) is
266
                when "00" => v.ctrl_ex.alu_op := ALU_OR;
267
                when "10" => v.ctrl_ex.alu_op := ALU_XOR;
268
                when others => v.ctrl_ex.alu_op := ALU_AND;
269
            end case;
270 2 takar
 
271 8 takar
            if opcode(3) = '1' and compare(opcode(1 downto 0), "11") = '1' then
272 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_NOT_IMM;
273 8 takar
            elsif opcode(3) = '1' then
274 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_IMM;
275 8 takar
            elsif opcode(3) = '0' and compare(opcode(1 downto 0), "11") = '1' then
276 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_NOT_REGB;
277 8 takar
            else
278 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_REGB;
279 8 takar
            end if;
280 2 takar
 
281
            -- Flag writeback if reg_d != 0
282 8 takar
            v.ctrl_wrb.reg_write := is_not_zero(v.ctrl_wrb.reg_d);
283 2 takar
 
284 8 takar
        elsif compare(opcode, "101100") = '1' then
285 2 takar
        -- IMM instruction
286 8 takar
            v_reg.immediate := instruction(15 downto 0);
287 2 takar
            v_reg.is_immediate := '1';
288
 
289 8 takar
        elsif compare(opcode, "100100") = '1' then
290 2 takar
        -- SHIFT, SIGN EXTEND
291 8 takar
            if compare(instruction(6 downto 5), "11") = '1' then
292
                if instruction(0) = '1' then
293 2 takar
                    v.ctrl_ex.alu_op:= ALU_SEXT16;
294 8 takar
                else
295 2 takar
                    v.ctrl_ex.alu_op:= ALU_SEXT8;
296 8 takar
                end if;
297
            else
298 2 takar
                v.ctrl_ex.alu_op:= ALU_SHIFT;
299 8 takar
                v.ctrl_ex.carry_keep := CARRY_NOT_KEEP;
300
                case instruction(6 downto 5) is
301
                    when "10"   => v.ctrl_ex.carry := CARRY_ZERO;
302
                    when "01"   => v.ctrl_ex.carry := CARRY_ALU;
303
                    when others => v.ctrl_ex.carry := CARRY_ARITH;
304
                end case;
305
            end if;
306 2 takar
 
307
            -- Flag writeback if reg_d != 0
308 8 takar
            v.ctrl_wrb.reg_write := is_not_zero(v.ctrl_wrb.reg_d);
309 2 takar
 
310 8 takar
        elsif (compare(opcode, "100110") or compare(opcode, "101110")) = '1' then
311 2 takar
        -- BRANCH UNCONDITIONAL
312
 
313
            v.ctrl_ex.branch_cond := BNC;
314
 
315 8 takar
            if opcode(3) = '1' then
316 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_IMM;
317 8 takar
            else
318 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_REGB;
319 8 takar
            end if;
320 2 takar
 
321
            -- WRITE THE RESULT ALSO TO REGISTER D
322 8 takar
            if v.reg_a(2) = '1' then
323 2 takar
                -- Flag writeback if reg_d != 0
324 8 takar
                v.ctrl_wrb.reg_write := is_not_zero(v.ctrl_wrb.reg_d);
325
            end if;
326 2 takar
 
327 8 takar
            if v.reg_a(3) = '1' then
328 2 takar
                v.ctrl_ex.alu_src_a := ALU_SRC_ZERO;
329 8 takar
            else
330 2 takar
                v.ctrl_ex.alu_src_a := ALU_SRC_PC;
331 8 takar
            end if;
332 2 takar
 
333 8 takar
            if G_INTERRUPT = true then
334 2 takar
                v_reg.delay_interrupt := '1';
335 8 takar
            end if;
336 2 takar
            v.ctrl_ex.delay := v.reg_a(4);
337
 
338 8 takar
        elsif (compare(opcode, "100111") or compare(opcode, "101111")) = '1' then
339 2 takar
        -- BRANCH CONDITIONAL
340
            v.ctrl_ex.alu_op := ALU_ADD;
341
            v.ctrl_ex.alu_src_a := ALU_SRC_PC;
342
 
343 8 takar
            if opcode(3) = '1' then
344 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_IMM;
345 8 takar
            else
346 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_REGB;
347 8 takar
            end if;
348 2 takar
 
349 8 takar
            case v.ctrl_wrb.reg_d(2 downto 0) is
350
                when "000"  => v.ctrl_ex.branch_cond := BEQ;
351
                when "001"  => v.ctrl_ex.branch_cond := BNE;
352
                when "010"  => v.ctrl_ex.branch_cond := BLT;
353
                when "011"  => v.ctrl_ex.branch_cond := BLE;
354
                when "100"  => v.ctrl_ex.branch_cond := BGT;
355
                when others => v.ctrl_ex.branch_cond := BGE;
356
            end case;
357 2 takar
 
358 8 takar
            if G_INTERRUPT = true then
359 2 takar
                v_reg.delay_interrupt := '1';
360 8 takar
            end if;
361
            v.ctrl_ex.delay := v.ctrl_wrb.reg_d(4);
362 2 takar
 
363 8 takar
        elsif compare(opcode, "101101") = '1' then
364 2 takar
        -- RETURN
365
 
366
            v.ctrl_ex.branch_cond := BNC;
367
            v.ctrl_ex.alu_src_b := ALU_SRC_IMM;
368
            v.ctrl_ex.delay := '1';
369
 
370 8 takar
            if G_INTERRUPT = true then
371
                if v.ctrl_wrb.reg_d(0) = '1' then
372 2 takar
                    v_reg.msr_interrupt_enable := '1';
373 8 takar
                end if;
374 2 takar
                v_reg.delay_interrupt := '1';
375 8 takar
            end if;
376 2 takar
 
377 8 takar
        elsif compare(opcode(5 downto 4), "11") = '1' then
378 2 takar
            -- SW, LW
379
            v.ctrl_ex.alu_op := ALU_ADD;
380
            v.ctrl_ex.alu_src_a := ALU_SRC_REGA;
381
 
382 8 takar
            if opcode(3) = '1' then
383 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_IMM;
384 8 takar
            else
385 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_REGB;
386 8 takar
            end if;
387 2 takar
 
388
            v.ctrl_ex.carry := CARRY_ZERO;
389
 
390 8 takar
            if opcode(2) = '1' then
391 2 takar
                -- Store
392
                v.ctrl_mem.mem_write := '1';
393 8 takar
                v.ctrl_mem.mem_read  := '0';
394
                v.ctrl_wrb.reg_write := '0';
395
            else
396 2 takar
                -- Load
397
                v.ctrl_mem.mem_write := '0';
398 8 takar
                v.ctrl_mem.mem_read  := '1';
399
                v.ctrl_wrb.reg_write := is_not_zero(v.ctrl_wrb.reg_d);
400
            end if;
401 2 takar
 
402 8 takar
            case opcode(1 downto 0) is
403
                when "00" => v.ctrl_mem.transfer_size := BYTE;
404
                when "01" => v.ctrl_mem.transfer_size := HALFWORD;
405
                when others => v.ctrl_mem.transfer_size := WORD;
406
            end case;
407 2 takar
 
408
            v.ctrl_ex.delay := '0';
409
 
410 8 takar
        elsif G_USE_HW_MUL = true and (compare(opcode, "010000") or compare(opcode, "011000")) = '1' then
411 2 takar
 
412
            v.ctrl_ex.alu_op := ALU_MUL;
413
 
414 8 takar
            if opcode(3) = '1' then
415 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_IMM;
416 8 takar
            else
417 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_REGB;
418 8 takar
            end if;
419 2 takar
 
420 8 takar
            v.ctrl_wrb.reg_write := is_not_zero(v.ctrl_wrb.reg_d);
421 2 takar
 
422 8 takar
        elsif G_USE_BARREL = true and (compare(opcode, "010001") or compare(opcode, "011001")) = '1' then
423 2 takar
 
424
            v.ctrl_ex.alu_op := ALU_BS;
425
 
426 8 takar
            if opcode(3) = '1' then
427 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_IMM;
428 8 takar
            else
429 2 takar
                v.ctrl_ex.alu_src_b := ALU_SRC_REGB;
430 8 takar
            end if;
431 2 takar
 
432 8 takar
            v.ctrl_wrb.reg_write := is_not_zero(v.ctrl_wrb.reg_d);
433 2 takar
 
434 8 takar
        else
435 2 takar
            -- UNKNOWN OPCODE
436 8 takar
            null;
437
        end if;
438 2 takar
 
439
        rin <= v;
440
        regin <= v_reg;
441
 
442 8 takar
    end process;
443 2 takar
 
444 8 takar
    decode_seq: process(clk_i)
445
        procedure proc_reset_decode is
446
        begin
447
            r.reg_a                  <= (others => '0');
448
            r.reg_b                  <= (others => '0');
449
            r.imm                    <= (others => '0');
450
            r.program_counter        <= (others => '0');
451
            r.hazard                 <= '0';
452
            r.ctrl_ex.alu_op         <= ALU_ADD;
453
            r.ctrl_ex.alu_src_a      <= ALU_SRC_REGA;
454
            r.ctrl_ex.alu_src_b      <= ALU_SRC_REGB;
455
            r.ctrl_ex.operation      <= '0';
456
            r.ctrl_ex.carry          <= CARRY_ZERO;
457
            r.ctrl_ex.carry_keep     <= CARRY_NOT_KEEP;
458
            r.ctrl_ex.delay          <= '0';
459
            r.ctrl_ex.branch_cond    <= NOP;
460
            r.ctrl_mem.mem_write     <= '0';
461
            r.ctrl_mem.transfer_size <= WORD;
462
            r.ctrl_mem.mem_read      <= '0';
463
            r.ctrl_wrb.reg_d          <= (others => '0');
464
            r.ctrl_wrb.reg_write      <= '0';
465
            r.fwd_dec_result         <= (others => '0');
466
            r.fwd_dec.reg_d          <= (others => '0');
467
            r.fwd_dec.reg_write      <= '0';
468
            reg.instruction          <= (others => '0');
469
            reg.program_counter      <= (others => '0');
470
            reg.immediate            <= (others => '0');
471
            reg.is_immediate         <= '0';
472
            reg.msr_interrupt_enable <= '1';
473
            reg.interrupt            <= '0';
474
            reg.delay_interrupt      <= '0';
475
        end procedure proc_reset_decode;
476
    begin
477
        if rising_edge(clk_i) then
478
            if rst_i = '1' then
479 2 takar
                proc_reset_decode;
480 8 takar
            elsif ena_i = '1' then
481 2 takar
                r <= rin;
482
                reg <= regin;
483 8 takar
            end if;
484
        end if;
485
    end process;
486 2 takar
 
487 8 takar
    gprf0 : gprf port map
488 2 takar
    (
489
        gprf_o         => gprf_o,
490
        gprf_i.adr_a_i => rin.reg_a,
491
        gprf_i.adr_b_i => rin.reg_b,
492 8 takar
        gprf_i.adr_d_i => rin.ctrl_wrb.reg_d,
493 2 takar
        gprf_i.dat_w_i => wb_dat_d,
494 8 takar
        gprf_i.adr_w_i => decode_i.ctrl_wrb.reg_d,
495
        gprf_i.wre_i   => decode_i.ctrl_wrb.reg_write,
496 2 takar
        ena_i          => ena_i,
497
        clk_i          => clk_i
498
    );
499 8 takar
end arch;

powered by: WebSVN 2.1.0

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