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

Subversion Repositories aemb

[/] [aemb/] [trunk/] [rtl/] [verilog/] [aeMB2_pipe.v] - Diff between revs 191 and 204

Go to most recent revision | Show entire file | Details | Blame | View Log

Rev 191 Rev 204
Line 29... Line 29...
 
 
module aeMB2_pipe (/*AUTOARG*/
module aeMB2_pipe (/*AUTOARG*/
   // Outputs
   // Outputs
   brk_if, gpha, gclk, grst, dena, iena,
   brk_if, gpha, gclk, grst, dena, iena,
   // Inputs
   // Inputs
   bra_ex, dwb_fb, xwb_fb, ich_fb, fet_fb, msr_ex, sys_clk_i,
   bra_ex, dwb_fb, xwb_fb, ich_fb, fet_fb, msr_ex, exc_dwb, exc_iwb,
   sys_int_i, sys_rst_i, sys_ena_i
   exc_ill, sys_clk_i, sys_int_i, sys_rst_i, sys_ena_i
   );
   );
   parameter AEMB_HTX = 1;
   parameter AEMB_HTX = 1;
 
 
   output [1:0] brk_if;
   output [1:0] brk_if;
   input [1:0]   bra_ex;
   input [1:0]   bra_ex;
   input        dwb_fb;
   input        dwb_fb;
   input        xwb_fb;
   input        xwb_fb;
   input        ich_fb;
   input        ich_fb;
   input        fet_fb;
   input        fet_fb;
   input [3:0]   msr_ex;
   input [9:0]   msr_ex;
 
 
   output       gpha,
   output       gpha,
                gclk,
                gclk,
                grst,
                grst,
                dena,
                dena,
                iena;
                iena;
 
 
 
   input [1:0]   exc_dwb;
 
   input        exc_iwb;
 
   input        exc_ill;
 
 
   input        sys_clk_i,
   input        sys_clk_i,
                sys_int_i,
                sys_int_i,
                sys_rst_i,
                sys_rst_i,
                sys_ena_i;
                sys_ena_i;
 
 
Line 75... Line 79...
                               dwb_fb &
                               dwb_fb &
                               sys_ena_i;
                               sys_ena_i;
   // run data side pipeline
   // run data side pipeline
   assign               dena = iena;
   assign               dena = iena;
 
 
   // interrupt process
   // interrupt process - latches onto any interrupt until it is handled
   reg                  int_lat; ///< interrupt latch
   reg                  int_lat; ///< interrupt latch
 
 
   always @(posedge sys_clk_i)
   always @(posedge sys_clk_i)
     if (sys_rst_i) begin
     if (sys_rst_i) begin
        /*AUTORESET*/
        /*AUTORESET*/
Line 88... Line 92...
        // End of automatics
        // End of automatics
     end else begin
     end else begin
        int_lat <= #1 msr_ex[1] & (int_lat | sys_int_i);
        int_lat <= #1 msr_ex[1] & (int_lat | sys_int_i);
     end
     end
 
 
 
   // exception process - exceptions handled immediately
 
   wire                 exc_lat; ///< exception latch
 
   assign exc_lat = exc_ill | exc_dwb[1];
 
 
   always @(posedge gclk)
   always @(posedge gclk)
     if (grst) begin
     if (grst) begin
        /*AUTORESET*/
        /*AUTORESET*/
        // Beginning of autoreset for uninitialized flops
        // Beginning of autoreset for uninitialized flops
        brk_if <= 2'h0;
        brk_if <= 2'h0;
        // End of automatics
        // End of automatics
     end else if (dena) begin
     end else if (dena) begin
        brk_if[0] <= #1 !msr_ex[3] & int_lat; // interrupt & not BIP     
        // TODO: consider MSR[9:8]
 
        brk_if[1] <= #1 exc_lat; // HIGH PRIORITY - exception
 
        brk_if[0] <= #1 !exc_lat & !msr_ex[9] & !msr_ex[3] & int_lat; // LOW PRIORITY - interrupt (not BIP/EIP)
     end
     end
 
 
   // RESET DELAY
   // RESET DELAY
   always @(posedge sys_clk_i)
   always @(posedge sys_clk_i)
     if (sys_rst_i) begin
     if (sys_rst_i) begin
Line 122... Line 132...
        gpha <= #1 !gpha;
        gpha <= #1 !gpha;
     end
     end
 
 
endmodule // aeMB2_pipe
endmodule // aeMB2_pipe
 
 
/*
 
 $Log: not supported by cvs2svn $
 
 Revision 1.3  2008/04/26 01:09:06  sybreon
 
 Passes basic tests. Minor documentation changes to make it compatible with iverilog pre-processor.
 
 
 
 Revision 1.2  2008/04/20 16:34:32  sybreon
 
 Basic version with some features left out.
 
 
 
 Revision 1.1  2008/04/18 00:21:52  sybreon
 
 Initial import.
 
*/
 
 No newline at end of file
 No newline at end of file
 
 
 No newline at end of file
 No newline at end of file

powered by: WebSVN 2.1.0

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