From 5eb407d8d1e279127eefe771948e5a63f668f65c Mon Sep 17 00:00:00 2001
From: "Wesley W. Terpstra" <w.terpstra@gsi.de>
Date: Fri, 1 Mar 2013 11:42:08 +0100
Subject: [PATCH] lm32: add missing wires to silence warnings

In Verilog, an "assign x = y;" will cause a warning in Quartus if x was not defined.
For example,
  Warning (10236): Verilog HDL Implicit Net warning at lm32_allprofiles.v(45398): created implicit net for "multiply"
This patch defines all such nets.

Also, the CSR width is too narrow by default (CFG2 must fit).
---
 .../wb_lm32/generated/lm32_allprofiles.v      | 13335 ++++++++--------
 modules/wishbone/wb_lm32/src/lm32_cpu.v       |     6 +
 modules/wishbone/wb_lm32/src/lm32_decoder.v   |    73 +-
 modules/wishbone/wb_lm32/src/lm32_include.v   |     2 +-
 modules/wishbone/wb_lm32/src/lm32_interrupt.v |     3 +
 5 files changed, 7072 insertions(+), 6347 deletions(-)

diff --git a/modules/wishbone/wb_lm32/generated/lm32_allprofiles.v b/modules/wishbone/wb_lm32/generated/lm32_allprofiles.v
index e59b37b1..9542aaa9 100644
--- a/modules/wishbone/wb_lm32/generated/lm32_allprofiles.v
+++ b/modules/wishbone/wb_lm32/generated/lm32_allprofiles.v
@@ -53,16 +53,6 @@
 
   
 
-  
-
-	  
-
-	  
-
-	  
-
-	  
-
 	  
 
 	  
@@ -88,12 +78,13 @@
 	  
 
 	  
-
+	 
+	 
+	 
+	 
 	  
-
 	  
-
-	 
+	
 
  
 
@@ -231,25 +222,24 @@
 
 
   
-
-  
-
  
 
+
  
 
 
 
   
+ 
 
-  
 
- 
- 
+  
  
 
 
+ 
 
+ 
 
 
 
@@ -352,47 +342,27 @@
 
 
   
-
-  
-
-  
-
- 
- 
-                   
-                     
-
                    
                      
 
 
-
-
-
-  
-
-  
-
   
+                   
+                     
 
-  
 
   
 
   
 
-  
+ 
 
-  
+ 
 
-  
 
-  
 
   
 
- 
-
   
 
   
@@ -401,8 +371,6 @@
 
   
 
- 
-
   
 
   
@@ -410,19 +378,28 @@
   
 
   
+                      
+                    
 
-  
 
   
 
   
+                     
+                     
 
-  
 
   
+                     
+                     
+                     
+                     
+                     
+                     
+                     
+                     
 
  
- 
 
 
   
@@ -580,7 +557,7 @@
 
 
 
-module lm32_top_full_debug (
+module lm32_top_full (
     
     clk_i,
     rst_i,
@@ -737,15 +714,14 @@ wire   [ (2-1):0] D_BTE_O;
  
   
 
-
-wire [ 7:0] jtag_reg_d;
-wire [ 7:0] jtag_reg_q;
-wire jtag_update;
-wire [2:0] jtag_reg_addr_d;
-wire [2:0] jtag_reg_addr_q;
-wire jtck;
-wire jrstn;
+  
+  
  
+  
+  
+ 
+ 
+
 
 
 
@@ -824,7 +800,7 @@ endfunction
 
    
 
-lm32_cpu_full_debug cpu (
+lm32_cpu_full cpu (
     
     .clk_i                 (clk_i),
   
@@ -845,13 +821,12 @@ lm32_cpu_full_debug cpu (
 
      
   
-
     
-    .jtag_clk              (jtck),
-    .jtag_update           (jtag_update),
-    .jtag_reg_q            (jtag_reg_q),
-    .jtag_reg_addr_q       (jtag_reg_addr_q),
- 
+                  
+               
+                
+           
+
 
   
 
@@ -880,10 +855,9 @@ lm32_cpu_full_debug cpu (
 
 
   
+                
+           
 
-    .jtag_reg_d            (jtag_reg_d),
-    .jtag_reg_addr_d       (jtag_reg_addr_d),
- 
 
       
                 
@@ -918,21 +892,20 @@ lm32_cpu_full_debug cpu (
     .D_BTE_O               (D_BTE_O)
     );
    
-  
-		   
+  		   
 
-jtag_cores jtag_cores (
+  
     
-    .reg_d                 (jtag_reg_d),
-    .reg_addr_d            (jtag_reg_addr_d),
+                     
+                
     
-    .reg_update            (jtag_update),
-    .reg_q                 (jtag_reg_q),
-    .reg_addr_q            (jtag_reg_addr_q),
-    .jtck                  (jtck),
-    .jrstn                 (jrstn)
-    );
- 
+                
+                     
+                
+                      
+                     
+    
+
         
    
 endmodule
@@ -1152,7 +1125,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -1304,7 +1277,7 @@ endmodule
 
 
 
-module lm32_mc_arithmetic_full_debug (
+module lm32_mc_arithmetic_full (
     
     clk_i,
     rst_i,
@@ -1833,7 +1806,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -1970,7 +1943,7 @@ endmodule
 
 
 
-module lm32_cpu_full_debug (
+module lm32_cpu_full (
     
     clk_i,
   
@@ -1991,13 +1964,12 @@ module lm32_cpu_full_debug (
 
      
   
-
     
-    jtag_clk,
-    jtag_update, 
-    jtag_reg_q,
-    jtag_reg_addr_q,
- 
+    
+     
+    
+    
+
 
   
 
@@ -2026,10 +1998,9 @@ module lm32_cpu_full_debug (
 
 
   
+    
+    
 
-    jtag_reg_d,
-    jtag_reg_addr_d,
- 
 
       
     
@@ -2070,9 +2041,8 @@ module lm32_cpu_full_debug (
 
 parameter eba_reset =  32'h00000000;                           
   
+                            
 
-parameter deba_reset =  32'h10000000;                         
- 
 
 
   
@@ -2108,11 +2078,11 @@ parameter dcache_limit =  32'h7fffffff;
 
 
   
+                          
 
-parameter watchpoints =  32'h4;                       
- 
-   
 
+parameter watchpoints = 0;
+ 
 
   
                           
@@ -2154,12 +2124,11 @@ input [ (32-1):0] interrupt;
     
 
   
+                                  
+                               
+                
+  
 
-input jtag_clk;                                 
-input jtag_update;                              
-input [ 7:0] jtag_reg_q;              
-input [2:0] jtag_reg_addr_q;
- 
 
 
   
@@ -2199,12 +2168,11 @@ input D_RTY_I;
 
 
   
+  
+    
+  
+    
 
-output [ 7:0] jtag_reg_d;
-wire   [ 7:0] jtag_reg_d;
-output [2:0] jtag_reg_addr_d;
-wire   [2:0] jtag_reg_addr_d;
- 
 
 
   
@@ -2285,6 +2253,9 @@ reg load_x;
 reg load_m;
 wire load_q_x;
 wire store_q_x;
+wire q_m;
+wire load_q_m;
+wire store_q_m;
 wire store_d;                                   
 reg store_x;
 reg store_m;
@@ -2316,6 +2287,7 @@ wire x_result_sel_csr_d;
 reg x_result_sel_csr_x;
   
 
+wire q_d;
 wire x_result_sel_mc_arith_d;                   
 reg x_result_sel_mc_arith_x;
  
@@ -2384,15 +2356,14 @@ wire [ (5-1):0] write_idx_d;
 reg [ (5-1):0] write_idx_x;            
 reg [ (5-1):0] write_idx_m;
 reg [ (5-1):0] write_idx_w;
-wire [ (5-1):0] csr_d;                     
-reg  [ (5-1):0] csr_x;                  
+wire [ (4 -1):0] csr_d;                     
+reg  [ (4 -1):0] csr_x;                  
 wire [ (3-1):0] condition_d;         
 reg [ (3-1):0] condition_x;          
   
+                                    
+                                     
 
-wire break_d;                                   
-reg break_x;                                    
- 
 
 wire scall_d;                                   
 reg scall_x;    
@@ -2405,16 +2376,14 @@ reg eret_m;
 
 
   
-
-wire bret_d;                                    
-reg bret_x;
-wire bret_q_x;
-reg bret_m;
-  
+                                     
+ 
+ 
+ 
+ 
  
 
 
- 
 
 wire csr_write_enable_d;                        
 reg csr_write_enable_x;
@@ -2620,32 +2589,25 @@ wire stall_wb_load;
 
 
   
-
-  
-
-wire [ (32-1):0] jtx_csr_read_data;        
-wire [ (32-1):0] jrx_csr_read_data;        
  
+          
+          
 
+ 
+                      
+        
+                    
+                           
   
-
-wire jtag_csr_write_enable;                     
-wire [ (32-1):0] jtag_csr_write_data;      
-wire [ (5-1):0] jtag_csr;                  
-wire jtag_read_enable;                          
-wire [ 7:0] jtag_read_data;
-wire jtag_write_enable;
-wire [ 7:0] jtag_write_data;
-wire [ (32-1):0] jtag_address;
-wire jtag_access_complete;
  
-
   
-
-wire jtag_break;                                
+  
  
 
  
+                                 
+
+
 
 
 
@@ -2678,9 +2640,8 @@ wire kill_w;
 
 reg [ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8] eba;                 
   
+                  
 
-reg [ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8] deba;                
- 
 
 reg [ (3-1):0] eid_x;                      
   
@@ -2690,39 +2651,36 @@ reg [ (3-1):0] eid_x;
 
 
   
-
-  
-
-wire dc_ss;                                     
  
+                                      
 
-wire dc_re;                                     
-wire exception_x;                               
-reg exception_m;                                
-wire debug_exception_x;                         
-reg debug_exception_m;
-reg debug_exception_w;
-wire debug_exception_q_w;
-wire non_debug_exception_x;                     
-reg non_debug_exception_m;
-reg non_debug_exception_w;
-wire non_debug_exception_q_w;
+                                      
+ 
  
                                 
+                                 
+                          
+ 
+ 
+ 
+                      
  
  
  
 
 
+wire exception_x;                               
+reg exception_m;
+reg exception_w;
+wire exception_q_w;
+ 
 
-  
 
   
-
-wire reset_exception;                           
  
+                            
+
 
- 
 
   
 
@@ -2730,10 +2688,9 @@ wire interrupt_exception;
  
 
   
+                       
+                       
 
-wire breakpoint_exception;                      
-wire watchpoint_exception;                      
- 
 
   
 
@@ -2817,7 +2774,7 @@ endfunction
 
 
 
-lm32_instruction_unit_full_debug #(
+lm32_instruction_unit_full #(
     .associativity          (icache_associativity),
     .sets                   (icache_sets),
     .bytes_per_line         (icache_bytes_per_line),
@@ -2876,12 +2833,11 @@ lm32_instruction_unit_full_debug #(
  
 
   
+           
+          
+            
+               
 
-    .jtag_read_enable       (jtag_read_enable),
-    .jtag_write_enable      (jtag_write_enable),
-    .jtag_write_data        (jtag_write_data),
-    .jtag_address           (jtag_address),
- 
 
     
     
@@ -2917,10 +2873,9 @@ lm32_instruction_unit_full_debug #(
  
 
   
+             
+       
 
-    .jtag_read_data         (jtag_read_data),
-    .jtag_access_complete   (jtag_access_complete),
- 
 
   
 
@@ -2936,7 +2891,7 @@ lm32_instruction_unit_full_debug #(
     );
 
 
-lm32_decoder_full_debug decoder (
+lm32_decoder_full decoder (
     
     .instruction            (instruction_d),
     
@@ -3017,16 +2972,14 @@ lm32_decoder_full_debug decoder (
     .branch_reg             (branch_reg_d),
     .condition              (condition_d),
   
+               
 
-    .break_opcode           (break_d),
- 
 
     .scall                  (scall_d),
     .eret                   (eret_d),
   
+                       
 
-    .bret                   (bret_d),
- 
 
   
                 
@@ -3036,7 +2989,7 @@ lm32_decoder_full_debug decoder (
     ); 
 
 
-lm32_load_store_unit_full_debug #(
+lm32_load_store_unit_full #(
     .associativity          (dcache_associativity),
     .sets                   (dcache_sets),
     .bytes_per_line         (dcache_bytes_per_line),
@@ -3172,7 +3125,7 @@ lm32_multiplier multiplier (
   
 
 
-lm32_mc_arithmetic_full_debug mc_arithmetic (
+lm32_mc_arithmetic_full mc_arithmetic (
     
     .clk_i                  (clk_i),
     .rst_i                  (rst_i),
@@ -3211,7 +3164,7 @@ lm32_mc_arithmetic_full_debug mc_arithmetic (
   
 
 
-lm32_interrupt_full_debug interrupt_unit (
+lm32_interrupt_full interrupt_unit (
     
     .clk_i                  (clk_i), 
     .rst_i                  (rst_i),
@@ -3220,18 +3173,17 @@ lm32_interrupt_full_debug interrupt_unit (
     
     .stall_x                (stall_x),
   
+         
+            
 
-    .non_debug_exception    (non_debug_exception_q_w), 
-    .debug_exception        (debug_exception_q_w),
- 
-                   
 
+    .exception              (exception_q_w), 
+ 
 
     .eret_q_x               (eret_q_x),
   
+                   
 
-    .bret_q_x               (bret_q_x),
- 
 
     .csr                    (csr_x),
     .csr_write_data         (operand_1_x),
@@ -3246,117 +3198,95 @@ lm32_interrupt_full_debug interrupt_unit (
 
   
 
-
-lm32_jtag_full_debug jtag (
+  
     
-    .clk_i                  (clk_i),
-    .rst_i                  (rst_i),
+                      
+                      
     
-    .jtag_clk               (jtag_clk),
-    .jtag_update            (jtag_update),
-    .jtag_reg_q             (jtag_reg_q),
-    .jtag_reg_addr_q        (jtag_reg_addr_q),
+                   
+                
+                 
+            
     
-  
-
-    .csr                    (csr_x),
-    .csr_write_data         (operand_1_x),
-    .csr_write_enable       (csr_write_enable_q_x),
-    .stall_x                (stall_x),
  
+                        
+             
+           
+                    
 
-  
-
-    .jtag_read_data         (jtag_read_data),
-    .jtag_access_complete   (jtag_access_complete),
  
+             
+       
 
-  
-
-    .exception_q_w          (debug_exception_q_w || non_debug_exception_q_w),
  
+                
     
     
     
-  
-
-    .jtx_csr_read_data      (jtx_csr_read_data),
-    .jrx_csr_read_data      (jrx_csr_read_data),
  
+          
+          
 
-  
-
-    .jtag_csr_write_enable  (jtag_csr_write_enable),
-    .jtag_csr_write_data    (jtag_csr_write_data),
-    .jtag_csr               (jtag_csr),
-    .jtag_read_enable       (jtag_read_enable),
-    .jtag_write_enable      (jtag_write_enable),
-    .jtag_write_data        (jtag_write_data),
-    .jtag_address           (jtag_address),
  
+      
+        
+                   
+           
+          
+            
+               
 
-  
-
-    .jtag_break             (jtag_break),
-    .jtag_reset             (reset_exception),
  
+                 
+                 
 
     
-    .jtag_reg_d             (jtag_reg_d),
-    .jtag_reg_addr_d        (jtag_reg_addr_d)
-    );
- 
-
-
-  
-
-
-lm32_debug_full_debug #(
-    .breakpoints            (breakpoints),
-    .watchpoints            (watchpoints)
-  ) hw_debug (
+                 
+            
     
-    .clk_i                  (clk_i), 
-    .rst_i                  (rst_i),
-    .pc_x                   (pc_x),
-    .load_x                 (load_x),
-    .store_x                (store_x),
-    .load_store_address_x   (adder_result_x),
-    .csr_write_enable_x     (csr_write_enable_q_x),
-    .csr_write_data         (operand_1_x),
-    .csr_x                  (csr_x),
-  
 
-    .jtag_csr_write_enable  (jtag_csr_write_enable),
-    .jtag_csr_write_data    (jtag_csr_write_data),
-    .jtag_csr               (jtag_csr),
- 
 
-  
 
-    .eret_q_x               (eret_q_x),
-    .bret_q_x               (bret_q_x),
-    .stall_x                (stall_x),
-    .exception_x            (exception_x),
-    .q_x                    (q_x),
   
 
-    .dcache_refill_request  (dcache_refill_request),
  
+                
+                
+    
+    
+                       
+                      
+                       
+                     
+                    
+       
+         
+             
+                      
+ 
+      
+        
+                   
 
  
+                   
+                   
+                    
+                
+                        
+ 
+      
 
-    
-  
 
-    .dc_ss                  (dc_ss),
+    
  
+                      
+
+                      
+                   
+                   
+    
 
-    .dc_re                  (dc_re),
-    .bp_match               (bp_match),
-    .wp_match               (wp_match)
-    );
- 
 
 
 
@@ -3856,25 +3786,21 @@ assign kill_w =     1'b0
 
 
   
-
-assign breakpoint_exception =    (   (   (break_x ==  1'b1)
-				      || (bp_match ==  1'b1)
-				     )
-				  && (valid_x ==  1'b1)
-				 )
-  
-
-                              || (jtag_break ==  1'b1)
+              
+				         
+				     
+				     
+				 
  
+                                 
+
+                              
 
-                              ;
- 
 
 
   
+     
 
-assign watchpoint_exception = wp_match ==  1'b1;
- 
 
 
   
@@ -3901,17 +3827,38 @@ assign system_call_exception = (   (scall_x ==  1'b1)
 			       );
 
   
+      
+                            
+                         
 
-assign debug_exception_x =  (breakpoint_exception ==  1'b1)
-                         || (watchpoint_exception ==  1'b1)
-                         ;
+     
+ 
+                               
 
-assign non_debug_exception_x = (system_call_exception ==  1'b1)
-  
+ 
+                               
+                               
 
-                            || (reset_exception ==  1'b1)
  
+                               
 
+ 
+                                  
+ 
+                                   
+                            
+ 
+ 				   
+				   
+
+                               
+
+                            
+
+         
+
+
+assign exception_x =           (system_call_exception ==  1'b1)
   
 
                             || (instruction_bus_error_exception ==  1'b1)
@@ -3927,9 +3874,8 @@ assign non_debug_exception_x = (system_call_exception ==  1'b1)
 
                             || (   (interrupt_exception ==  1'b1)
   
+                                   
 
-                                && (dc_ss ==  1'b0)
- 
                             
   
 
@@ -3941,55 +3887,27 @@ assign non_debug_exception_x = (system_call_exception ==  1'b1)
  
 
                             ;
-
-assign exception_x = (debug_exception_x ==  1'b1) || (non_debug_exception_x ==  1'b1);
- 
-               
  
-                               
-                               
-
- 
-                               
-
- 
-                                  
- 
-                                   
-                            
- 
- 				   
-				   
-
-                               
-
-                            
-
 
 
 
 always @(*)
 begin
   
-
-  
-
-    if (reset_exception ==  1'b1)
-        eid_x =  3'h0;
-    else
  
+       
+          
+    
      
-  
-
-         if (data_bus_error_exception ==  1'b1)
-        eid_x =  3'h4;
-    else
  
+            
+          
+    
+
+            
+          
+    
 
-         if (breakpoint_exception ==  1'b1)
-        eid_x =  3'd1;
-    else
- 
 
   
 
@@ -4002,11 +3920,10 @@ begin
  
 
   
+            
+          
+     
 
-         if (watchpoint_exception ==  1'b1)
-        eid_x =  3'd3;
-    else 
- 
 
   
 
@@ -4019,9 +3936,8 @@ begin
 
          if (   (interrupt_exception ==  1'b1)
   
+                
 
-             && (dc_ss ==  1'b0)
- 
                             
             )
         eid_x =  3'h6;
@@ -4058,19 +3974,18 @@ assign stall_d =   (stall_x ==  1'b1)
                     && (kill_d ==  1'b0)
 		   )
   
+		         
+			   
+		       
+		          
+			   
+			   
+			   
+			   
+		       
+                       
+		   
 
-		|| (   (   (break_d ==  1'b1)
-			|| (bret_d ==  1'b1)
-		       )
-		    && (   (load_q_x ==  1'b1)
-			|| (store_q_x ==  1'b1)
-			|| (load_q_m ==  1'b1)
-			|| (store_q_m ==  1'b1)
-			|| (D_CYC_O ==  1'b1)
-		       )
-                    && (kill_d ==  1'b0)
-		   )
- 
                    
                 || (   (csr_write_enable_d ==  1'b1)
                     && (load_q_x ==  1'b1)
@@ -4176,24 +4091,21 @@ assign q_x = (valid_x ==  1'b1) && (kill_x ==  1'b0);
 assign csr_write_enable_q_x = (csr_write_enable_x ==  1'b1) && (q_x ==  1'b1);
 assign eret_q_x = (eret_x ==  1'b1) && (q_x ==  1'b1);
   
+         
 
-assign bret_q_x = (bret_x ==  1'b1) && (q_x ==  1'b1);
- 
 
 assign load_q_x = (load_x ==  1'b1) 
                && (q_x ==  1'b1)
   
+                  
 
-               && (bp_match ==  1'b0)
- 
 
                   ;
 assign store_q_x = (store_x ==  1'b1) 
                && (q_x ==  1'b1)
   
+                  
 
-               && (bp_match ==  1'b0)
- 
 
                   ;
   
@@ -4204,13 +4116,13 @@ assign q_m = (valid_m ==  1'b1) && (kill_m ==  1'b0) && (exception_m ==  1'b0);
 assign load_q_m = (load_m ==  1'b1) && (q_m ==  1'b1);
 assign store_q_m = (store_m ==  1'b1) && (q_m ==  1'b1);
   
-
-assign debug_exception_q_w = ((debug_exception_w ==  1'b1) && (valid_w ==  1'b1));
-assign non_debug_exception_q_w = ((non_debug_exception_w ==  1'b1) && (valid_w ==  1'b1));        
- 
+         
                  
 
 
+assign exception_q_w = ((exception_w ==  1'b1) && (valid_w ==  1'b1));        
+ 
+
 
 assign write_enable_q_x = (write_enable_x ==  1'b1) && (valid_x ==  1'b1) && (branch_flushX_m ==  1'b0);
 assign write_enable_q_m = (write_enable_m ==  1'b1) && (valid_m ==  1'b1);
@@ -4225,12 +4137,12 @@ assign cfg = {
               breakpoints[3:0],
               interrupts[5:0],
   
-
-               1'b1,
- 
               
 
 
+               1'b0,
+ 
+
   
               
 
@@ -4239,19 +4151,19 @@ assign cfg = {
  
 
   
-
-               1'b1,
- 
               
 
 
-  
-
-               1'b1,
+               1'b0,
  
+
+  
               
 
 
+               1'b0,
+ 
+
   
 
                1'b1,
@@ -4332,17 +4244,16 @@ assign cfg2 = {
   
 
 assign iflush = (   (csr_write_enable_d ==  1'b1) 
-                 && (csr_d ==  5'h3)
+                 && (csr_d ==  4 'h3)
                  && (stall_d ==  1'b0)
                  && (kill_d ==  1'b0)
                  && (valid_d ==  1'b1))
 
   
+             
+                     
+		    
 
-             ||
-                (   (jtag_csr_write_enable ==  1'b1)
-		 && (jtag_csr ==  5'h3))
- 
 
 		 ;
  
@@ -4350,21 +4261,20 @@ assign iflush = (   (csr_write_enable_d ==  1'b1)
   
 
 assign dflush_x = (   (csr_write_enable_q_x ==  1'b1) 
-                   && (csr_x ==  5'h4))
+                   && (csr_x ==  4 'h4))
 
   
+               
+                       
+		      
 
-               ||
-                  (   (jtag_csr_write_enable ==  1'b1)
-		   && (jtag_csr ==  5'h4))
- 
 
 		   ;
  
  
 
 
-assign csr_d = read_idx_0_d[ (5-1):0];
+assign csr_d = read_idx_0_d[ (4 -1):0];
 
 
 always @(*)
@@ -4372,29 +4282,27 @@ begin
     case (csr_x)
   
 
-     5'h0,
-     5'h1,
-     5'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
+     4 'h0,
+     4 'h1,
+     4 'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
  
 
   
          
 
 
-     5'h6:  csr_read_data_x = cfg;
-     5'h7:  csr_read_data_x = {eba, 8'h00};
+     4 'h6:  csr_read_data_x = cfg;
+     4 'h7:  csr_read_data_x = {eba, 8'h00};
   
+        
 
-     5'h9: csr_read_data_x = {deba, 8'h00};
- 
 
   
+          
+        
 
-     5'he:  csr_read_data_x = jtx_csr_read_data;  
-     5'hf:  csr_read_data_x = jrx_csr_read_data;
- 
 
-     5'ha: csr_read_data_x = cfg2;
+     4 'ha: csr_read_data_x = cfg2;
       
     default:        csr_read_data_x = { 32{1'bx}};
     endcase
@@ -4411,37 +4319,33 @@ begin
         eba <= eba_reset[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
     else
     begin
-        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  5'h7) && (stall_x ==  1'b0))
+        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  4 'h7) && (stall_x ==  1'b0))
             eba <= operand_1_x[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
   
+               
+              
 
-        if ((jtag_csr_write_enable ==  1'b1) && (jtag_csr ==  5'h7))
-            eba <= jtag_csr_write_data[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
- 
 
     end
 end
 
   
 
+   
 
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-        deba <= deba_reset[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
-    else
-    begin
-        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  5'h9) && (stall_x ==  1'b0))
-            deba <= operand_1_x[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
-  
-
-        if ((jtag_csr_write_enable ==  1'b1) && (jtag_csr ==  5'h9))
-            deba <= jtag_csr_write_data[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+       
+          
+    
+    
+                   
+              
  
+               
+              
+
+    
+
 
-    end
-end
- 
 
 
 
@@ -4623,7 +4527,7 @@ begin
         m_bypass_enable_x <=  1'b0;
         write_enable_x <=  1'b0;
         write_idx_x <= { 5{1'b0}};
-        csr_x <= { 5{1'b0}};
+        csr_x <= { 4 {1'b0}};
         load_x <=  1'b0;
         store_x <=  1'b0;
         size_x <= { 2{1'b0}};
@@ -4646,16 +4550,14 @@ begin
         branch_predict_taken_x <=  1'b0;
         condition_x <=  3'b000;
   
+          
 
-        break_x <=  1'b0;
- 
 
         scall_x <=  1'b0;
         eret_x <=  1'b0;
   
+          
 
-        bret_x <=  1'b0;
- 
 
   
 
@@ -4699,10 +4601,9 @@ begin
  
 
   
+          
+                  
 
-        debug_exception_m <=  1'b0;
-        non_debug_exception_m <=  1'b0;        
- 
 
         operand_w <= { 32{1'b0}};        
         w_result_sel_load_w <=  1'b0;
@@ -4714,13 +4615,13 @@ begin
         write_idx_w <= { 5{1'b0}};        
         write_enable_w <=  1'b0;
   
-
-        debug_exception_w <=  1'b0;
-        non_debug_exception_w <=  1'b0;        
- 
           
+                  
 
 
+        exception_w <=  1'b0;
+ 
+
   
 
         memop_pc_w <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
@@ -4800,9 +4701,8 @@ begin
             condition_x <= condition_d;
             csr_write_enable_x <= csr_write_enable_d;
   
+              
 
-            break_x <= break_d;
- 
 
             scall_x <= scall_d;
   
@@ -4812,9 +4712,8 @@ begin
 
             eret_x <= eret_d;
   
+               
 
-            bret_x <= bret_d; 
- 
 
             write_enable_x <= write_enable_d;
         end
@@ -4866,40 +4765,40 @@ begin
 
 
   
-
 	   
 	   
 	   
 	   
 	   
-            if (non_debug_exception_x ==  1'b1) 
-                write_idx_m <=  5'd30;
-            else if (debug_exception_x ==  1'b1)
-                write_idx_m <=  5'd31;
-            else 
-                write_idx_m <= write_idx_x;
- 
-               
+                
+                  
+                
                   
              
                   
 
 
+            if (exception_x ==  1'b1)
+                write_idx_m <=  5'd30;
+            else 
+                write_idx_m <= write_idx_x;
+ 
+
             condition_met_m <= condition_met_x;
   
+	      
+	        
+		     
+		        
+	           
+	     
+	           
+	   
+	       
 
-	   if (exception_x ==  1'b1)
-	     if ((dc_re ==  1'b1)
-		 || ((debug_exception_x ==  1'b1) 
-		     && (non_debug_exception_x ==  1'b0)))
-	       branch_target_m <= {deba, eid_x, {3{1'b0}}};
-	     else
-	       branch_target_m <= {eba, eid_x, {3{1'b0}}};
-	   else
-	     branch_target_m <= branch_target_x;
- 
-                      
 
+            branch_target_m <= exception_x ==  1'b1 ? {eba, eid_x, {3{1'b0}}} : branch_target_x;
+ 
 
   
               
@@ -4912,16 +4811,14 @@ begin
 
             eret_m <= eret_q_x;
   
+               
 
-            bret_m <= bret_q_x; 
- 
 
             write_enable_m <= exception_x ==  1'b1 ?  1'b1 : write_enable_x;            
   
+              
+                      
 
-            debug_exception_m <= debug_exception_x;
-            non_debug_exception_m <= non_debug_exception_x;        
- 
 
         end
         
@@ -4936,9 +4833,8 @@ begin
 
 	   data_bus_error_exception_m <=    (data_bus_error_exception ==  1'b1) 
   
+					    
 
-					 && (reset_exception ==  1'b0)
- 
 
 					 ;
  
@@ -4970,13 +4866,13 @@ begin
 
         write_enable_w <= write_enable_m;
   
-
-        debug_exception_w <= debug_exception_m;
-        non_debug_exception_w <= non_debug_exception_m;
- 
+          
           
 
 
+        exception_w <= exception_m;
+ 
+
   
 
         if (   (stall_m ==  1'b0)
@@ -5384,7 +5280,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -5521,7 +5417,7 @@ endmodule
 
 
 
-module lm32_load_store_unit_full_debug (
+module lm32_load_store_unit_full (
     
     clk_i,
     rst_i,
@@ -5899,7 +5795,7 @@ endfunction
   
 
 
-lm32_dcache_full_debug #(
+lm32_dcache_full #(
     .associativity          (associativity),
     .sets                   (sets),
     .bytes_per_line         (bytes_per_line),
@@ -6616,7 +6512,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -6851,7 +6747,7 @@ endmodule
 
 
 
-module lm32_decoder_full_debug (
+module lm32_decoder_full (
     
     instruction,
     
@@ -6932,16 +6828,14 @@ module lm32_decoder_full_debug (
     bi_conditional,
     bi_unconditional,
   
+    
 
-    break_opcode,
- 
 
     scall,
     eret,
   
+    
 
-    bret,
- 
 
   
     
@@ -7077,20 +6971,18 @@ wire bi_conditional;
 output bi_unconditional;
 wire bi_unconditional;
   
-
-output break_opcode;
-wire   break_opcode;
  
+   
+
 
 output scall;
 wire   scall;
 output eret;
 wire   eret;
   
-
-output bret;
-wire   bret;
  
+   
+
 
   
   
@@ -7112,6 +7004,92 @@ wire sign_extend_immediate;
 wire select_high_immediate;                     
 wire select_call_immediate;                     
 
+wire op_add;
+wire op_and;
+wire op_andhi;
+wire op_b;
+wire op_bi;
+wire op_be;
+wire op_bg;
+wire op_bge;
+wire op_bgeu;
+wire op_bgu;
+wire op_bne;
+wire op_call;
+wire op_calli;
+wire op_cmpe;
+wire op_cmpg;
+wire op_cmpge;
+wire op_cmpgeu;
+wire op_cmpgu;
+wire op_cmpne;
+  
+
+wire op_divu;
+ 
+
+wire op_lb;
+wire op_lbu;
+wire op_lh;
+wire op_lhu;
+wire op_lw;
+  
+
+wire op_modu;
+ 
+
+  
+
+wire op_mul;
+ 
+
+wire op_nor;
+wire op_or;
+wire op_orhi;
+wire op_raise;
+wire op_rcsr;
+wire op_sb;
+  
+
+wire op_sextb;
+wire op_sexth;
+ 
+
+wire op_sh;
+  
+
+wire op_sl;
+ 
+
+wire op_sr;
+wire op_sru;
+wire op_sub;
+wire op_sw;
+wire op_user;
+wire op_wcsr;
+wire op_xnor;
+wire op_xor;
+
+wire arith;
+wire logical;
+wire cmp;
+wire bra;
+wire call;
+  
+
+wire shift;
+ 
+
+  
+ 
+
+
+  
+
+wire sext;
+ 
+
+
 
 
 
@@ -7269,9 +7247,8 @@ assign sext = op_sextb | op_sexth;
  
 
   
+   
 
-assign multiply = op_mul;
- 
 
   
 
@@ -7454,16 +7431,14 @@ assign branch = bra | call;
 assign branch_reg = op_call | op_b;
 assign condition = instruction[28:26];      
   
+     
 
-assign break_opcode = op_raise & ~instruction[2];
- 
 
 assign scall = op_raise & instruction[2];
 assign eret = op_b & (instruction[25:21] == 5'd30);
   
+       
 
-assign bret = op_b & (instruction[25:21] == 5'd31);
- 
 
   
 
@@ -7717,7 +7692,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -7895,7 +7870,7 @@ endmodule
 
 
 
-module lm32_icache_full_debug ( 
+module lm32_icache_full ( 
     
     clk_i,
     rst_i,    
@@ -8565,7 +8540,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -8741,7 +8716,7 @@ endmodule
 
 
 
-module lm32_dcache_full_debug ( 
+module lm32_dcache_full ( 
     
     clk_i,
     rst_i,    
@@ -9461,7 +9436,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -9597,106 +9572,133 @@ endmodule
   
 
 
+                  
+                 
+         
+     
+     
+              
 
-  
 
-  
 
-  
 
-  
 
   
+    
+     
+    
+    
+    
+    
+    
+    
+    
+    
+ 
+    
+    
+    
 
-  
+ 
+    
+    
+    
+    
+    
+ 
+    
 
 
+    
+ 
+    
 
+    
+    
+    
+    
+    
 
 
 
-module lm32_debug_full_debug (
-    
-    clk_i, 
-    rst_i,
-    pc_x,
-    load_x,
-    store_x,
-    load_store_address_x,
-    csr_write_enable_x,
-    csr_write_data,
-    csr_x,
-  
 
-    jtag_csr_write_enable,
-    jtag_csr_write_data,
-    jtag_csr,
- 
+                         
+                         
 
-  
 
-    eret_q_x,
-    bret_q_x,
-    stall_x,
-    exception_x,
-    q_x,
-  
 
-    dcache_refill_request,
+
+
+                                     
+                                     
+
+                        
+                                    
+                                   
+      
+                        
+            
+                      
  
+                     
+       
+                   
 
  
+                                  
+                                  
+                                   
+                               
+                                       
+ 
+                     
+
+
+
+
+
 
-    
-  
 
-    dc_ss,
  
+                                    
+    
 
-    dc_re,
-    bp_match,
-    wp_match
-    );
+                                    
     
+                                 
+           
+                                 
+   
 
 
 
 
-parameter breakpoints = 0;                      
-parameter watchpoints = 0;                      
 
+                                        
 
 
 
+         
+                       
+                
 
-input clk_i;                                    
-input rst_i;                                    
+     
+         
+                
 
-input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_x;                      
-input load_x;                                   
-input store_x;                                  
-input [ (32-1):0] load_store_address_x;    
-input csr_write_enable_x;                       
-input [ (32-1):0] csr_write_data;          
-input [ (5-1):0] csr_x;                    
-  
+                     
+       
+                   
 
-input jtag_csr_write_enable;                    
-input [ (32-1):0] jtag_csr_write_data;     
-input [ (5-1):0] jtag_csr;                 
  
 
-  
+             
+
+
+
+
 
-input eret_q_x;                                 
-input bret_q_x;                                 
-input stall_x;                                  
-input exception_x;                              
-input q_x;                                      
-  
 
-input dcache_refill_request;                    
- 
 
  
 
@@ -9705,52 +9707,177 @@ input dcache_refill_request;
 
 
 
-  
 
-output dc_ss;                                   
-reg    dc_ss;
+               
+      
+         
+    
+
+ 
  
+        
+       
+    
+     
 
-output dc_re;                                   
-reg    dc_re;
-output bp_match;                                
-wire   bp_match;        
-output wp_match;                                
-wire   wp_match;
+        
+   
+    
+   
 
+    
+               
 
+ 
+               
+      
+             
+                   
 
 
+        
+                   
+    
+   
 
-genvar i;                                       
+                
+                 
 
+         
+         
+         
 
+   
+   
+   
 
-reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] bp_a[0:breakpoints-1];       
-reg bp_e[0:breakpoints-1];                      
-wire [0:breakpoints-1]bp_match_n;               
 
-reg [ 1:0] wpc_c[0:watchpoints-1];   
-reg [ (32-1):0] wp[0:watchpoints-1];       
-wire [0:watchpoints]wp_match_n;               
 
-wire debug_csr_write_enable;                    
-wire [ (32-1):0] debug_csr_write_data;     
-wire [ (5-1):0] debug_csr;                 
 
-  
 
 
-reg [ 2:0] state;           
 
- 
 
+               
+      
+   
+
+       
+    
+          
+          
+    
+    
+    
+                 
+        
+              
+              
+        
+    
+    
+    
 
 
 
 
+               
+      
+   
 
-  
+       
+    
+          
+          
+    
+    
+    
+           
+        
+               
+                  
+                 
+                  
+        
+      
+
+    
+
+
+
+   
+
+       
+          
+    
+    
+               
+              
+    
+    
+
+ 
+
+   
+
+       
+    
+          
+          
+    
+    
+    
+               
+        
+              
+                
+                  
+             
+                  
+        
+         
+        
+        
+            
+                     
+                       
+                    
+                   
+               
+                   
+        
+        
+        
+            
+                   
+                  
+        
+        
+        
+            
+ 
+               
+                  
+             
+
+                            
+            
+                  
+                  
+            
+        
+        
+        
+            
+ 
+               
+                  
+             
+
+                  
+        
+        
+    
 
 
 
@@ -9775,245 +9902,6 @@ reg [ 2:0] state;
 
 
 
-
-
-
-
-					  
-function integer clogb2;
-input [31:0] value;
-begin
-   for (clogb2 = 0; value > 0; clogb2 = clogb2 + 1)
-        value = value >> 1;
-end
-endfunction 
-
-function integer clogb2_v1;
-input [31:0] value;
-reg   [31:0] i;
-reg   [31:0] temp;
-begin
-   temp = 0;
-   i    = 0;
-   for (i = 0; temp < value; i = i + 1)  
-	temp = 1<<i;
-   clogb2_v1 = i-1;
-end
-endfunction
-
-
-
-
-
-
-
-
-
-generate
-    for (i = 0; i < breakpoints; i = i + 1)
-    begin : bp_comb
-assign bp_match_n[i] = ((bp_a[i] == pc_x) && (bp_e[i] ==  1'b1));
-    end
-endgenerate
-generate 
-  
-
-    if (breakpoints > 0) 
-assign bp_match = (|bp_match_n) || (state ==  3'b011);
-    else
-assign bp_match = state ==  3'b011;
- 
-        
-   
-    
-   
-
-
-endgenerate    
-               
-
-generate 
-    for (i = 0; i < watchpoints; i = i + 1)
-    begin : wp_comb
-assign wp_match_n[i] = (wp[i] == load_store_address_x) && ((load_x & wpc_c[i][0]) | (store_x & wpc_c[i][1]));
-    end               
-endgenerate
-generate
-    if (watchpoints > 0) 
-assign wp_match = |wp_match_n;                
-    else
-assign wp_match =  1'b0;
-endgenerate
-                
-  
-                
-
-assign debug_csr_write_enable = (csr_write_enable_x ==  1'b1) || (jtag_csr_write_enable ==  1'b1);
-assign debug_csr_write_data = jtag_csr_write_enable ==  1'b1 ? jtag_csr_write_data : csr_write_data;
-assign debug_csr = jtag_csr_write_enable ==  1'b1 ? jtag_csr : csr_x;
- 
-   
-   
-   
-
-
-
-
-
-
-
-
-generate
-    for (i = 0; i < breakpoints; i = i + 1)
-    begin : bp_seq
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        bp_a[i] <= { (clogb2(32'h7fffffff-32'h0)-2){1'bx}};
-        bp_e[i] <=  1'b0;
-    end
-    else
-    begin
-        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h10 + i))
-        begin
-            bp_a[i] <= debug_csr_write_data[ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2];
-            bp_e[i] <= debug_csr_write_data[0];
-        end
-    end
-end    
-    end
-endgenerate
-
-
-generate
-    for (i = 0; i < watchpoints; i = i + 1)
-    begin : wp_seq
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        wp[i] <= { 32{1'bx}};
-        wpc_c[i] <=  2'b00;
-    end
-    else
-    begin
-        if (debug_csr_write_enable ==  1'b1)
-        begin
-            if (debug_csr ==  5'h8)
-                wpc_c[i] <= debug_csr_write_data[3+i*2:2+i*2];
-            if (debug_csr ==  5'h18 + i)
-                wp[i] <= debug_csr_write_data;
-        end
-    end  
-end
-    end
-endgenerate
-
-
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-        dc_re <=  1'b0;
-    else
-    begin
-        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h8))
-            dc_re <= debug_csr_write_data[1];
-    end
-end    
-
-  
-
-
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        state <=  3'b000;
-        dc_ss <=  1'b0;
-    end
-    else
-    begin
-        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h8))
-        begin
-            dc_ss <= debug_csr_write_data[0];
-            if (debug_csr_write_data[0] ==  1'b0) 
-                state <=  3'b000;
-            else 
-                state <=  3'b001;
-        end
-        case (state)
-         3'b001:
-        begin
-            
-            if (   (   (eret_q_x ==  1'b1)
-                    || (bret_q_x ==  1'b1)
-                    )
-                && (stall_x ==  1'b0)
-               )
-                state <=  3'b010; 
-        end
-         3'b010:
-        begin
-            
-            if ((q_x ==  1'b1) && (stall_x ==  1'b0))
-                state <=  3'b011;
-        end
-         3'b011:
-        begin
-            
-  
-
-            if (dcache_refill_request ==  1'b1)
-                state <=  3'b010;
-            else 
- 
-
-                 if ((exception_x ==  1'b1) && (q_x ==  1'b1) && (stall_x ==  1'b0))
-            begin
-                dc_ss <=  1'b0;
-                state <=  3'b100;
-            end
-        end
-         3'b100:
-        begin
-            
-  
-
-            if (dcache_refill_request ==  1'b1)
-                state <=  3'b010;
-            else 
- 
-
-                state <=  3'b000;
-        end
-        endcase
-    end
-end
- 
-
-
-endmodule
-
- 
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
 
 
 
@@ -10231,7 +10119,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -10368,7 +10256,7 @@ endmodule
 
 
 
-module lm32_instruction_unit_full_debug (
+module lm32_instruction_unit_full (
     
     clk_i,
     rst_i,
@@ -10421,12 +10309,11 @@ module lm32_instruction_unit_full_debug (
  
 
   
+    
+    
+    
+    
 
-    jtag_read_enable,
-    jtag_write_enable,
-    jtag_write_data,
-    jtag_address,
- 
 
     
     
@@ -10462,10 +10349,9 @@ module lm32_instruction_unit_full_debug (
  
 
   
+    
+    
 
-    jtag_read_data,
-    jtag_access_complete,
- 
 
   
 
@@ -10555,12 +10441,11 @@ input i_rty_i;
 
 
   
+                                  
+                                 
+                   
+                      
 
-input jtag_read_enable;                                 
-input jtag_write_enable;                                
-input [ 7:0] jtag_write_data;                 
-input [ (32-1):0] jtag_address;                    
- 
 
 
 
@@ -10601,11 +10486,11 @@ wire   icache_refilling;
 
 output [ (32-1):0] i_dat_o;                        
   
+     
 
-reg    [ (32-1):0] i_dat_o;
- 
-    
 
+wire   [ (32-1):0] i_dat_o;
+ 
 
 output [ (32-1):0] i_adr_o;                        
 reg    [ (32-1):0] i_adr_o;
@@ -10613,21 +10498,21 @@ output i_cyc_o;
 reg    i_cyc_o; 
 output [ (4-1):0] i_sel_o;                 
   
+     
 
-reg    [ (4-1):0] i_sel_o;
- 
-    
 
+wire   [ (4-1):0] i_sel_o;
+ 
 
 output i_stb_o;                                         
 reg    i_stb_o;
 output i_we_o;                                          
   
+    
 
-reg    i_we_o;
- 
-   
 
+wire   i_we_o;
+ 
 
 output [ (3-1):0] i_cti_o;                       
 reg    [ (3-1):0] i_cti_o;
@@ -10639,12 +10524,11 @@ wire   [ (2-1):0] i_bte_o;
 
 
   
+                   
+     
+                             
+   
 
-output [ 7:0] jtag_read_data;                 
-reg    [ 7:0] jtag_read_data;
-output jtag_access_complete;                            
-wire   jtag_access_complete;
- 
 
 
   
@@ -10710,9 +10594,8 @@ reg bus_error_f;
 
 
   
+                                         
 
-reg jtag_access;                                        
- 
 
 
 
@@ -10830,7 +10713,7 @@ endfunction
   
 
 
-lm32_icache_full_debug #(
+lm32_icache_full #(
     .associativity          (associativity),
     .sets                   (sets),
     .bytes_per_line         (bytes_per_line),
@@ -10953,11 +10836,11 @@ assign instruction_f = icache_data_f;
 
   
 
- 
-   
-   
-   
 
+assign i_dat_o = 32'd0;
+assign i_we_o =  1'b0;
+assign i_sel_o = 4'b1111;
+ 
 
 assign i_bte_o =  2'b00;
  
@@ -11074,18 +10957,17 @@ end
 
 
   
-
-assign jtag_access_complete = (i_cyc_o ==  1'b1) && ((i_ack_i ==  1'b1) || (i_err_i ==  1'b1)) && (jtag_access ==  1'b1);
-always @(*)
-begin
-    case (jtag_address[1:0])
-    2'b00: jtag_read_data = i_dat_i[ 31:24];
-    2'b01: jtag_read_data = i_dat_i[ 23:16];
-    2'b10: jtag_read_data = i_dat_i[ 15:8];
-    2'b11: jtag_read_data = i_dat_i[ 7:0];
-    endcase 
-end
+                 
  
+
+     
+       
+       
+       
+       
+     
+
+
 
 
   
@@ -11110,11 +10992,10 @@ begin
  
 
   
+          
+          
+          
 
-        i_we_o <=  1'b0;
-        i_sel_o <= 4'b1111;
-        jtag_access <=  1'b0;
- 
 
     end
     else
@@ -11127,16 +11008,15 @@ begin
             if ((i_ack_i ==  1'b1) || (i_err_i ==  1'b1))
             begin
   
+                   
+                
+                      
+                             
+                        
+                          
+                
+                
 
-                if (jtag_access ==  1'b1)
-                begin
-                    i_cyc_o <=  1'b0;
-                    i_stb_o <=  1'b0;       
-                    i_we_o <=  1'b0;  
-                    jtag_access <=  1'b0;    
-                end
-                else
- 
 
                 begin
                     if (last_word ==  1'b1)
@@ -11169,10 +11049,9 @@ begin
             if ((icache_refill_request ==  1'b1) && (icache_refill_ready ==  1'b0))
             begin
                 
-  
-     
-                i_sel_o <= 4'b1111;
- 
+       
+                  
+
 
                 i_adr_o <= {first_address, 2'b00};
                 i_cyc_o <=  1'b1;
@@ -11186,27 +11065,26 @@ begin
 
             end
   
+            
+            
+                       
+                
+                     
+                       
+                       
+                       
+                       
+                    
+                      
+                      
+                      
+                      
+                      
+                      
+                      
+                
+             
 
-            else
-            begin
-                if ((jtag_read_enable ==  1'b1) || (jtag_write_enable ==  1'b1))
-                begin
-                    case (jtag_address[1:0])
-                    2'b00: i_sel_o <= 4'b1000;
-                    2'b01: i_sel_o <= 4'b0100;
-                    2'b10: i_sel_o <= 4'b0010;
-                    2'b11: i_sel_o <= 4'b0001;
-                    endcase
-                    i_adr_o <= jtag_address;
-                    i_dat_o <= {4{jtag_write_data}};
-                    i_cyc_o <=  1'b1;
-                    i_stb_o <=  1'b1;
-                    i_we_o <= jtag_write_enable;
-                    i_cti_o <=  3'b111;
-                    jtag_access <=  1'b1;
-                end
-            end 
- 
                     
   
 
@@ -11546,7 +11424,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -11681,523 +11559,443 @@ endmodule
 
   
 
+                              
+                              
+                              
 
-  
-
-  
-
-  
-
-
-
-  
-
-  
-
-  
-
-  
-
-  
-
-  
-
-  
-
-  
-
-
-
-  
-
-  
 
-  
+                          
+                  
+                 
+              
+             
+                    
+                        
+                        
 
-  
 
-  
+                  
+         
+          
+          
+          
+          
+          
+      
+      
+         
 
-  
 
-  
 
-  
 
-  
 
   
-
-
-
-
-
-
-module lm32_jtag_full_debug (
     
-    clk_i,
-    rst_i,
-    jtag_clk, 
-    jtag_update,
-    jtag_reg_q,
-    jtag_reg_addr_q,
-  
-
-    csr,
-    csr_write_enable,
-    csr_write_data,
-    stall_x,
+    
+    
+     
+    
+    
+    
  
+    
+    
+    
+    
 
-  
-
-    jtag_read_data,
-    jtag_access_complete,
  
+    
+    
 
-  
-
-    exception_q_w,
  
-
     
-  
 
-    jtx_csr_read_data,
-    jrx_csr_read_data,
+    
  
+    
+    
 
-  
-
-    jtag_csr_write_enable,
-    jtag_csr_write_data,
-    jtag_csr,
-    jtag_read_enable,
-    jtag_write_enable,
-    jtag_write_data,
-    jtag_address,
  
+    
+    
+    
+    
+    
+    
+    
 
-  
-
-    jtag_break,
-    jtag_reset,
  
+    
+    
 
-    jtag_reg_d,
-    jtag_reg_addr_d
-    );
-
+    
+    
+    
 
 
 
 
-input clk_i;                                            
-input rst_i;                                            
 
-input jtag_clk;                                         
-input jtag_update;                                      
-input [ 7:0] jtag_reg_q;                      
-input [2:0] jtag_reg_addr_q;                            
+                                             
+                                             
 
-  
+                                          
+                                       
+                        
+                              
 
-input [ (5-1):0] csr;                              
-input csr_write_enable;                                 
-input [ (32-1):0] csr_write_data;                  
-input stall_x;                                          
  
+                                
+                                  
+                    
+                                           
 
-  
-
-input [ 7:0] jtag_read_data;                  
-input jtag_access_complete;                             
  
+                    
+                              
 
-  
-
-input exception_q_w;                                    
  
+                                     
 
 
 
 
 
        
-  
-
-output [ (32-1):0] jtx_csr_read_data;              
-wire   [ (32-1):0] jtx_csr_read_data;
-output [ (32-1):0] jrx_csr_read_data;              
-wire   [ (32-1):0] jrx_csr_read_data;
  
+                
+    
+                
+    
 
-  
-
-output jtag_csr_write_enable;                           
-reg    jtag_csr_write_enable;
-output [ (32-1):0] jtag_csr_write_data;            
-wire   [ (32-1):0] jtag_csr_write_data;
-output [ (5-1):0] jtag_csr;                        
-wire   [ (5-1):0] jtag_csr;
-output jtag_read_enable;                                
-reg    jtag_read_enable;
-output jtag_write_enable;                               
-reg    jtag_write_enable;
-output [ 7:0] jtag_write_data;                
-wire   [ 7:0] jtag_write_data;        
-output [ (32-1):0] jtag_address;                   
-wire   [ (32-1):0] jtag_address;
  
+                            
+    
+              
+    
+                          
+    
+                                 
+    
+                                
+    
+                  
+            
+                     
+    
 
-  
-
-output jtag_break;                                      
-reg    jtag_break;
-output jtag_reset;                                      
-reg    jtag_reset;
  
+                                       
+    
+                                       
+    
 
-output [ 7:0] jtag_reg_d;
-reg    [ 7:0] jtag_reg_d;
-output [2:0] jtag_reg_addr_d;
-wire   [2:0] jtag_reg_addr_d;
+  
+     
+  
+    
              
 
 
 
 
-reg rx_update;                          
-reg rx_update_r;                        
-reg rx_update_r_r;                      
-reg rx_update_r_r_r;                    
-
+                           
+                         
+                       
+                     
 
 
-wire [ 7:0] rx_byte;   
-wire [2:0] rx_addr;
 
+     
   
-                 
-reg [ 7:0] uart_tx_byte;      
-reg uart_tx_valid;                      
-reg [ 7:0] uart_rx_byte;      
-reg uart_rx_valid;                      
- 
 
+                  
+        
+                       
+        
+                       
 
-reg [ 3:0] command;             
-  
 
-reg [ 7:0] jtag_byte_0;       
-reg [ 7:0] jtag_byte_1;
-reg [ 7:0] jtag_byte_2;
-reg [ 7:0] jtag_byte_3;
-reg [ 7:0] jtag_byte_4;
-reg processing;                         
+               
  
+         
+  
+  
+  
+  
+                          
 
 
-reg [ 3:0] state;       
-
+         
 
 
 
 
-  
 
-assign jtag_csr_write_data = {jtag_byte_0, jtag_byte_1, jtag_byte_2, jtag_byte_3};
-assign jtag_csr = jtag_byte_4[ (5-1):0];
-assign jtag_address = {jtag_byte_0, jtag_byte_1, jtag_byte_2, jtag_byte_3};
-assign jtag_write_data = jtag_byte_4;
  
+      
+   
+      
+   
 
                  
 
-  
-                 
-assign jtag_reg_addr_d[1:0] = {uart_rx_valid, uart_tx_valid};         
- 
-   
-
+                  
+             
 
-  
+   
 
-assign jtag_reg_addr_d[2] = processing;
  
    
 
+   
 
 
-  
-                 
-assign jtx_csr_read_data = {{ 32-9{1'b0}}, uart_tx_valid, 8'h00};
-assign jrx_csr_read_data = {{ 32-9{1'b0}}, uart_rx_valid, uart_rx_byte};
- 
+                  
+     
+     
          
                  
 
 
 
 
-assign rx_byte = jtag_reg_q;
-assign rx_addr = jtag_reg_addr_q;
+   
+   
 
 
 
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        rx_update <= 1'b0;
-        rx_update_r <= 1'b0;
-        rx_update_r_r <= 1'b0;
-        rx_update_r_r_r <= 1'b0;
-    end
-    else
-    begin
-        rx_update <= jtag_update;
-        rx_update_r <= rx_update;
-        rx_update_r_r <= rx_update_r;
-        rx_update_r_r_r <= rx_update_r_r;
-    end
-end
+   
 
+       
+    
+          
+          
+          
+          
+    
+    
+    
+          
+          
+          
+          
+    
 
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        state <=  4'h0;
-        command <= 4'b0000;
-        jtag_reg_d <= 8'h00;
-  
 
-        processing <=  1'b0;
-        jtag_csr_write_enable <=  1'b0;
-        jtag_read_enable <=  1'b0;
-        jtag_write_enable <=  1'b0;
- 
 
-  
+   
 
-        jtag_break <=  1'b0;
-        jtag_reset <=  1'b0;
+       
+    
+          
+          
+          
  
+          
+          
+          
+          
 
-  
-                 
-        uart_tx_byte <= 8'h00;
-        uart_tx_valid <=  1'b0;
-        uart_rx_byte <= 8'h00;
-        uart_rx_valid <=  1'b0;
  
+          
+          
 
-    end
-    else
-    begin
-  
-                 
-        if ((csr_write_enable ==  1'b1) && (stall_x ==  1'b0))
-        begin
-            case (csr)
-             5'he:
-            begin
+                  
+          
+          
+          
+          
+
+    
+    
+    
+                  
+               
+        
+             
+            
+            
                 
-                uart_tx_byte <= csr_write_data[ 7:0];
-                uart_tx_valid <=  1'b1;
-            end
-             5'hf:
-            begin
+                  
+                  
+            
+            
+            
                 
-                uart_rx_valid <=  1'b0;
-            end
-            endcase
-        end
- 
-
-  
-
+                  
+            
+            
         
-        if (exception_q_w ==  1'b1)
-        begin
-            jtag_break <=  1'b0;
-            jtag_reset <=  1'b0;
-        end
+
  
+        
+           
+        
+              
+              
+        
 
-        case (state)
-         4'h0:
-        begin
+         
+        
+        
             
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                command <= rx_byte[7:4];                
-                case (rx_addr)
-  
+                 
+            
+                                  
+                 
+ 
+                
+                
+                     
+ 
+                    
+                          
+                    
+                    
+                              
+                          
+                    
+                    
+                          
+                    
+                    
+                              
+                          
+                    
+                    
+                          
+                    
+                    
+                    
+      
+                              
+                                   
 
-                 3'b000:
-                begin
-                    case (rx_byte[7:4])
-  
+                          
+                    
+                    
+                    
+      
+                              
+                                   
 
-                     4'b0001:
-                        state <=  4'h1;
-                     4'b0011:
-                    begin
-                        {jtag_byte_2, jtag_byte_3} <= {jtag_byte_2, jtag_byte_3} + 1'b1;
-                        state <=  4'h6;
-                    end
-                     4'b0010:
-                        state <=  4'h1;
-                     4'b0100:
-                    begin
-                        {jtag_byte_2, jtag_byte_3} <= {jtag_byte_2, jtag_byte_3} + 1'b1;
-                        state <= 5;
-                    end
-                     4'b0101:
-                        state <=  4'h1;
- 
+                          
                     
-                     4'b0110:
-                    begin
-  
-     
-                        uart_rx_valid <=  1'b0;    
-                        uart_tx_valid <=  1'b0;         
- 
+                                                   
+                
 
-                        jtag_break <=  1'b1;
-                    end
-                     4'b0111:
-                    begin
-  
-     
-                        uart_rx_valid <=  1'b0;    
-                        uart_tx_valid <=  1'b0;         
- 
+                  
+                
+                
+                      
+                      
+                                    
+                
+                
+                      
+                      
+                
 
-                        jtag_reset <=  1'b1;
-                    end
-                    endcase                               
-                end
+                
+                    
+                                
+            
+        
  
-
-  
+        
+        
                  
-                 3'b001:
-                begin
-                    uart_rx_byte <= rx_byte;
-                    uart_rx_valid <=  1'b1;
-                end                    
-                 3'b010:
-                begin
-                    jtag_reg_d <= uart_tx_byte;
-                    uart_tx_valid <=  1'b0;
-                end
- 
+            
+                  
+                  
+            
+        
+        
+        
+                 
+            
+                  
+                  
+            
+        
+        
+        
+                 
+            
+                  
+                  
+            
+        
+        
+        
+                 
+            
+                  
+                   
+                      
+                 
+                      
+            
+        
+        
+        
+                 
+            
+                  
+                  
+            
+        
+        
+        
+             
+            
+            
+            
+                  
+                  
+                  
+            
+            
+            
+            
+                  
+                  
+                  
+            
+            
+            
+                  
+                  
+                  
+            
+            
+        
+        
+        
+               
+                      
+                  
+                  
+                    
+                  
+                  
+            
+            
+        
+        
+              
+              
+              
+            
+
+        
+    
 
-                default:
-                    ;
-                endcase                
-            end
-        end
   
 
-         4'h1:
-        begin
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                jtag_byte_0 <= rx_byte;
-                state <=  4'h2;
-            end
-        end
-         4'h2:
-        begin
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                jtag_byte_1 <= rx_byte;
-                state <=  4'h3;
-            end
-        end
-         4'h3:
-        begin
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                jtag_byte_2 <= rx_byte;
-                state <=  4'h4;
-            end
-        end
-         4'h4:
-        begin
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                jtag_byte_3 <= rx_byte;
-                if (command ==  4'b0001)
-                    state <=  4'h6;
-                else 
-                    state <=  4'h5;
-            end
-        end
-         4'h5:
-        begin
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                jtag_byte_4 <= rx_byte;
-                state <=  4'h6;
-            end
-        end
-         4'h6:
-        begin
-            case (command)
-             4'b0001,
-             4'b0011:
-            begin
-                jtag_read_enable <=  1'b1;
-                processing <=  1'b1;
-                state <=  4'h7;
-            end
-             4'b0010,
-             4'b0100:
-            begin
-                jtag_write_enable <=  1'b1;
-                processing <=  1'b1;
-                state <=  4'h7;
-            end
-             4'b0101:
-            begin
-                jtag_csr_write_enable <=  1'b1;
-                processing <=  1'b1;
-                state <=  4'h8;
-            end
-            endcase
-        end
-         4'h7:
-        begin
-            if (jtag_access_complete ==  1'b1)
-            begin          
-                jtag_read_enable <=  1'b0;
-                jtag_reg_d <= jtag_read_data;
-                jtag_write_enable <=  1'b0;  
-                processing <=  1'b0;
-                state <=  4'h0;
-            end
-        end    
-         4'h8:
-        begin
-            jtag_csr_write_enable <=  1'b0;
-            processing <=  1'b0;
-            state <=  4'h0;
-        end    
- 
 
-        endcase
-    end
-end
-  
-endmodule
 
- 
 
 
 
@@ -12415,7 +12213,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -12552,7 +12350,7 @@ endmodule
 
 
 
-module lm32_interrupt_full_debug (
+module lm32_interrupt_full (
     
     clk_i, 
     rst_i,
@@ -12561,18 +12359,17 @@ module lm32_interrupt_full_debug (
     
     stall_x,
   
-
-    non_debug_exception,
-    debug_exception,
- 
     
+    
+
 
+    exception,
+ 
 
     eret_q_x,
   
+    
 
-    bret_q_x,
- 
 
     csr,
     csr_write_data,
@@ -12601,21 +12398,20 @@ input [interrupts-1:0] interrupt;
 input stall_x;                                  
 
   
+                       
+                           
 
-input non_debug_exception;                      
-input debug_exception;                          
- 
-                                 
 
+input exception;                                
+ 
 
 input eret_q_x;                                 
   
+                                  
 
-input bret_q_x;                                 
- 
 
 
-input [ (5-1):0] csr;                      
+input [ (4 -1):0] csr;                      
 input [ (32-1):0] csr_write_data;          
 input csr_write_enable;                         
 
@@ -12636,15 +12432,17 @@ reg    [ (32-1):0] csr_read_data;
 wire [interrupts-1:0] asserted;                 
 
 wire [interrupts-1:0] interrupt_n_exception;
+wire [interrupts-1:0] ie_csr_read_data;
+wire [interrupts-1:0] ip_csr_read_data;
+wire [interrupts-1:0] im_csr_read_data;
 
 
 
 reg ie;                                         
 reg eie;                                        
   
+                                         
 
-reg bie;                                        
- 
 
 reg [interrupts-1:0] ip;                        
 reg [interrupts-1:0] im;                        
@@ -12664,11 +12462,11 @@ assign asserted = ip | interrupt;
        
 assign ie_csr_read_data = {{ 32-3{1'b0}}, 
   
-
-                           bie,
- 
                            
 
+
+                           1'b0,
+ 
                              
                            eie, 
                            ie
@@ -12682,19 +12480,19 @@ generate
 always @(*)
 begin
     case (csr)
-     5'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     4 'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
+                                    
 
-                                    bie,
- 
-                                                                         
 
+                                    1'b0,                                     
+ 
 
                                     eie, 
                                     ie
                                    };
-     5'h2:  csr_read_data = ip;
-     5'h1:  csr_read_data = im;
+     4 'h2:  csr_read_data = ip;
+     4 'h1:  csr_read_data = im;
     default:       csr_read_data = { 32{1'bx}};
     endcase
 end
@@ -12705,18 +12503,18 @@ end
 always @(*)
 begin
     case (csr)
-     5'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     4 'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
+                                     
 
-                                    bie, 
- 
-                                                                        
 
+                                    1'b0,                                    
+ 
 
                                     eie, 
                                     ie
                                    };
-     5'h2:  csr_read_data = ip;
+     4 'h2:  csr_read_data = ip;
     default:       csr_read_data = { 32{1'bx}};
       endcase
 end
@@ -12745,9 +12543,8 @@ always @(posedge clk_i  )
         ie                   <=  1'b0;
         eie                  <=  1'b0;
   
+                           
 
-        bie                  <=  1'b0;
- 
 
         im                   <= {interrupts{1'b0}};
         ip                   <= {interrupts{1'b0}};
@@ -12759,21 +12556,13 @@ always @(posedge clk_i  )
         
         ip                   <= asserted;
   
-
-        if (non_debug_exception ==  1'b1)
-        begin
+           
+        
             
-            eie              <= ie;
-            ie               <=  1'b0;
-        end
-        else if (debug_exception ==  1'b1)
-        begin
+                           
+                            
+        
             
-            bie              <= ie;
-            ie               <=  1'b0;
-        end
- 
-           
         
             
                            
@@ -12781,6 +12570,14 @@ always @(posedge clk_i  )
         
 
 
+        if (exception ==  1'b1)
+        begin
+            
+            eie              <= ie;
+            ie               <=  1'b0;
+        end
+ 
+
         else if (stall_x ==  1'b0)
         begin
 
@@ -12798,28 +12595,26 @@ always @(posedge clk_i  )
                       
            
   
-
-            else if (bret_q_x ==  1'b1)
                 
-                ie      <= bie;
- 
+                
+                       
+
 
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  5'h0)
+                if (csr ==  4 'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
   
+                      
 
-                    bie <= csr_write_data[2];
- 
 
                 end
-                if (csr ==  5'h1)
+                if (csr ==  4 'h1)
                     im  <= csr_write_data[interrupts-1:0];
-                if (csr ==  5'h2)
+                if (csr ==  4 'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -12836,9 +12631,8 @@ always @(posedge clk_i  )
         ie              <=  1'b0;
         eie             <=  1'b0;
   
+                      
 
-        bie             <=  1'b0;
- 
 
         ip              <= {interrupts{1'b0}};
        eie_delay        <= 0;
@@ -12848,21 +12642,13 @@ always @(posedge clk_i  )
         
         ip              <= asserted;
   
-
-        if (non_debug_exception ==  1'b1)
-        begin
+           
+        
             
-            eie         <= ie;
-            ie          <=  1'b0;
-        end
-        else if (debug_exception ==  1'b1)
-        begin
+                      
+                       
+        
             
-            bie         <= ie;
-            ie          <=  1'b0;
-        end
- 
-           
         
             
                       
@@ -12870,6 +12656,14 @@ always @(posedge clk_i  )
         
 
 
+        if (exception ==  1'b1)
+        begin
+            
+            eie         <= ie;
+            ie          <=  1'b0;
+        end
+ 
+
         else if (stall_x ==  1'b0)
           begin
 
@@ -12885,26 +12679,24 @@ always @(posedge clk_i  )
              end
            
   
-
-            else if (bret_q_x ==  1'b1)
                 
-                ie      <= bie;
- 
+                
+                       
+
 
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  5'h0)
+                if (csr ==  4 'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
   
+                      
 
-                    bie <= csr_write_data[2];
- 
 
                 end
-                if (csr ==  5'h2)
+                if (csr ==  4 'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -12971,6 +12763,8 @@ endmodule
 
   
 
+  
+
 	  
 
 	  
@@ -12996,19 +12790,26 @@ endmodule
 	  
 
 	  
-	 
-	 
-	 
-	 
+
 	  
+
 	  
-	
 
- 
+	  
 
+	  
 
+	  
 
-  
+	  
+
+	 
+
+ 
+
+
+
+  
 
 
 
@@ -13140,24 +12941,25 @@ endmodule
 
 
   
- 
 
+  
 
  
 
+ 
 
 
-  
- 
 
+  
 
   
+
+ 
+ 
  
 
 
- 
 
- 
 
 
 
@@ -13260,24 +13062,36 @@ endmodule
 
 
   
-                   
-                     
 
+  
 
   
+
+ 
+ 
                    
                      
 
+                    
+                     
+
+
+
+
 
   
 
   
 
- 
+  
 
- 
+  
+
+  
 
+  
 
+  
 
   
 
@@ -13287,6 +13101,8 @@ endmodule
 
   
 
+ 
+
   
 
   
@@ -13295,29 +13111,28 @@ endmodule
 
   
 
+ 
+
   
-                      
-                    
 
+  
 
   
 
   
-                     
-                     
 
+  
+
+  
+
+  
+
+  
 
   
-                     
-                     
-                     
-                     
-                     
-                     
-                     
-                     
 
  
+ 
 
 
   
@@ -13475,7 +13290,7 @@ endmodule
 
 
 
-module lm32_top_full (
+module lm32_top_full_debug (
     
     clk_i,
     rst_i,
@@ -13632,14 +13447,15 @@ wire   [ (2-1):0] D_BTE_O;
  
   
 
-  
-  
- 
-  
-  
- 
- 
 
+wire [ 7:0] jtag_reg_d;
+wire [ 7:0] jtag_reg_q;
+wire jtag_update;
+wire [2:0] jtag_reg_addr_d;
+wire [2:0] jtag_reg_addr_q;
+wire jtck;
+wire jrstn;
+ 
 
 
 
@@ -13718,7 +13534,7 @@ endfunction
 
    
 
-lm32_cpu_full cpu (
+lm32_cpu_full_debug cpu (
     
     .clk_i                 (clk_i),
   
@@ -13739,12 +13555,13 @@ lm32_cpu_full cpu (
 
      
   
-    
-                  
-               
-                
-           
 
+    
+    .jtag_clk              (jtck),
+    .jtag_update           (jtag_update),
+    .jtag_reg_q            (jtag_reg_q),
+    .jtag_reg_addr_q       (jtag_reg_addr_q),
+ 
 
   
 
@@ -13773,9 +13590,10 @@ lm32_cpu_full cpu (
 
 
   
-                
-           
 
+    .jtag_reg_d            (jtag_reg_d),
+    .jtag_reg_addr_d       (jtag_reg_addr_d),
+ 
 
       
                 
@@ -13810,20 +13628,21 @@ lm32_cpu_full cpu (
     .D_BTE_O               (D_BTE_O)
     );
    
-  		   
-
   
+		   
+
+jtag_cores jtag_cores (
     
-                     
-                
-    
-                
-                     
-                
-                      
-                     
+    .reg_d                 (jtag_reg_d),
+    .reg_addr_d            (jtag_reg_addr_d),
     
-
+    .reg_update            (jtag_update),
+    .reg_q                 (jtag_reg_q),
+    .reg_addr_q            (jtag_reg_addr_q),
+    .jtck                  (jtck),
+    .jrstn                 (jrstn)
+    );
+ 
         
    
 endmodule
@@ -14043,7 +13862,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -14195,7 +14014,7 @@ endmodule
 
 
 
-module lm32_mc_arithmetic_full (
+module lm32_mc_arithmetic_full_debug (
     
     clk_i,
     rst_i,
@@ -14724,7 +14543,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -14861,7 +14680,7 @@ endmodule
 
 
 
-module lm32_cpu_full (
+module lm32_cpu_full_debug (
     
     clk_i,
   
@@ -14882,12 +14701,13 @@ module lm32_cpu_full (
 
      
   
-    
-    
-     
-    
-    
 
+    
+    jtag_clk,
+    jtag_update, 
+    jtag_reg_q,
+    jtag_reg_addr_q,
+ 
 
   
 
@@ -14916,9 +14736,10 @@ module lm32_cpu_full (
 
 
   
-    
-    
 
+    jtag_reg_d,
+    jtag_reg_addr_d,
+ 
 
       
     
@@ -14959,8 +14780,9 @@ module lm32_cpu_full (
 
 parameter eba_reset =  32'h00000000;                           
   
-                            
 
+parameter deba_reset =  32'h10000000;                         
+ 
 
 
   
@@ -14996,11 +14818,11 @@ parameter dcache_limit =  32'h7fffffff;
 
 
   
-                          
-
 
-parameter watchpoints = 0;
+parameter watchpoints =  32'h4;                       
  
+   
+
 
   
                           
@@ -15042,11 +14864,12 @@ input [ (32-1):0] interrupt;
     
 
   
-                                  
-                               
-                
-  
 
+input jtag_clk;                                 
+input jtag_update;                              
+input [ 7:0] jtag_reg_q;              
+input [2:0] jtag_reg_addr_q;
+ 
 
 
   
@@ -15086,11 +14909,12 @@ input D_RTY_I;
 
 
   
-  
-    
-  
-    
 
+output [ 7:0] jtag_reg_d;
+wire   [ 7:0] jtag_reg_d;
+output [2:0] jtag_reg_addr_d;
+wire   [2:0] jtag_reg_addr_d;
+ 
 
 
   
@@ -15171,6 +14995,9 @@ reg load_x;
 reg load_m;
 wire load_q_x;
 wire store_q_x;
+wire q_m;
+wire load_q_m;
+wire store_q_m;
 wire store_d;                                   
 reg store_x;
 reg store_m;
@@ -15202,6 +15029,7 @@ wire x_result_sel_csr_d;
 reg x_result_sel_csr_x;
   
 
+wire q_d;
 wire x_result_sel_mc_arith_d;                   
 reg x_result_sel_mc_arith_x;
  
@@ -15270,14 +15098,15 @@ wire [ (5-1):0] write_idx_d;
 reg [ (5-1):0] write_idx_x;            
 reg [ (5-1):0] write_idx_m;
 reg [ (5-1):0] write_idx_w;
-wire [ (3-1):0] csr_d;                     
-reg  [ (3-1):0] csr_x;                  
+wire [ (5-1):0] csr_d;                     
+reg  [ (5-1):0] csr_x;                  
 wire [ (3-1):0] condition_d;         
 reg [ (3-1):0] condition_x;          
   
-                                    
-                                     
 
+wire break_d;                                   
+reg break_x;                                    
+ 
 
 wire scall_d;                                   
 reg scall_x;    
@@ -15290,14 +15119,16 @@ reg eret_m;
 
 
   
-                                     
- 
- 
- 
- 
+
+wire bret_d;                                    
+reg bret_x;
+wire bret_q_x;
+reg bret_m;
+  
  
 
 
+ 
 
 wire csr_write_enable_d;                        
 reg csr_write_enable_x;
@@ -15503,25 +15334,32 @@ wire stall_wb_load;
 
 
   
- 
-          
-          
 
- 
-                      
-        
-                    
-                           
   
+
+wire [ (32-1):0] jtx_csr_read_data;        
+wire [ (32-1):0] jrx_csr_read_data;        
  
+
   
-  
- 
 
+wire jtag_csr_write_enable;                     
+wire [ (32-1):0] jtag_csr_write_data;      
+wire [ (5-1):0] jtag_csr;                  
+wire jtag_read_enable;                          
+wire [ 7:0] jtag_read_data;
+wire jtag_write_enable;
+wire [ 7:0] jtag_write_data;
+wire [ (32-1):0] jtag_address;
+wire jtag_access_complete;
  
-                                 
 
+  
+
+wire jtag_break;                                
+ 
 
+ 
 
 
 
@@ -15554,8 +15392,9 @@ wire kill_w;
 
 reg [ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8] eba;                 
   
-                  
 
+reg [ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8] deba;                
+ 
 
 reg [ (3-1):0] eid_x;                      
   
@@ -15565,34 +15404,41 @@ reg [ (3-1):0] eid_x;
 
 
   
- 
-                                      
 
-                                      
-                                
-                                 
-                          
- 
+  
+
+wire dc_ss;                                     
  
+
+wire dc_re;                                     
+wire bp_match;
+wire wp_match;
+wire exception_x;                               
+reg exception_m;                                
+wire debug_exception_x;                         
+reg debug_exception_m;
+reg debug_exception_w;
+wire debug_exception_q_w;
+wire non_debug_exception_x;                     
+reg non_debug_exception_m;
+reg non_debug_exception_w;
+wire non_debug_exception_q_w;
  
-                      
+                                
  
  
  
 
 
-wire exception_x;                               
-reg exception_m;
-reg exception_w;
-wire exception_q_w;
- 
 
+  
 
   
- 
-                            
 
+wire reset_exception;                           
+ 
 
+ 
 
   
 
@@ -15600,9 +15446,10 @@ wire interrupt_exception;
  
 
   
-                       
-                       
 
+wire breakpoint_exception;                      
+wire watchpoint_exception;                      
+ 
 
   
 
@@ -15686,7 +15533,7 @@ endfunction
 
 
 
-lm32_instruction_unit_full #(
+lm32_instruction_unit_full_debug #(
     .associativity          (icache_associativity),
     .sets                   (icache_sets),
     .bytes_per_line         (icache_bytes_per_line),
@@ -15745,11 +15592,12 @@ lm32_instruction_unit_full #(
  
 
   
-           
-          
-            
-               
 
+    .jtag_read_enable       (jtag_read_enable),
+    .jtag_write_enable      (jtag_write_enable),
+    .jtag_write_data        (jtag_write_data),
+    .jtag_address           (jtag_address),
+ 
 
     
     
@@ -15785,9 +15633,10 @@ lm32_instruction_unit_full #(
  
 
   
-             
-       
 
+    .jtag_read_data         (jtag_read_data),
+    .jtag_access_complete   (jtag_access_complete),
+ 
 
   
 
@@ -15803,7 +15652,7 @@ lm32_instruction_unit_full #(
     );
 
 
-lm32_decoder_full decoder (
+lm32_decoder_full_debug decoder (
     
     .instruction            (instruction_d),
     
@@ -15884,14 +15733,16 @@ lm32_decoder_full decoder (
     .branch_reg             (branch_reg_d),
     .condition              (condition_d),
   
-               
 
+    .break_opcode           (break_d),
+ 
 
     .scall                  (scall_d),
     .eret                   (eret_d),
   
-                       
 
+    .bret                   (bret_d),
+ 
 
   
                 
@@ -15901,7 +15752,7 @@ lm32_decoder_full decoder (
     ); 
 
 
-lm32_load_store_unit_full #(
+lm32_load_store_unit_full_debug #(
     .associativity          (dcache_associativity),
     .sets                   (dcache_sets),
     .bytes_per_line         (dcache_bytes_per_line),
@@ -16037,7 +15888,7 @@ lm32_multiplier multiplier (
   
 
 
-lm32_mc_arithmetic_full mc_arithmetic (
+lm32_mc_arithmetic_full_debug mc_arithmetic (
     
     .clk_i                  (clk_i),
     .rst_i                  (rst_i),
@@ -16076,7 +15927,7 @@ lm32_mc_arithmetic_full mc_arithmetic (
   
 
 
-lm32_interrupt_full interrupt_unit (
+lm32_interrupt_full_debug interrupt_unit (
     
     .clk_i                  (clk_i), 
     .rst_i                  (rst_i),
@@ -16085,17 +15936,18 @@ lm32_interrupt_full interrupt_unit (
     
     .stall_x                (stall_x),
   
-         
-            
-
 
-    .exception              (exception_q_w), 
+    .non_debug_exception    (non_debug_exception_q_w), 
+    .debug_exception        (debug_exception_q_w),
  
+                   
+
 
     .eret_q_x               (eret_q_x),
   
-                   
 
+    .bret_q_x               (bret_q_x),
+ 
 
     .csr                    (csr_x),
     .csr_write_data         (operand_1_x),
@@ -16110,95 +15962,117 @@ lm32_interrupt_full interrupt_unit (
 
   
 
-  
+
+lm32_jtag_full_debug jtag (
     
-                      
-                      
+    .clk_i                  (clk_i),
+    .rst_i                  (rst_i),
     
-                   
-                
-                 
-            
+    .jtag_clk               (jtag_clk),
+    .jtag_update            (jtag_update),
+    .jtag_reg_q             (jtag_reg_q),
+    .jtag_reg_addr_q        (jtag_reg_addr_q),
     
+  
+
+    .csr                    (csr_x),
+    .csr_write_data         (operand_1_x),
+    .csr_write_enable       (csr_write_enable_q_x),
+    .stall_x                (stall_x),
  
-                        
-             
-           
-                    
 
+  
+
+    .jtag_read_data         (jtag_read_data),
+    .jtag_access_complete   (jtag_access_complete),
  
-             
-       
 
+  
+
+    .exception_q_w          (debug_exception_q_w || non_debug_exception_q_w),
  
-                
     
     
     
+  
+
+    .jtx_csr_read_data      (jtx_csr_read_data),
+    .jrx_csr_read_data      (jrx_csr_read_data),
  
-          
-          
 
+  
+
+    .jtag_csr_write_enable  (jtag_csr_write_enable),
+    .jtag_csr_write_data    (jtag_csr_write_data),
+    .jtag_csr               (jtag_csr),
+    .jtag_read_enable       (jtag_read_enable),
+    .jtag_write_enable      (jtag_write_enable),
+    .jtag_write_data        (jtag_write_data),
+    .jtag_address           (jtag_address),
  
-      
-        
-                   
-           
-          
-            
-               
 
+  
+
+    .jtag_break             (jtag_break),
+    .jtag_reset             (reset_exception),
  
-                 
-                 
 
     
-                 
-            
-    
-
+    .jtag_reg_d             (jtag_reg_d),
+    .jtag_reg_addr_d        (jtag_reg_addr_d)
+    );
+ 
 
 
   
 
- 
-                
-                
-    
+
+lm32_debug_full_debug #(
+    .breakpoints            (breakpoints),
+    .watchpoints            (watchpoints)
+  ) hw_debug (
     
-                       
-                      
-                       
-                     
-                    
-       
-         
-             
-                      
- 
-      
-        
-                   
+    .clk_i                  (clk_i), 
+    .rst_i                  (rst_i),
+    .pc_x                   (pc_x),
+    .load_x                 (load_x),
+    .store_x                (store_x),
+    .load_store_address_x   (adder_result_x),
+    .csr_write_enable_x     (csr_write_enable_q_x),
+    .csr_write_data         (operand_1_x),
+    .csr_x                  (csr_x),
+  
 
+    .jtag_csr_write_enable  (jtag_csr_write_enable),
+    .jtag_csr_write_data    (jtag_csr_write_data),
+    .jtag_csr               (jtag_csr),
  
-                   
-                   
-                    
-                
-                        
- 
-      
 
+  
+
+    .eret_q_x               (eret_q_x),
+    .bret_q_x               (bret_q_x),
+    .stall_x                (stall_x),
+    .exception_x            (exception_x),
+    .q_x                    (q_x),
+  
+
+    .dcache_refill_request  (dcache_refill_request),
+ 
 
-    
  
-                      
 
-                      
-                   
-                   
     
+  
 
+    .dc_ss                  (dc_ss),
+ 
+
+    .dc_re                  (dc_re),
+    .bp_match               (bp_match),
+    .wp_match               (wp_match)
+    );
+ 
 
 
 
@@ -16698,21 +16572,25 @@ assign kill_w =     1'b0
 
 
   
-              
-				         
-				     
-				     
-				 
- 
-                                 
 
-                              
+assign breakpoint_exception =    (   (   (break_x ==  1'b1)
+				      || (bp_match ==  1'b1)
+				     )
+				  && (valid_x ==  1'b1)
+				 )
+  
 
+                              || (jtag_break ==  1'b1)
+ 
+
+                              ;
+ 
 
 
   
-     
 
+assign watchpoint_exception = wp_match ==  1'b1;
+ 
 
 
   
@@ -16739,38 +16617,17 @@ assign system_call_exception = (   (scall_x ==  1'b1)
 			       );
 
   
-      
-                            
-                         
 
-     
- 
-                               
-
- 
-                               
-                               
+assign debug_exception_x =  (breakpoint_exception ==  1'b1)
+                         || (watchpoint_exception ==  1'b1)
+                         ;
 
- 
-                               
+assign non_debug_exception_x = (system_call_exception ==  1'b1)
+  
 
+                            || (reset_exception ==  1'b1)
  
-                                  
- 
-                                   
-                            
- 
- 				   
-				   
-
-                               
-
-                            
-
-         
 
-
-assign exception_x =           (system_call_exception ==  1'b1)
   
 
                             || (instruction_bus_error_exception ==  1'b1)
@@ -16786,8 +16643,9 @@ assign exception_x =           (system_call_exception ==  1'b1)
 
                             || (   (interrupt_exception ==  1'b1)
   
-                                   
 
+                                && (dc_ss ==  1'b0)
+ 
                             
   
 
@@ -16799,27 +16657,55 @@ assign exception_x =           (system_call_exception ==  1'b1)
  
 
                             ;
+
+assign exception_x = (debug_exception_x ==  1'b1) || (non_debug_exception_x ==  1'b1);
+ 
+               
  
+                               
+                               
+
+ 
+                               
+
+ 
+                                  
+ 
+                                   
+                            
+ 
+ 				   
+				   
+
+                               
+
+                            
+
 
 
 
 always @(*)
 begin
   
+
+  
+
+    if (reset_exception ==  1'b1)
+        eid_x =  3'h0;
+    else
  
-       
-          
-    
      
- 
-            
-          
-    
+  
 
-            
-          
-    
+         if (data_bus_error_exception ==  1'b1)
+        eid_x =  3'h4;
+    else
+ 
 
+         if (breakpoint_exception ==  1'b1)
+        eid_x =  3'd1;
+    else
+ 
 
   
 
@@ -16832,10 +16718,11 @@ begin
  
 
   
-            
-          
-     
 
+         if (watchpoint_exception ==  1'b1)
+        eid_x =  3'd3;
+    else 
+ 
 
   
 
@@ -16848,8 +16735,9 @@ begin
 
          if (   (interrupt_exception ==  1'b1)
   
-                
 
+             && (dc_ss ==  1'b0)
+ 
                             
             )
         eid_x =  3'h6;
@@ -16886,18 +16774,19 @@ assign stall_d =   (stall_x ==  1'b1)
                     && (kill_d ==  1'b0)
 		   )
   
-		         
-			   
-		       
-		          
-			   
-			   
-			   
-			   
-		       
-                       
-		   
 
+		|| (   (   (break_d ==  1'b1)
+			|| (bret_d ==  1'b1)
+		       )
+		    && (   (load_q_x ==  1'b1)
+			|| (store_q_x ==  1'b1)
+			|| (load_q_m ==  1'b1)
+			|| (store_q_m ==  1'b1)
+			|| (D_CYC_O ==  1'b1)
+		       )
+                    && (kill_d ==  1'b0)
+		   )
+ 
                    
                 || (   (csr_write_enable_d ==  1'b1)
                     && (load_q_x ==  1'b1)
@@ -17003,21 +16892,24 @@ assign q_x = (valid_x ==  1'b1) && (kill_x ==  1'b0);
 assign csr_write_enable_q_x = (csr_write_enable_x ==  1'b1) && (q_x ==  1'b1);
 assign eret_q_x = (eret_x ==  1'b1) && (q_x ==  1'b1);
   
-         
 
+assign bret_q_x = (bret_x ==  1'b1) && (q_x ==  1'b1);
+ 
 
 assign load_q_x = (load_x ==  1'b1) 
                && (q_x ==  1'b1)
   
-                  
 
+               && (bp_match ==  1'b0)
+ 
 
                   ;
 assign store_q_x = (store_x ==  1'b1) 
                && (q_x ==  1'b1)
   
-                  
 
+               && (bp_match ==  1'b0)
+ 
 
                   ;
   
@@ -17028,12 +16920,12 @@ assign q_m = (valid_m ==  1'b1) && (kill_m ==  1'b0) && (exception_m ==  1'b0);
 assign load_q_m = (load_m ==  1'b1) && (q_m ==  1'b1);
 assign store_q_m = (store_m ==  1'b1) && (q_m ==  1'b1);
   
-         
-                 
 
-
-assign exception_q_w = ((exception_w ==  1'b1) && (valid_w ==  1'b1));        
+assign debug_exception_q_w = ((debug_exception_w ==  1'b1) && (valid_w ==  1'b1));
+assign non_debug_exception_q_w = ((non_debug_exception_w ==  1'b1) && (valid_w ==  1'b1));        
  
+                 
+
 
 
 assign write_enable_q_x = (write_enable_x ==  1'b1) && (valid_x ==  1'b1) && (branch_flushX_m ==  1'b0);
@@ -17049,19 +16941,12 @@ assign cfg = {
               breakpoints[3:0],
               interrupts[5:0],
   
-              
 
-
-               1'b0,
+               1'b1,
  
-
-  
               
 
 
-               1'b0,
- 
-
   
               
 
@@ -17070,11 +16955,18 @@ assign cfg = {
  
 
   
+
+               1'b1,
+ 
               
 
 
-               1'b0,
+  
+
+               1'b1,
  
+              
+
 
   
 
@@ -17156,16 +17048,17 @@ assign cfg2 = {
   
 
 assign iflush = (   (csr_write_enable_d ==  1'b1) 
-                 && (csr_d ==  3'h3)
+                 && (csr_d ==  5'h3)
                  && (stall_d ==  1'b0)
                  && (kill_d ==  1'b0)
                  && (valid_d ==  1'b1))
 
   
-             
-                     
-		    
 
+             ||
+                (   (jtag_csr_write_enable ==  1'b1)
+		 && (jtag_csr ==  5'h3))
+ 
 
 		 ;
  
@@ -17173,20 +17066,21 @@ assign iflush = (   (csr_write_enable_d ==  1'b1)
   
 
 assign dflush_x = (   (csr_write_enable_q_x ==  1'b1) 
-                   && (csr_x ==  3'h4))
+                   && (csr_x ==  5'h4))
 
   
-               
-                       
-		      
 
+               ||
+                  (   (jtag_csr_write_enable ==  1'b1)
+		   && (jtag_csr ==  5'h4))
+ 
 
 		   ;
  
  
 
 
-assign csr_d = read_idx_0_d[ (3-1):0];
+assign csr_d = read_idx_0_d[ (5-1):0];
 
 
 always @(*)
@@ -17194,27 +17088,29 @@ begin
     case (csr_x)
   
 
-     3'h0,
-     3'h1,
-     3'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
+     5'h0,
+     5'h1,
+     5'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
  
 
   
          
 
 
-     3'h6:  csr_read_data_x = cfg;
-     3'h7:  csr_read_data_x = {eba, 8'h00};
+     5'h6:  csr_read_data_x = cfg;
+     5'h7:  csr_read_data_x = {eba, 8'h00};
   
-        
 
+     5'h9: csr_read_data_x = {deba, 8'h00};
+ 
 
   
-          
-        
 
+     5'he:  csr_read_data_x = jtx_csr_read_data;  
+     5'hf:  csr_read_data_x = jrx_csr_read_data;
+ 
 
-     3'ha: csr_read_data_x = cfg2;
+     5'ha: csr_read_data_x = cfg2;
       
     default:        csr_read_data_x = { 32{1'bx}};
     endcase
@@ -17231,33 +17127,37 @@ begin
         eba <= eba_reset[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
     else
     begin
-        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  3'h7) && (stall_x ==  1'b0))
+        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  5'h7) && (stall_x ==  1'b0))
             eba <= operand_1_x[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
   
-               
-              
 
+        if ((jtag_csr_write_enable ==  1'b1) && (jtag_csr ==  5'h7))
+            eba <= jtag_csr_write_data[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+ 
 
     end
 end
 
   
 
-   
 
-       
-          
-    
-    
-                   
-              
- 
-               
-              
-
-    
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+        deba <= deba_reset[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+    else
+    begin
+        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  5'h9) && (stall_x ==  1'b0))
+            deba <= operand_1_x[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+  
 
+        if ((jtag_csr_write_enable ==  1'b1) && (jtag_csr ==  5'h9))
+            deba <= jtag_csr_write_data[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+ 
 
+    end
+end
+ 
 
 
 
@@ -17439,7 +17339,7 @@ begin
         m_bypass_enable_x <=  1'b0;
         write_enable_x <=  1'b0;
         write_idx_x <= { 5{1'b0}};
-        csr_x <= { 3{1'b0}};
+        csr_x <= { 5{1'b0}};
         load_x <=  1'b0;
         store_x <=  1'b0;
         size_x <= { 2{1'b0}};
@@ -17462,14 +17362,16 @@ begin
         branch_predict_taken_x <=  1'b0;
         condition_x <=  3'b000;
   
-          
 
+        break_x <=  1'b0;
+ 
 
         scall_x <=  1'b0;
         eret_x <=  1'b0;
   
-          
 
+        bret_x <=  1'b0;
+ 
 
   
 
@@ -17513,9 +17415,10 @@ begin
  
 
   
-          
-                  
 
+        debug_exception_m <=  1'b0;
+        non_debug_exception_m <=  1'b0;        
+ 
 
         operand_w <= { 32{1'b0}};        
         w_result_sel_load_w <=  1'b0;
@@ -17527,12 +17430,12 @@ begin
         write_idx_w <= { 5{1'b0}};        
         write_enable_w <=  1'b0;
   
-          
-                  
-
 
-        exception_w <=  1'b0;
+        debug_exception_w <=  1'b0;
+        non_debug_exception_w <=  1'b0;        
  
+          
+
 
   
 
@@ -17613,8 +17516,9 @@ begin
             condition_x <= condition_d;
             csr_write_enable_x <= csr_write_enable_d;
   
-              
 
+            break_x <= break_d;
+ 
 
             scall_x <= scall_d;
   
@@ -17624,8 +17528,9 @@ begin
 
             eret_x <= eret_d;
   
-               
 
+            bret_x <= bret_d; 
+ 
 
             write_enable_x <= write_enable_d;
         end
@@ -17677,40 +17582,40 @@ begin
 
 
   
+
 	   
 	   
 	   
 	   
 	   
-                
-                  
-                
-                  
-             
-                  
-
-
-            if (exception_x ==  1'b1)
+            if (non_debug_exception_x ==  1'b1) 
                 write_idx_m <=  5'd30;
+            else if (debug_exception_x ==  1'b1)
+                write_idx_m <=  5'd31;
             else 
                 write_idx_m <= write_idx_x;
  
+               
+                  
+             
+                  
+
 
             condition_met_m <= condition_met_x;
   
-	      
-	        
-		     
-		        
-	           
-	     
-	           
-	   
-	       
 
-
-            branch_target_m <= exception_x ==  1'b1 ? {eba, eid_x, {3{1'b0}}} : branch_target_x;
+	   if (exception_x ==  1'b1)
+	     if ((dc_re ==  1'b1)
+		 || ((debug_exception_x ==  1'b1) 
+		     && (non_debug_exception_x ==  1'b0)))
+	       branch_target_m <= {deba, eid_x, {3{1'b0}}};
+	     else
+	       branch_target_m <= {eba, eid_x, {3{1'b0}}};
+	   else
+	     branch_target_m <= branch_target_x;
  
+                      
+
 
   
               
@@ -17723,14 +17628,16 @@ begin
 
             eret_m <= eret_q_x;
   
-               
 
+            bret_m <= bret_q_x; 
+ 
 
             write_enable_m <= exception_x ==  1'b1 ?  1'b1 : write_enable_x;            
   
-              
-                      
 
+            debug_exception_m <= debug_exception_x;
+            non_debug_exception_m <= non_debug_exception_x;        
+ 
 
         end
         
@@ -17745,8 +17652,9 @@ begin
 
 	   data_bus_error_exception_m <=    (data_bus_error_exception ==  1'b1) 
   
-					    
 
+					 && (reset_exception ==  1'b0)
+ 
 
 					 ;
  
@@ -17778,12 +17686,12 @@ begin
 
         write_enable_w <= write_enable_m;
   
-          
-          
 
-
-        exception_w <= exception_m;
+        debug_exception_w <= debug_exception_m;
+        non_debug_exception_w <= non_debug_exception_m;
  
+          
+
 
   
 
@@ -18192,7 +18100,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -18329,7 +18237,7 @@ endmodule
 
 
 
-module lm32_load_store_unit_full (
+module lm32_load_store_unit_full_debug (
     
     clk_i,
     rst_i,
@@ -18707,7 +18615,7 @@ endfunction
   
 
 
-lm32_dcache_full #(
+lm32_dcache_full_debug #(
     .associativity          (associativity),
     .sets                   (sets),
     .bytes_per_line         (bytes_per_line),
@@ -19424,7 +19332,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -19659,7 +19567,7 @@ endmodule
 
 
 
-module lm32_decoder_full (
+module lm32_decoder_full_debug (
     
     instruction,
     
@@ -19740,14 +19648,16 @@ module lm32_decoder_full (
     bi_conditional,
     bi_unconditional,
   
-    
 
+    break_opcode,
+ 
 
     scall,
     eret,
   
-    
 
+    bret,
+ 
 
   
     
@@ -19883,18 +19793,20 @@ wire bi_conditional;
 output bi_unconditional;
 wire bi_unconditional;
   
- 
-   
 
+output break_opcode;
+wire   break_opcode;
+ 
 
 output scall;
 wire   scall;
 output eret;
 wire   eret;
   
- 
-   
 
+output bret;
+wire   bret;
+ 
 
   
   
@@ -19916,6 +19828,92 @@ wire sign_extend_immediate;
 wire select_high_immediate;                     
 wire select_call_immediate;                     
 
+wire op_add;
+wire op_and;
+wire op_andhi;
+wire op_b;
+wire op_bi;
+wire op_be;
+wire op_bg;
+wire op_bge;
+wire op_bgeu;
+wire op_bgu;
+wire op_bne;
+wire op_call;
+wire op_calli;
+wire op_cmpe;
+wire op_cmpg;
+wire op_cmpge;
+wire op_cmpgeu;
+wire op_cmpgu;
+wire op_cmpne;
+  
+
+wire op_divu;
+ 
+
+wire op_lb;
+wire op_lbu;
+wire op_lh;
+wire op_lhu;
+wire op_lw;
+  
+
+wire op_modu;
+ 
+
+  
+
+wire op_mul;
+ 
+
+wire op_nor;
+wire op_or;
+wire op_orhi;
+wire op_raise;
+wire op_rcsr;
+wire op_sb;
+  
+
+wire op_sextb;
+wire op_sexth;
+ 
+
+wire op_sh;
+  
+
+wire op_sl;
+ 
+
+wire op_sr;
+wire op_sru;
+wire op_sub;
+wire op_sw;
+wire op_user;
+wire op_wcsr;
+wire op_xnor;
+wire op_xor;
+
+wire arith;
+wire logical;
+wire cmp;
+wire bra;
+wire call;
+  
+
+wire shift;
+ 
+
+  
+ 
+
+
+  
+
+wire sext;
+ 
+
+
 
 
 
@@ -20073,9 +20071,8 @@ assign sext = op_sextb | op_sexth;
  
 
   
+   
 
-assign multiply = op_mul;
- 
 
   
 
@@ -20258,14 +20255,16 @@ assign branch = bra | call;
 assign branch_reg = op_call | op_b;
 assign condition = instruction[28:26];      
   
-     
 
+assign break_opcode = op_raise & ~instruction[2];
+ 
 
 assign scall = op_raise & instruction[2];
 assign eret = op_b & (instruction[25:21] == 5'd30);
   
-       
 
+assign bret = op_b & (instruction[25:21] == 5'd31);
+ 
 
   
 
@@ -20519,7 +20518,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -20697,7 +20696,7 @@ endmodule
 
 
 
-module lm32_icache_full ( 
+module lm32_icache_full_debug ( 
     
     clk_i,
     rst_i,    
@@ -21367,7 +21366,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -21543,7 +21542,7 @@ endmodule
 
 
 
-module lm32_dcache_full ( 
+module lm32_dcache_full_debug ( 
     
     clk_i,
     rst_i,    
@@ -22263,7 +22262,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -22399,314 +22398,160 @@ endmodule
   
 
 
-                  
-                 
-         
-     
-     
-              
-
-
-
 
+  
 
   
-    
-     
-    
-    
-    
-    
-    
-    
-    
-    
- 
-    
-    
-    
 
- 
-    
-    
-    
-    
-    
- 
-    
+  
 
+  
 
-    
- 
-    
+  
 
-    
-    
-    
-    
-    
+  
 
 
 
 
-                         
-                         
 
 
+module lm32_debug_full_debug (
+    
+    clk_i, 
+    rst_i,
+    pc_x,
+    load_x,
+    store_x,
+    load_store_address_x,
+    csr_write_enable_x,
+    csr_write_data,
+    csr_x,
+  
 
+    jtag_csr_write_enable,
+    jtag_csr_write_data,
+    jtag_csr,
+ 
 
+  
 
-                                     
-                                     
+    eret_q_x,
+    bret_q_x,
+    stall_x,
+    exception_x,
+    q_x,
+  
 
-                        
-                                    
-                                   
-      
-                        
-            
-                      
+    dcache_refill_request,
  
-                     
-       
-                   
 
  
-                                  
-                                  
-                                   
-                               
-                                       
- 
-                     
-
-
-
-
-
 
+    
+  
 
+    dc_ss,
  
-                                    
-    
 
-                                    
+    dc_re,
+    bp_match,
+    wp_match
+    );
     
-                                 
-           
-                                 
-   
 
 
 
 
-
-                                        
-
-
-
-         
-                       
-                
-
-     
-         
-                
-
-                     
-       
-                   
-
- 
-
-             
+parameter breakpoints = 0;                      
+parameter watchpoints = 0;                      
 
 
 
 
 
+input clk_i;                                    
+input rst_i;                                    
 
+input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_x;                      
+input load_x;                                   
+input store_x;                                  
+input [ (32-1):0] load_store_address_x;    
+input csr_write_enable_x;                       
+input [ (32-1):0] csr_write_data;          
+input [ (5-1):0] csr_x;                    
+  
 
+input jtag_csr_write_enable;                    
+input [ (32-1):0] jtag_csr_write_data;     
+input [ (5-1):0] jtag_csr;                 
  
 
+  
 
+input eret_q_x;                                 
+input bret_q_x;                                 
+input stall_x;                                  
+input exception_x;                              
+input q_x;                                      
+  
 
-
-
-
-
-               
-      
-         
-    
-
- 
+input dcache_refill_request;                    
  
-        
-       
-    
-     
-
-        
-   
-    
-   
-
-    
-               
 
  
-               
-      
-             
-                   
 
 
-        
-                   
-    
-   
-
-                
-                 
-
-         
-         
-         
-
-   
-   
-   
 
 
 
 
+  
 
+output dc_ss;                                   
+reg    dc_ss;
+ 
 
+output dc_re;                                   
+reg    dc_re;
+output bp_match;                                
+wire   bp_match;        
+output wp_match;                                
+wire   wp_match;
 
 
-               
-      
-   
 
-       
-    
-          
-          
-    
-    
-    
-                 
-        
-              
-              
-        
-    
-    
-    
 
 
+genvar i;                                       
 
 
-               
-      
-   
 
-       
-    
-          
-          
-    
-    
-    
-           
-        
-               
-                  
-                 
-                  
-        
-      
+reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] bp_a[0:breakpoints-1];       
+reg bp_e[0:breakpoints-1];                      
+wire [0:breakpoints-1]bp_match_n;               
 
-    
+reg [ 1:0] wpc_c[0:watchpoints-1];   
+reg [ (32-1):0] wp[0:watchpoints-1];       
+wire [0:watchpoints]wp_match_n;               
 
+wire debug_csr_write_enable;                    
+wire [ (32-1):0] debug_csr_write_data;     
+wire [ (5-1):0] debug_csr;                 
 
+  
 
-   
 
-       
-          
-    
-    
-               
-              
-    
-    
+reg [ 2:0] state;           
 
  
 
-   
 
-       
-    
-          
-          
-    
-    
-    
-               
-        
-              
-                
-                  
-             
-                  
-        
-         
-        
-        
-            
-                     
-                       
-                    
-                   
-               
-                   
-        
-        
-        
-            
-                   
-                  
-        
-        
-        
-            
- 
-               
-                  
-             
 
-                            
-            
-                  
-                  
-            
-        
-        
-        
-            
- 
-               
-                  
-             
 
-                  
-        
-        
-    
 
 
+  
 
 
 
@@ -22729,6 +22574,247 @@ endmodule
 
 
 
+
+
+
+
+
+
+					  
+function integer clogb2;
+input [31:0] value;
+begin
+   for (clogb2 = 0; value > 0; clogb2 = clogb2 + 1)
+        value = value >> 1;
+end
+endfunction 
+
+function integer clogb2_v1;
+input [31:0] value;
+reg   [31:0] i;
+reg   [31:0] temp;
+begin
+   temp = 0;
+   i    = 0;
+   for (i = 0; temp < value; i = i + 1)  
+	temp = 1<<i;
+   clogb2_v1 = i-1;
+end
+endfunction
+
+
+
+
+
+
+
+
+
+generate
+    for (i = 0; i < breakpoints; i = i + 1)
+    begin : bp_comb
+assign bp_match_n[i] = ((bp_a[i] == pc_x) && (bp_e[i] ==  1'b1));
+    end
+endgenerate
+generate 
+  
+
+    if (breakpoints > 0) 
+assign bp_match = (|bp_match_n) || (state ==  3'b011);
+    else
+assign bp_match = state ==  3'b011;
+ 
+        
+   
+    
+   
+
+
+endgenerate    
+               
+
+generate 
+    for (i = 0; i < watchpoints; i = i + 1)
+    begin : wp_comb
+assign wp_match_n[i] = (wp[i] == load_store_address_x) && ((load_x & wpc_c[i][0]) | (store_x & wpc_c[i][1]));
+    end               
+endgenerate
+generate
+    if (watchpoints > 0) 
+assign wp_match = |wp_match_n;                
+    else
+assign wp_match =  1'b0;
+endgenerate
+                
+  
+                
+
+assign debug_csr_write_enable = (csr_write_enable_x ==  1'b1) || (jtag_csr_write_enable ==  1'b1);
+assign debug_csr_write_data = jtag_csr_write_enable ==  1'b1 ? jtag_csr_write_data : csr_write_data;
+assign debug_csr = jtag_csr_write_enable ==  1'b1 ? jtag_csr : csr_x;
+ 
+   
+   
+   
+
+
+
+
+
+
+
+
+generate
+    for (i = 0; i < breakpoints; i = i + 1)
+    begin : bp_seq
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        bp_a[i] <= { (clogb2(32'h7fffffff-32'h0)-2){1'bx}};
+        bp_e[i] <=  1'b0;
+    end
+    else
+    begin
+        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h10 + i))
+        begin
+            bp_a[i] <= debug_csr_write_data[ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2];
+            bp_e[i] <= debug_csr_write_data[0];
+        end
+    end
+end    
+    end
+endgenerate
+
+
+generate
+    for (i = 0; i < watchpoints; i = i + 1)
+    begin : wp_seq
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        wp[i] <= { 32{1'bx}};
+        wpc_c[i] <=  2'b00;
+    end
+    else
+    begin
+        if (debug_csr_write_enable ==  1'b1)
+        begin
+            if (debug_csr ==  5'h8)
+                wpc_c[i] <= debug_csr_write_data[3+i*2:2+i*2];
+            if (debug_csr ==  5'h18 + i)
+                wp[i] <= debug_csr_write_data;
+        end
+    end  
+end
+    end
+endgenerate
+
+
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+        dc_re <=  1'b0;
+    else
+    begin
+        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h8))
+            dc_re <= debug_csr_write_data[1];
+    end
+end    
+
+  
+
+
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        state <=  3'b000;
+        dc_ss <=  1'b0;
+    end
+    else
+    begin
+        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h8))
+        begin
+            dc_ss <= debug_csr_write_data[0];
+            if (debug_csr_write_data[0] ==  1'b0) 
+                state <=  3'b000;
+            else 
+                state <=  3'b001;
+        end
+        case (state)
+         3'b001:
+        begin
+            
+            if (   (   (eret_q_x ==  1'b1)
+                    || (bret_q_x ==  1'b1)
+                    )
+                && (stall_x ==  1'b0)
+               )
+                state <=  3'b010; 
+        end
+         3'b010:
+        begin
+            
+            if ((q_x ==  1'b1) && (stall_x ==  1'b0))
+                state <=  3'b011;
+        end
+         3'b011:
+        begin
+            
+  
+
+            if (dcache_refill_request ==  1'b1)
+                state <=  3'b010;
+            else 
+ 
+
+                 if ((exception_x ==  1'b1) && (q_x ==  1'b1) && (stall_x ==  1'b0))
+            begin
+                dc_ss <=  1'b0;
+                state <=  3'b100;
+            end
+        end
+         3'b100:
+        begin
+            
+  
+
+            if (dcache_refill_request ==  1'b1)
+                state <=  3'b010;
+            else 
+ 
+
+                state <=  3'b000;
+        end
+        endcase
+    end
+end
+ 
+
+
+endmodule
+
+ 
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
 
 
 
@@ -22946,7 +23032,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -23083,7 +23169,7 @@ endmodule
 
 
 
-module lm32_instruction_unit_full (
+module lm32_instruction_unit_full_debug (
     
     clk_i,
     rst_i,
@@ -23136,11 +23222,12 @@ module lm32_instruction_unit_full (
  
 
   
-    
-    
-    
-    
 
+    jtag_read_enable,
+    jtag_write_enable,
+    jtag_write_data,
+    jtag_address,
+ 
 
     
     
@@ -23176,9 +23263,10 @@ module lm32_instruction_unit_full (
  
 
   
-    
-    
 
+    jtag_read_data,
+    jtag_access_complete,
+ 
 
   
 
@@ -23268,11 +23356,12 @@ input i_rty_i;
 
 
   
-                                  
-                                 
-                   
-                      
 
+input jtag_read_enable;                                 
+input jtag_write_enable;                                
+input [ 7:0] jtag_write_data;                 
+input [ (32-1):0] jtag_address;                    
+ 
 
 
 
@@ -23313,11 +23402,11 @@ wire   icache_refilling;
 
 output [ (32-1):0] i_dat_o;                        
   
-     
 
-
-wire   [ (32-1):0] i_dat_o;
+reg    [ (32-1):0] i_dat_o;
  
+    
+
 
 output [ (32-1):0] i_adr_o;                        
 reg    [ (32-1):0] i_adr_o;
@@ -23325,21 +23414,21 @@ output i_cyc_o;
 reg    i_cyc_o; 
 output [ (4-1):0] i_sel_o;                 
   
-     
 
-
-wire   [ (4-1):0] i_sel_o;
+reg    [ (4-1):0] i_sel_o;
  
+    
+
 
 output i_stb_o;                                         
 reg    i_stb_o;
 output i_we_o;                                          
   
-    
 
-
-wire   i_we_o;
+reg    i_we_o;
  
+   
+
 
 output [ (3-1):0] i_cti_o;                       
 reg    [ (3-1):0] i_cti_o;
@@ -23351,11 +23440,12 @@ wire   [ (2-1):0] i_bte_o;
 
 
   
-                   
-     
-                             
-   
 
+output [ 7:0] jtag_read_data;                 
+reg    [ 7:0] jtag_read_data;
+output jtag_access_complete;                            
+wire   jtag_access_complete;
+ 
 
 
   
@@ -23421,8 +23511,9 @@ reg bus_error_f;
 
 
   
-                                         
 
+reg jtag_access;                                        
+ 
 
 
 
@@ -23540,7 +23631,7 @@ endfunction
   
 
 
-lm32_icache_full #(
+lm32_icache_full_debug #(
     .associativity          (associativity),
     .sets                   (sets),
     .bytes_per_line         (bytes_per_line),
@@ -23663,11 +23754,11 @@ assign instruction_f = icache_data_f;
 
   
 
-
-assign i_dat_o = 32'd0;
-assign i_we_o =  1'b0;
-assign i_sel_o = 4'b1111;
  
+   
+   
+   
+
 
 assign i_bte_o =  2'b00;
  
@@ -23784,17 +23875,18 @@ end
 
 
   
-                 
- 
-
-     
-       
-       
-       
-       
-     
-
 
+assign jtag_access_complete = (i_cyc_o ==  1'b1) && ((i_ack_i ==  1'b1) || (i_err_i ==  1'b1)) && (jtag_access ==  1'b1);
+always @(*)
+begin
+    case (jtag_address[1:0])
+    2'b00: jtag_read_data = i_dat_i[ 31:24];
+    2'b01: jtag_read_data = i_dat_i[ 23:16];
+    2'b10: jtag_read_data = i_dat_i[ 15:8];
+    2'b11: jtag_read_data = i_dat_i[ 7:0];
+    endcase 
+end
+ 
 
 
   
@@ -23819,10 +23911,11 @@ begin
  
 
   
-          
-          
-          
 
+        i_we_o <=  1'b0;
+        i_sel_o <= 4'b1111;
+        jtag_access <=  1'b0;
+ 
 
     end
     else
@@ -23835,15 +23928,16 @@ begin
             if ((i_ack_i ==  1'b1) || (i_err_i ==  1'b1))
             begin
   
-                   
-                
-                      
-                             
-                        
-                          
-                
-                
 
+                if (jtag_access ==  1'b1)
+                begin
+                    i_cyc_o <=  1'b0;
+                    i_stb_o <=  1'b0;       
+                    i_we_o <=  1'b0;  
+                    jtag_access <=  1'b0;    
+                end
+                else
+ 
 
                 begin
                     if (last_word ==  1'b1)
@@ -23876,9 +23970,10 @@ begin
             if ((icache_refill_request ==  1'b1) && (icache_refill_ready ==  1'b0))
             begin
                 
-       
-                  
-
+  
+     
+                i_sel_o <= 4'b1111;
+ 
 
                 i_adr_o <= {first_address, 2'b00};
                 i_cyc_o <=  1'b1;
@@ -23892,26 +23987,27 @@ begin
 
             end
   
-            
-            
-                       
-                
-                     
-                       
-                       
-                       
-                       
-                    
-                      
-                      
-                      
-                      
-                      
-                      
-                      
-                
-             
 
+            else
+            begin
+                if ((jtag_read_enable ==  1'b1) || (jtag_write_enable ==  1'b1))
+                begin
+                    case (jtag_address[1:0])
+                    2'b00: i_sel_o <= 4'b1000;
+                    2'b01: i_sel_o <= 4'b0100;
+                    2'b10: i_sel_o <= 4'b0010;
+                    2'b11: i_sel_o <= 4'b0001;
+                    endcase
+                    i_adr_o <= jtag_address;
+                    i_dat_o <= {4{jtag_write_data}};
+                    i_cyc_o <=  1'b1;
+                    i_stb_o <=  1'b1;
+                    i_we_o <= jtag_write_enable;
+                    i_cti_o <=  3'b111;
+                    jtag_access <=  1'b1;
+                end
+            end 
+ 
                     
   
 
@@ -24251,7 +24347,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -24386,443 +24482,523 @@ endmodule
 
   
 
-                              
-                              
-                              
 
+  
 
-                          
-                  
-                 
-              
-             
-                    
-                        
-                        
+  
 
+  
 
-                  
-         
-          
-          
-          
-          
-          
-      
-      
-         
 
 
+  
 
+  
 
+  
 
   
+
+  
+
+  
+
+  
+
+  
+
+
+
+  
+
+  
+
+  
+
+  
+
+  
+
+  
+
+  
+
+  
+
+  
+
+  
+
+
+
+
+
+
+module lm32_jtag_full_debug (
     
-    
-    
-     
-    
-    
-    
+    clk_i,
+    rst_i,
+    jtag_clk, 
+    jtag_update,
+    jtag_reg_q,
+    jtag_reg_addr_q,
+  
+
+    csr,
+    csr_write_enable,
+    csr_write_data,
+    stall_x,
  
-    
-    
-    
-    
 
+  
+
+    jtag_read_data,
+    jtag_access_complete,
  
-    
-    
 
+  
+
+    exception_q_w,
  
-    
 
     
+  
+
+    jtx_csr_read_data,
+    jrx_csr_read_data,
  
-    
-    
 
+  
+
+    jtag_csr_write_enable,
+    jtag_csr_write_data,
+    jtag_csr,
+    jtag_read_enable,
+    jtag_write_enable,
+    jtag_write_data,
+    jtag_address,
  
-    
-    
-    
-    
-    
-    
-    
 
+  
+
+    jtag_break,
+    jtag_reset,
  
-    
-    
 
-    
-    
-    
+    jtag_reg_d,
+    jtag_reg_addr_d
+    );
 
 
 
 
 
-                                             
-                                             
+input clk_i;                                            
+input rst_i;                                            
 
-                                          
-                                       
-                        
-                              
+input jtag_clk;                                         
+input jtag_update;                                      
+input [ 7:0] jtag_reg_q;                      
+input [2:0] jtag_reg_addr_q;                            
 
+  
+
+input [ (5-1):0] csr;                              
+input csr_write_enable;                                 
+input [ (32-1):0] csr_write_data;                  
+input stall_x;                                          
  
-                                
-                                  
-                    
-                                           
 
+  
+
+input [ 7:0] jtag_read_data;                  
+input jtag_access_complete;                             
  
-                    
-                              
 
+  
+
+input exception_q_w;                                    
  
-                                     
 
 
 
 
 
        
- 
-                
-    
-                
-    
+  
 
+output [ (32-1):0] jtx_csr_read_data;              
+wire   [ (32-1):0] jtx_csr_read_data;
+output [ (32-1):0] jrx_csr_read_data;              
+wire   [ (32-1):0] jrx_csr_read_data;
  
-                            
-    
-              
-    
-                          
-    
-                                 
-    
-                                
-    
-                  
-            
-                     
-    
 
+  
+
+output jtag_csr_write_enable;                           
+reg    jtag_csr_write_enable;
+output [ (32-1):0] jtag_csr_write_data;            
+wire   [ (32-1):0] jtag_csr_write_data;
+output [ (5-1):0] jtag_csr;                        
+wire   [ (5-1):0] jtag_csr;
+output jtag_read_enable;                                
+reg    jtag_read_enable;
+output jtag_write_enable;                               
+reg    jtag_write_enable;
+output [ 7:0] jtag_write_data;                
+wire   [ 7:0] jtag_write_data;        
+output [ (32-1):0] jtag_address;                   
+wire   [ (32-1):0] jtag_address;
  
-                                       
-    
-                                       
-    
 
   
-     
-  
-    
+
+output jtag_break;                                      
+reg    jtag_break;
+output jtag_reset;                                      
+reg    jtag_reset;
+ 
+
+output [ 7:0] jtag_reg_d;
+reg    [ 7:0] jtag_reg_d;
+output [2:0] jtag_reg_addr_d;
+wire   [2:0] jtag_reg_addr_d;
              
 
 
 
 
-                           
-                         
-                       
-                     
+reg rx_update;                          
+reg rx_update_r;                        
+reg rx_update_r_r;                      
+reg rx_update_r_r_r;                    
 
 
 
-     
+wire [ 7:0] rx_byte;   
+wire [2:0] rx_addr;
+
   
+                 
+reg [ 7:0] uart_tx_byte;      
+reg uart_tx_valid;                      
+reg [ 7:0] uart_rx_byte;      
+reg uart_rx_valid;                      
+ 
 
-                  
-        
-                       
-        
-                       
 
+reg [ 3:0] command;             
+  
 
-               
+reg [ 7:0] jtag_byte_0;       
+reg [ 7:0] jtag_byte_1;
+reg [ 7:0] jtag_byte_2;
+reg [ 7:0] jtag_byte_3;
+reg [ 7:0] jtag_byte_4;
+reg processing;                         
  
-         
-  
-  
-  
-  
-                          
 
 
-         
+reg [ 3:0] state;       
 
 
 
 
 
+  
+
+assign jtag_csr_write_data = {jtag_byte_0, jtag_byte_1, jtag_byte_2, jtag_byte_3};
+assign jtag_csr = jtag_byte_4[ (5-1):0];
+assign jtag_address = {jtag_byte_0, jtag_byte_1, jtag_byte_2, jtag_byte_3};
+assign jtag_write_data = jtag_byte_4;
  
-      
-   
-      
-   
 
                  
 
-                  
-             
-
+  
+                 
+assign jtag_reg_addr_d[1:0] = {uart_rx_valid, uart_tx_valid};         
+ 
    
 
+
+  
+
+assign jtag_reg_addr_d[2] = processing;
  
    
 
-   
 
 
-                  
-     
-     
+  
+                 
+assign jtx_csr_read_data = {{ 32-9{1'b0}}, uart_tx_valid, 8'h00};
+assign jrx_csr_read_data = {{ 32-9{1'b0}}, uart_rx_valid, uart_rx_byte};
+ 
          
                  
 
 
 
 
-   
-   
+assign rx_byte = jtag_reg_q;
+assign rx_addr = jtag_reg_addr_q;
 
 
 
-   
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        rx_update <= 1'b0;
+        rx_update_r <= 1'b0;
+        rx_update_r_r <= 1'b0;
+        rx_update_r_r_r <= 1'b0;
+    end
+    else
+    begin
+        rx_update <= jtag_update;
+        rx_update_r <= rx_update;
+        rx_update_r_r <= rx_update_r;
+        rx_update_r_r_r <= rx_update_r_r;
+    end
+end
 
-       
-    
-          
-          
-          
-          
-    
-    
-    
-          
-          
-          
-          
-    
 
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        state <=  4'h0;
+        command <= 4'b0000;
+        jtag_reg_d <= 8'h00;
+  
 
+        processing <=  1'b0;
+        jtag_csr_write_enable <=  1'b0;
+        jtag_read_enable <=  1'b0;
+        jtag_write_enable <=  1'b0;
+ 
 
-   
+  
 
-       
-    
-          
-          
-          
+        jtag_break <=  1'b0;
+        jtag_reset <=  1'b0;
  
-          
-          
-          
-          
 
+  
+                 
+        uart_tx_byte <= 8'h00;
+        uart_tx_valid <=  1'b0;
+        uart_rx_byte <= 8'h00;
+        uart_rx_valid <=  1'b0;
  
-          
-          
-
-                  
-          
-          
-          
-          
 
-    
-    
-    
-                  
-               
-        
-             
-            
-            
+    end
+    else
+    begin
+  
+                 
+        if ((csr_write_enable ==  1'b1) && (stall_x ==  1'b0))
+        begin
+            case (csr)
+             5'he:
+            begin
                 
-                  
-                  
-            
-            
-            
+                uart_tx_byte <= csr_write_data[ 7:0];
+                uart_tx_valid <=  1'b1;
+            end
+             5'hf:
+            begin
                 
-                  
-            
-            
-        
-
+                uart_rx_valid <=  1'b0;
+            end
+            endcase
+        end
  
-        
-           
-        
-              
-              
-        
 
-         
-        
+  
+
         
-            
-                 
-            
-                                  
-                 
- 
-                
-                
-                     
+        if (exception_q_w ==  1'b1)
+        begin
+            jtag_break <=  1'b0;
+            jtag_reset <=  1'b0;
+        end
  
-                    
-                          
-                    
-                    
-                              
-                          
-                    
-                    
-                          
-                    
-                    
-                              
-                          
-                    
-                    
-                          
-                    
-                    
-                    
-      
-                              
-                                   
 
-                          
-                    
-                    
-                    
-      
-                              
-                                   
+        case (state)
+         4'h0:
+        begin
+            
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                command <= rx_byte[7:4];                
+                case (rx_addr)
+  
 
-                          
+                 3'b000:
+                begin
+                    case (rx_byte[7:4])
+  
+
+                     4'b0001:
+                        state <=  4'h1;
+                     4'b0011:
+                    begin
+                        {jtag_byte_2, jtag_byte_3} <= {jtag_byte_2, jtag_byte_3} + 1'b1;
+                        state <=  4'h6;
+                    end
+                     4'b0010:
+                        state <=  4'h1;
+                     4'b0100:
+                    begin
+                        {jtag_byte_2, jtag_byte_3} <= {jtag_byte_2, jtag_byte_3} + 1'b1;
+                        state <= 5;
+                    end
+                     4'b0101:
+                        state <=  4'h1;
+ 
                     
-                                                   
-                
+                     4'b0110:
+                    begin
+  
+     
+                        uart_rx_valid <=  1'b0;    
+                        uart_tx_valid <=  1'b0;         
+ 
 
-                  
-                
-                
-                      
-                      
-                                    
-                
-                
-                      
-                      
-                
+                        jtag_break <=  1'b1;
+                    end
+                     4'b0111:
+                    begin
+  
+     
+                        uart_rx_valid <=  1'b0;    
+                        uart_tx_valid <=  1'b0;         
+ 
 
-                
-                    
-                                
-            
-        
+                        jtag_reset <=  1'b1;
+                    end
+                    endcase                               
+                end
  
-        
-        
-                 
-            
-                  
-                  
-            
-        
-        
-        
-                 
-            
-                  
-                  
-            
-        
-        
-        
-                 
-            
-                  
-                  
-            
-        
-        
-        
-                 
-            
-                  
-                   
-                      
-                 
-                      
-            
-        
-        
-        
-                 
-            
-                  
-                  
-            
-        
-        
-        
-             
-            
-            
-            
-                  
-                  
-                  
-            
-            
-            
-            
-                  
-                  
-                  
-            
-            
-            
-                  
-                  
-                  
-            
-            
-        
-        
-        
-               
-                      
-                  
-                  
-                    
-                  
-                  
-            
-            
-        
-        
-              
-              
-              
-            
 
-        
-    
+  
+                 
+                 3'b001:
+                begin
+                    uart_rx_byte <= rx_byte;
+                    uart_rx_valid <=  1'b1;
+                end                    
+                 3'b010:
+                begin
+                    jtag_reg_d <= uart_tx_byte;
+                    uart_tx_valid <=  1'b0;
+                end
+ 
 
+                default:
+                    ;
+                endcase                
+            end
+        end
   
 
+         4'h1:
+        begin
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                jtag_byte_0 <= rx_byte;
+                state <=  4'h2;
+            end
+        end
+         4'h2:
+        begin
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                jtag_byte_1 <= rx_byte;
+                state <=  4'h3;
+            end
+        end
+         4'h3:
+        begin
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                jtag_byte_2 <= rx_byte;
+                state <=  4'h4;
+            end
+        end
+         4'h4:
+        begin
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                jtag_byte_3 <= rx_byte;
+                if (command ==  4'b0001)
+                    state <=  4'h6;
+                else 
+                    state <=  4'h5;
+            end
+        end
+         4'h5:
+        begin
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                jtag_byte_4 <= rx_byte;
+                state <=  4'h6;
+            end
+        end
+         4'h6:
+        begin
+            case (command)
+             4'b0001,
+             4'b0011:
+            begin
+                jtag_read_enable <=  1'b1;
+                processing <=  1'b1;
+                state <=  4'h7;
+            end
+             4'b0010,
+             4'b0100:
+            begin
+                jtag_write_enable <=  1'b1;
+                processing <=  1'b1;
+                state <=  4'h7;
+            end
+             4'b0101:
+            begin
+                jtag_csr_write_enable <=  1'b1;
+                processing <=  1'b1;
+                state <=  4'h8;
+            end
+            endcase
+        end
+         4'h7:
+        begin
+            if (jtag_access_complete ==  1'b1)
+            begin          
+                jtag_read_enable <=  1'b0;
+                jtag_reg_d <= jtag_read_data;
+                jtag_write_enable <=  1'b0;  
+                processing <=  1'b0;
+                state <=  4'h0;
+            end
+        end    
+         4'h8:
+        begin
+            jtag_csr_write_enable <=  1'b0;
+            processing <=  1'b0;
+            state <=  4'h0;
+        end    
+ 
 
+        endcase
+    end
+end
+  
+endmodule
 
+ 
 
 
 
@@ -25040,7 +25216,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -25177,7 +25353,7 @@ endmodule
 
 
 
-module lm32_interrupt_full (
+module lm32_interrupt_full_debug (
     
     clk_i, 
     rst_i,
@@ -25186,17 +25362,18 @@ module lm32_interrupt_full (
     
     stall_x,
   
-    
-    
 
-
-    exception,
+    non_debug_exception,
+    debug_exception,
  
+    
+
 
     eret_q_x,
   
-    
 
+    bret_q_x,
+ 
 
     csr,
     csr_write_data,
@@ -25225,20 +25402,21 @@ input [interrupts-1:0] interrupt;
 input stall_x;                                  
 
   
-                       
-                           
-
 
-input exception;                                
+input non_debug_exception;                      
+input debug_exception;                          
  
+                                 
+
 
 input eret_q_x;                                 
   
-                                  
 
+input bret_q_x;                                 
+ 
 
 
-input [ (3-1):0] csr;                      
+input [ (5-1):0] csr;                      
 input [ (32-1):0] csr_write_data;          
 input csr_write_enable;                         
 
@@ -25259,14 +25437,18 @@ reg    [ (32-1):0] csr_read_data;
 wire [interrupts-1:0] asserted;                 
 
 wire [interrupts-1:0] interrupt_n_exception;
+wire [interrupts-1:0] ie_csr_read_data;
+wire [interrupts-1:0] ip_csr_read_data;
+wire [interrupts-1:0] im_csr_read_data;
 
 
 
 reg ie;                                         
 reg eie;                                        
   
-                                         
 
+reg bie;                                        
+ 
 
 reg [interrupts-1:0] ip;                        
 reg [interrupts-1:0] im;                        
@@ -25286,11 +25468,11 @@ assign asserted = ip | interrupt;
        
 assign ie_csr_read_data = {{ 32-3{1'b0}}, 
   
-                           
-
 
-                           1'b0,
+                           bie,
  
+                           
+
                              
                            eie, 
                            ie
@@ -25304,19 +25486,19 @@ generate
 always @(*)
 begin
     case (csr)
-     3'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     5'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
-                                    
 
-
-                                    1'b0,                                     
+                                    bie,
  
+                                                                         
+
 
                                     eie, 
                                     ie
                                    };
-     3'h2:  csr_read_data = ip;
-     3'h1:  csr_read_data = im;
+     5'h2:  csr_read_data = ip;
+     5'h1:  csr_read_data = im;
     default:       csr_read_data = { 32{1'bx}};
     endcase
 end
@@ -25327,18 +25509,18 @@ end
 always @(*)
 begin
     case (csr)
-     3'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     5'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
-                                     
-
 
-                                    1'b0,                                    
+                                    bie, 
  
+                                                                        
+
 
                                     eie, 
                                     ie
                                    };
-     3'h2:  csr_read_data = ip;
+     5'h2:  csr_read_data = ip;
     default:       csr_read_data = { 32{1'bx}};
       endcase
 end
@@ -25367,8 +25549,9 @@ always @(posedge clk_i  )
         ie                   <=  1'b0;
         eie                  <=  1'b0;
   
-                           
 
+        bie                  <=  1'b0;
+ 
 
         im                   <= {interrupts{1'b0}};
         ip                   <= {interrupts{1'b0}};
@@ -25380,13 +25563,21 @@ always @(posedge clk_i  )
         
         ip                   <= asserted;
   
-           
-        
+
+        if (non_debug_exception ==  1'b1)
+        begin
             
-                           
-                            
-        
+            eie              <= ie;
+            ie               <=  1'b0;
+        end
+        else if (debug_exception ==  1'b1)
+        begin
             
+            bie              <= ie;
+            ie               <=  1'b0;
+        end
+ 
+           
         
             
                            
@@ -25394,14 +25585,6 @@ always @(posedge clk_i  )
         
 
 
-        if (exception ==  1'b1)
-        begin
-            
-            eie              <= ie;
-            ie               <=  1'b0;
-        end
- 
-
         else if (stall_x ==  1'b0)
         begin
 
@@ -25419,26 +25602,28 @@ always @(posedge clk_i  )
                       
            
   
-                
-                
-                       
 
+            else if (bret_q_x ==  1'b1)
+                
+                ie      <= bie;
+ 
 
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  3'h0)
+                if (csr ==  5'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
   
-                      
 
+                    bie <= csr_write_data[2];
+ 
 
                 end
-                if (csr ==  3'h1)
+                if (csr ==  5'h1)
                     im  <= csr_write_data[interrupts-1:0];
-                if (csr ==  3'h2)
+                if (csr ==  5'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -25455,8 +25640,9 @@ always @(posedge clk_i  )
         ie              <=  1'b0;
         eie             <=  1'b0;
   
-                      
 
+        bie             <=  1'b0;
+ 
 
         ip              <= {interrupts{1'b0}};
        eie_delay        <= 0;
@@ -25466,13 +25652,21 @@ always @(posedge clk_i  )
         
         ip              <= asserted;
   
-           
-        
+
+        if (non_debug_exception ==  1'b1)
+        begin
             
-                      
-                       
-        
+            eie         <= ie;
+            ie          <=  1'b0;
+        end
+        else if (debug_exception ==  1'b1)
+        begin
             
+            bie         <= ie;
+            ie          <=  1'b0;
+        end
+ 
+           
         
             
                       
@@ -25480,14 +25674,6 @@ always @(posedge clk_i  )
         
 
 
-        if (exception ==  1'b1)
-        begin
-            
-            eie         <= ie;
-            ie          <=  1'b0;
-        end
- 
-
         else if (stall_x ==  1'b0)
           begin
 
@@ -25503,24 +25689,26 @@ always @(posedge clk_i  )
              end
            
   
-                
-                
-                       
 
+            else if (bret_q_x ==  1'b1)
+                
+                ie      <= bie;
+ 
 
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  3'h0)
+                if (csr ==  5'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
   
-                      
 
+                    bie <= csr_write_data[2];
+ 
 
                 end
-                if (csr ==  3'h2)
+                if (csr ==  5'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -25577,12 +25765,6 @@ endmodule
 
   
 
-  
-
-  
-
-	  
-
 	  
 
 	  
@@ -25608,18 +25790,13 @@ endmodule
 	  
 
 	  
-
-	  
-
-	  
-
-	  
-
+	 
+	 
+	 
+	 
 	  
-
 	  
-
-	 
+	
 
  
 
@@ -25719,16 +25896,18 @@ endmodule
 
 
   
+                    
+
 
   
 
- 
- 
-                    
+  
 
+ 
                     
 
 
+ 
 
   
 
@@ -25757,25 +25936,24 @@ endmodule
 
 
   
-
-  
-
  
 
+
  
 
 
 
   
+ 
 
-  
 
- 
- 
+  
  
 
 
+ 
 
+ 
 
 
 
@@ -25876,47 +26054,27 @@ endmodule
 
 
   
-
-  
-
-  
-
- 
- 
-                   
-                     
-
                    
                      
 
 
-
-
-
-  
-
-  
-
   
+                   
+                     
 
-  
 
   
 
   
 
-  
+ 
 
-  
+ 
 
-  
 
-  
 
   
 
- 
-
   
 
   
@@ -25925,8 +26083,6 @@ endmodule
 
   
 
- 
-
   
 
   
@@ -25934,19 +26090,28 @@ endmodule
   
 
   
+                      
+                    
 
-  
 
   
 
   
+                     
+                     
 
-  
 
   
+                     
+                     
+                     
+                     
+                     
+                     
+                     
+                     
 
  
- 
 
 
   
@@ -26007,14 +26172,14 @@ endmodule
 
 
   
+ 
 
-  
 
- 
- 
+  
  
 
 
+ 
 
 
 
@@ -26104,7 +26269,7 @@ endmodule
 
 
 
-module lm32_top_medium_debug (
+module lm32_top_medium (
     
     clk_i,
     rst_i,
@@ -26261,225 +26426,221 @@ wire   [ (2-1):0] D_BTE_O;
  
   
 
-
-wire [ 7:0] jtag_reg_d;
-wire [ 7:0] jtag_reg_q;
-wire jtag_update;
-wire [2:0] jtag_reg_addr_d;
-wire [2:0] jtag_reg_addr_q;
-wire jtck;
-wire jrstn;
- 
-
-
-
   
-
-                     
-                             
-                            
-                   
-                                 
- 
-                                 
-
-
-
-
-
-
-
-
   
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-					  
-function integer clogb2;
-input [31:0] value;
-begin
-   for (clogb2 = 0; value > 0; clogb2 = clogb2 + 1)
-        value = value >> 1;
-end
-endfunction 
-
-function integer clogb2_v1;
-input [31:0] value;
-reg   [31:0] i;
-reg   [31:0] temp;
-begin
-   temp = 0;
-   i    = 0;
-   for (i = 0; temp < value; i = i + 1)  
-	temp = 1<<i;
-   clogb2_v1 = i-1;
-end
-endfunction
-
-
-
-
-
-
-   
-
-lm32_cpu_medium_debug cpu (
-    
-    .clk_i                 (clk_i),
-  
-                   
-
-
-    .rst_i                 (rst_i),
-    
-  
-
-    .interrupt             (interrupt),
  
-
-    
   
-               
-             
-
-     
   
-
-    
-    .jtag_clk              (jtck),
-    .jtag_update           (jtag_update),
-    .jtag_reg_q            (jtag_reg_q),
-    .jtag_reg_addr_q       (jtag_reg_addr_q),
  
-
-  
-
-     
-    .I_DAT_I               (I_DAT_I),
-    .I_ACK_I               (I_ACK_I),
-    .I_ERR_I               (I_ERR_I),
-    .I_RTY_I               (I_RTY_I),
  
 
-    
-    .D_DAT_I               (D_DAT_I),
-    .D_ACK_I               (D_ACK_I),
-    .D_ERR_I               (D_ERR_I),
-    .D_RTY_I               (D_RTY_I),
-    
-  
-                  
-            
-           
-                 
-                
- 
-                
 
 
 
   
 
-    .jtag_reg_d            (jtag_reg_d),
-    .jtag_reg_addr_d       (jtag_reg_addr_d),
- 
-
-      
-                
-               
-            
-            
-
-    
-  
-
-    
-    .I_DAT_O               (I_DAT_O),
-    .I_ADR_O               (I_ADR_O),
-    .I_CYC_O               (I_CYC_O),
-    .I_SEL_O               (I_SEL_O),
-    .I_STB_O               (I_STB_O),
-    .I_WE_O                (I_WE_O),
-    .I_CTI_O               (I_CTI_O),
-    .I_LOCK_O              (I_LOCK_O),
-    .I_BTE_O               (I_BTE_O),
-     
-
-    
-    .D_DAT_O               (D_DAT_O),
-    .D_ADR_O               (D_ADR_O),
-    .D_CYC_O               (D_CYC_O),
-    .D_SEL_O               (D_SEL_O),
-    .D_STB_O               (D_STB_O),
-    .D_WE_O                (D_WE_O),
-    .D_CTI_O               (D_CTI_O),
-    .D_LOCK_O              (D_LOCK_O),
-    .D_BTE_O               (D_BTE_O)
-    );
-   
-  
-		   
-
-jtag_cores jtag_cores (
-    
-    .reg_d                 (jtag_reg_d),
-    .reg_addr_d            (jtag_reg_addr_d),
-    
-    .reg_update            (jtag_update),
-    .reg_q                 (jtag_reg_q),
-    .reg_addr_q            (jtag_reg_addr_q),
-    .jtck                  (jtck),
-    .jrstn                 (jrstn)
-    );
+                     
+                             
+                            
+                   
+                                 
  
-        
-   
-endmodule
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+                                 
+
+
+
+
+
+
+
+
+  
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+					  
+function integer clogb2;
+input [31:0] value;
+begin
+   for (clogb2 = 0; value > 0; clogb2 = clogb2 + 1)
+        value = value >> 1;
+end
+endfunction 
+
+function integer clogb2_v1;
+input [31:0] value;
+reg   [31:0] i;
+reg   [31:0] temp;
+begin
+   temp = 0;
+   i    = 0;
+   for (i = 0; temp < value; i = i + 1)  
+	temp = 1<<i;
+   clogb2_v1 = i-1;
+end
+endfunction
+
+
+
+
+
+
+   
+
+lm32_cpu_medium cpu (
+    
+    .clk_i                 (clk_i),
+  
+                   
+
+
+    .rst_i                 (rst_i),
+    
+  
+
+    .interrupt             (interrupt),
+ 
+
+    
+  
+               
+             
+
+     
+  
+    
+                  
+               
+                
+           
+
+
+  
+
+     
+    .I_DAT_I               (I_DAT_I),
+    .I_ACK_I               (I_ACK_I),
+    .I_ERR_I               (I_ERR_I),
+    .I_RTY_I               (I_RTY_I),
+ 
+
+    
+    .D_DAT_I               (D_DAT_I),
+    .D_ACK_I               (D_ACK_I),
+    .D_ERR_I               (D_ERR_I),
+    .D_RTY_I               (D_RTY_I),
+    
+  
+                  
+            
+           
+                 
+                
+ 
+                
+
+
+
+  
+                
+           
+
+
+      
+                
+               
+            
+            
+
+    
+  
+
+    
+    .I_DAT_O               (I_DAT_O),
+    .I_ADR_O               (I_ADR_O),
+    .I_CYC_O               (I_CYC_O),
+    .I_SEL_O               (I_SEL_O),
+    .I_STB_O               (I_STB_O),
+    .I_WE_O                (I_WE_O),
+    .I_CTI_O               (I_CTI_O),
+    .I_LOCK_O              (I_LOCK_O),
+    .I_BTE_O               (I_BTE_O),
+     
+
+    
+    .D_DAT_O               (D_DAT_O),
+    .D_ADR_O               (D_ADR_O),
+    .D_CYC_O               (D_CYC_O),
+    .D_SEL_O               (D_SEL_O),
+    .D_STB_O               (D_STB_O),
+    .D_WE_O                (D_WE_O),
+    .D_CTI_O               (D_CTI_O),
+    .D_LOCK_O              (D_LOCK_O),
+    .D_BTE_O               (D_BTE_O)
+    );
+   
+  		   
+
+  
+    
+                     
+                
+    
+                
+                     
+                
+                      
+                     
+    
+
+        
+   
+endmodule
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
 
 
 
@@ -26676,7 +26837,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -26828,7 +26989,7 @@ endmodule
 
 
 
-module lm32_mc_arithmetic_medium_debug (
+module lm32_mc_arithmetic_medium (
     
     clk_i,
     rst_i,
@@ -27347,7 +27508,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -27484,7 +27645,7 @@ endmodule
 
 
 
-module lm32_cpu_medium_debug (
+module lm32_cpu_medium (
     
     clk_i,
   
@@ -27505,13 +27666,12 @@ module lm32_cpu_medium_debug (
 
      
   
-
     
-    jtag_clk,
-    jtag_update, 
-    jtag_reg_q,
-    jtag_reg_addr_q,
- 
+    
+     
+    
+    
+
 
   
 
@@ -27540,10 +27700,9 @@ module lm32_cpu_medium_debug (
 
 
   
+    
+    
 
-    jtag_reg_d,
-    jtag_reg_addr_d,
- 
 
       
     
@@ -27584,25 +27743,24 @@ module lm32_cpu_medium_debug (
 
 parameter eba_reset =  32'h00000000;                           
   
+                            
 
-parameter deba_reset =  32'h10000000;                         
- 
 
 
   
+        
+                          
+      
+          
+                        
 
-parameter icache_associativity =  1;     
-parameter icache_sets =  256;                       
-parameter icache_bytes_per_line =  16;   
-parameter icache_base_address =  32'h0;       
-parameter icache_limit =  32'h7fffffff;                     
- 
-       
-                         
-     
-         
-                       
 
+parameter icache_associativity = 1;    
+parameter icache_sets = 512;                      
+parameter icache_bytes_per_line = 16;  
+parameter icache_base_address = 0;      
+parameter icache_limit = 0;                    
+ 
 
 
   
@@ -27622,11 +27780,11 @@ parameter dcache_limit = 0;
 
 
   
+                          
 
-parameter watchpoints =  32'h4;                       
- 
-   
 
+parameter watchpoints = 0;
+ 
 
   
                           
@@ -27668,12 +27826,11 @@ input [ (32-1):0] interrupt;
     
 
   
+                                  
+                               
+                
+  
 
-input jtag_clk;                                 
-input jtag_update;                              
-input [ 7:0] jtag_reg_q;              
-input [2:0] jtag_reg_addr_q;
- 
 
 
   
@@ -27713,12 +27870,11 @@ input D_RTY_I;
 
 
   
+  
+    
+  
+    
 
-output [ 7:0] jtag_reg_d;
-wire   [ 7:0] jtag_reg_d;
-output [2:0] jtag_reg_addr_d;
-wire   [2:0] jtag_reg_addr_d;
- 
 
 
   
@@ -27782,9 +27938,8 @@ wire   [ (2-1):0] D_BTE_O;
 
 
   
+                                     
 
-reg valid_a;                                    
- 
 
 reg valid_f;                                    
 reg valid_d;                                    
@@ -27799,6 +27954,9 @@ reg load_x;
 reg load_m;
 wire load_q_x;
 wire store_q_x;
+wire q_m;
+wire load_q_m;
+wire store_q_m;
 wire store_d;                                   
 reg store_x;
 reg store_m;
@@ -27807,8 +27965,8 @@ reg [ 1:0] size_x;
 wire branch_d;                                  
 wire branch_predict_d;                          
 wire branch_predict_taken_d;                    
-wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_predict_address_d;   
-wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_target_d;
+wire [ ((32-2)+2-1):2] branch_predict_address_d;   
+wire [ ((32-2)+2-1):2] branch_target_d;
 wire bi_unconditional;
 wire bi_conditional;
 reg branch_x;                                   
@@ -27820,15 +27978,16 @@ reg branch_predict_taken_m;
 wire branch_mispredict_taken_m;                 
 wire branch_flushX_m;                           
 wire branch_reg_d;                              
-wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_offset_d;            
-reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_target_x;             
-reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_target_m;
+wire [ ((32-2)+2-1):2] branch_offset_d;            
+reg [ ((32-2)+2-1):2] branch_target_x;             
+reg [ ((32-2)+2-1):2] branch_target_m;
 wire [ 0:0] d_result_sel_0_d; 
 wire [ 1:0] d_result_sel_1_d; 
 
 wire x_result_sel_csr_d;                        
 reg x_result_sel_csr_x;
   
+ 
                     
  
 
@@ -27897,15 +28056,14 @@ wire [ (5-1):0] write_idx_d;
 reg [ (5-1):0] write_idx_x;            
 reg [ (5-1):0] write_idx_m;
 reg [ (5-1):0] write_idx_w;
-wire [ (5-1):0] csr_d;                     
-reg  [ (5-1):0] csr_x;                  
+wire [ (4 -1):0] csr_d;                     
+reg  [ (4 -1):0] csr_x;                  
 wire [ (3-1):0] condition_d;         
 reg [ (3-1):0] condition_x;          
   
+                                    
+                                     
 
-wire break_d;                                   
-reg break_x;                                    
- 
 
 wire scall_d;                                   
 reg scall_x;    
@@ -27918,16 +28076,14 @@ reg eret_m;
 
 
   
-
-wire bret_d;                                    
-reg bret_x;
-wire bret_q_x;
-reg bret_m;
-  
+                                     
+ 
+ 
+ 
+ 
  
 
 
- 
 
 wire csr_write_enable_d;                        
 reg csr_write_enable_x;
@@ -28079,11 +28235,11 @@ wire [ (32-1):0] cfg2;
 reg [ (32-1):0] csr_read_data_x;           
 
 
-wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_f;                       
-wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_d;                       
-wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_x;                       
-wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_m;                       
-wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_w;                       
+wire [ ((32-2)+2-1):2] pc_f;                       
+wire [ ((32-2)+2-1):2] pc_d;                       
+wire [ ((32-2)+2-1):2] pc_x;                       
+wire [ ((32-2)+2-1):2] pc_m;                       
+wire [ ((32-2)+2-1):2] pc_w;                       
   
                           
 
@@ -28097,13 +28253,12 @@ wire [ (32-1):0] instruction_f;
 
 wire [ (32-1):0] instruction_d;     
   
+                                     
+                       
+                     
+                      
+                           
 
-wire iflush;                                    
-wire icache_stall_request;                      
-wire icache_restart_request;                    
-wire icache_refill_request;                     
-wire icache_refilling;                          
- 
 
   
           
@@ -28129,32 +28284,25 @@ wire stall_wb_load;
 
 
   
-
-  
-
-wire [ (32-1):0] jtx_csr_read_data;        
-wire [ (32-1):0] jrx_csr_read_data;        
  
+          
+          
 
+ 
+                      
+        
+                    
+                           
   
-
-wire jtag_csr_write_enable;                     
-wire [ (32-1):0] jtag_csr_write_data;      
-wire [ (5-1):0] jtag_csr;                  
-wire jtag_read_enable;                          
-wire [ 7:0] jtag_read_data;
-wire jtag_write_enable;
-wire [ 7:0] jtag_write_data;
-wire [ (32-1):0] jtag_address;
-wire jtag_access_complete;
  
-
   
-
-wire jtag_break;                                
+  
  
 
  
+                                 
+
+
 
 
 
@@ -28184,11 +28332,10 @@ wire kill_x;
 wire kill_m;                                    
 wire kill_w;                                    
 
-reg [ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8] eba;                 
+reg [ (32-2)+2-1:8] eba;                 
   
+                  
 
-reg [ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8] deba;                
- 
 
 reg [ (3-1):0] eid_x;                      
   
@@ -28198,39 +28345,36 @@ reg [ (3-1):0] eid_x;
 
 
   
-
-  
-
-wire dc_ss;                                     
  
+                                      
 
-wire dc_re;                                     
-wire exception_x;                               
-reg exception_m;                                
-wire debug_exception_x;                         
-reg debug_exception_m;
-reg debug_exception_w;
-wire debug_exception_q_w;
-wire non_debug_exception_x;                     
-reg non_debug_exception_m;
-reg non_debug_exception_w;
-wire non_debug_exception_q_w;
+                                      
+ 
  
                                 
+                                 
+                          
+ 
+ 
+ 
+                      
  
  
  
 
 
+wire exception_x;                               
+reg exception_m;
+reg exception_w;
+wire exception_q_w;
+ 
 
-  
 
   
-
-wire reset_exception;                           
  
+                            
+
 
- 
 
   
 
@@ -28238,10 +28382,9 @@ wire interrupt_exception;
  
 
   
+                       
+                       
 
-wire breakpoint_exception;                      
-wire watchpoint_exception;                      
- 
 
   
             
@@ -28322,7 +28465,7 @@ endfunction
 
 
 
-lm32_instruction_unit_medium_debug #(
+lm32_instruction_unit_medium #(
     .associativity          (icache_associativity),
     .sets                   (icache_sets),
     .bytes_per_line         (icache_bytes_per_line),
@@ -28353,9 +28496,8 @@ lm32_instruction_unit_medium_debug #(
     .branch_mispredict_taken_m (branch_mispredict_taken_m),
     .branch_target_m        (branch_target_m),
   
+                     
 
-    .iflush                 (iflush),
- 
 
   
           
@@ -28379,12 +28521,11 @@ lm32_instruction_unit_medium_debug #(
  
 
   
+           
+          
+            
+               
 
-    .jtag_read_enable       (jtag_read_enable),
-    .jtag_write_enable      (jtag_write_enable),
-    .jtag_write_data        (jtag_write_data),
-    .jtag_address           (jtag_address),
- 
 
     
     
@@ -28394,12 +28535,11 @@ lm32_instruction_unit_medium_debug #(
     .pc_m                   (pc_m),
     .pc_w                   (pc_w),
   
+       
+     
+      
+           
 
-    .icache_stall_request   (icache_stall_request),
-    .icache_restart_request (icache_restart_request),
-    .icache_refill_request  (icache_refill_request),
-    .icache_refilling       (icache_refilling),
- 
 
   
                 
@@ -28420,10 +28560,9 @@ lm32_instruction_unit_medium_debug #(
  
 
   
+             
+       
 
-    .jtag_read_data         (jtag_read_data),
-    .jtag_access_complete   (jtag_access_complete),
- 
 
   
                 
@@ -28438,7 +28577,7 @@ lm32_instruction_unit_medium_debug #(
     );
 
 
-lm32_decoder_medium_debug decoder (
+lm32_decoder_medium decoder (
     
     .instruction            (instruction_d),
     
@@ -28517,16 +28656,14 @@ lm32_decoder_medium_debug decoder (
     .branch_reg             (branch_reg_d),
     .condition              (condition_d),
   
+               
 
-    .break_opcode           (break_d),
- 
 
     .scall                  (scall_d),
     .eret                   (eret_d),
   
+                       
 
-    .bret                   (bret_d),
- 
 
   
                 
@@ -28536,7 +28673,7 @@ lm32_decoder_medium_debug decoder (
     ); 
 
 
-lm32_load_store_unit_medium_debug #(
+lm32_load_store_unit_medium #(
     .associativity          (dcache_associativity),
     .sets                   (dcache_sets),
     .bytes_per_line         (dcache_bytes_per_line),
@@ -28702,7 +28839,7 @@ lm32_multiplier multiplier (
   
 
 
-lm32_interrupt_medium_debug interrupt_unit (
+lm32_interrupt_medium interrupt_unit (
     
     .clk_i                  (clk_i), 
     .rst_i                  (rst_i),
@@ -28711,18 +28848,17 @@ lm32_interrupt_medium_debug interrupt_unit (
     
     .stall_x                (stall_x),
   
+         
+            
 
-    .non_debug_exception    (non_debug_exception_q_w), 
-    .debug_exception        (debug_exception_q_w),
- 
-                   
 
+    .exception              (exception_q_w), 
+ 
 
     .eret_q_x               (eret_q_x),
   
+                   
 
-    .bret_q_x               (bret_q_x),
- 
 
     .csr                    (csr_x),
     .csr_write_data         (operand_1_x),
@@ -28737,116 +28873,95 @@ lm32_interrupt_medium_debug interrupt_unit (
 
   
 
-
-lm32_jtag_medium_debug jtag (
+  
     
-    .clk_i                  (clk_i),
-    .rst_i                  (rst_i),
+                      
+                      
     
-    .jtag_clk               (jtag_clk),
-    .jtag_update            (jtag_update),
-    .jtag_reg_q             (jtag_reg_q),
-    .jtag_reg_addr_q        (jtag_reg_addr_q),
+                   
+                
+                 
+            
     
-  
-
-    .csr                    (csr_x),
-    .csr_write_data         (operand_1_x),
-    .csr_write_enable       (csr_write_enable_q_x),
-    .stall_x                (stall_x),
  
+                        
+             
+           
+                    
 
-  
-
-    .jtag_read_data         (jtag_read_data),
-    .jtag_access_complete   (jtag_access_complete),
  
+             
+       
 
-  
-
-    .exception_q_w          (debug_exception_q_w || non_debug_exception_q_w),
  
+                
     
     
     
-  
-
-    .jtx_csr_read_data      (jtx_csr_read_data),
-    .jrx_csr_read_data      (jrx_csr_read_data),
  
+          
+          
 
-  
-
-    .jtag_csr_write_enable  (jtag_csr_write_enable),
-    .jtag_csr_write_data    (jtag_csr_write_data),
-    .jtag_csr               (jtag_csr),
-    .jtag_read_enable       (jtag_read_enable),
-    .jtag_write_enable      (jtag_write_enable),
-    .jtag_write_data        (jtag_write_data),
-    .jtag_address           (jtag_address),
  
+      
+        
+                   
+           
+          
+            
+               
 
-  
-
-    .jtag_break             (jtag_break),
-    .jtag_reset             (reset_exception),
  
+                 
+                 
 
     
-    .jtag_reg_d             (jtag_reg_d),
-    .jtag_reg_addr_d        (jtag_reg_addr_d)
-    );
- 
-
+                 
+            
+    
 
-  
 
 
-lm32_debug_medium_debug #(
-    .breakpoints            (breakpoints),
-    .watchpoints            (watchpoints)
-  ) hw_debug (
-    
-    .clk_i                  (clk_i), 
-    .rst_i                  (rst_i),
-    .pc_x                   (pc_x),
-    .load_x                 (load_x),
-    .store_x                (store_x),
-    .load_store_address_x   (adder_result_x),
-    .csr_write_enable_x     (csr_write_enable_q_x),
-    .csr_write_data         (operand_1_x),
-    .csr_x                  (csr_x),
   
 
-    .jtag_csr_write_enable  (jtag_csr_write_enable),
-    .jtag_csr_write_data    (jtag_csr_write_data),
-    .jtag_csr               (jtag_csr),
  
+                
+                
+    
+    
+                       
+                      
+                       
+                     
+                    
+       
+         
+             
+                      
+ 
+      
+        
+                   
 
-  
-
-    .eret_q_x               (eret_q_x),
-    .bret_q_x               (bret_q_x),
-    .stall_x                (stall_x),
-    .exception_x            (exception_x),
-    .q_x                    (q_x),
-  
+ 
+                   
+                   
+                    
+                
+                        
+ 
       
 
 
+    
  
+                      
 
+                      
+                   
+                   
     
-  
-
-    .dc_ss                  (dc_ss),
- 
 
-    .dc_re                  (dc_re),
-    .bp_match               (bp_match),
-    .wp_match               (wp_match)
-    );
- 
 
 
 
@@ -29291,9 +29406,8 @@ assign kill_f =    (   (valid_d ==  1'b1)
 
 
   
+                    
 
-                || (icache_refill_request ==  1'b1) 
- 
 
                   
                    
@@ -29306,9 +29420,8 @@ assign kill_d =    (branch_taken_m ==  1'b1)
 
 
   
+                        
 
-                || (icache_refill_request ==  1'b1)     
- 
                 
                   
                    
@@ -29337,25 +29450,21 @@ assign kill_w =     1'b0
 
 
   
-
-assign breakpoint_exception =    (   (   (break_x ==  1'b1)
-				      || (bp_match ==  1'b1)
-				     )
-				  && (valid_x ==  1'b1)
-				 )
-  
-
-                              || (jtag_break ==  1'b1)
+              
+				         
+				     
+				     
+				 
  
+                                 
+
+                              
 
-                              ;
- 
 
 
   
+     
 
-assign watchpoint_exception = wp_match ==  1'b1;
- 
 
 
   
@@ -29379,17 +29488,38 @@ assign system_call_exception = (   (scall_x ==  1'b1)
 			       );
 
   
+      
+                            
+                         
 
-assign debug_exception_x =  (breakpoint_exception ==  1'b1)
-                         || (watchpoint_exception ==  1'b1)
-                         ;
+     
+ 
+                               
 
-assign non_debug_exception_x = (system_call_exception ==  1'b1)
-  
+ 
+                               
+                               
 
-                            || (reset_exception ==  1'b1)
  
+                               
 
+ 
+                                  
+ 
+                                   
+                            
+ 
+ 				   
+				   
+
+                               
+
+                            
+
+         
+
+
+assign exception_x =           (system_call_exception ==  1'b1)
   
                                
                                
@@ -29403,9 +29533,8 @@ assign non_debug_exception_x = (system_call_exception ==  1'b1)
 
                             || (   (interrupt_exception ==  1'b1)
   
+                                   
 
-                                && (dc_ss ==  1'b0)
- 
                             
   
  				   
@@ -29416,54 +29545,27 @@ assign non_debug_exception_x = (system_call_exception ==  1'b1)
  
 
                             ;
-
-assign exception_x = (debug_exception_x ==  1'b1) || (non_debug_exception_x ==  1'b1);
  
-               
- 
-                               
-                               
-
- 
-                               
-
- 
-                                  
- 
-                                   
-                            
- 
- 				   
-				   
-
-                               
-
-                            
-
 
 
 
 always @(*)
 begin
   
-
-  
-
-    if (reset_exception ==  1'b1)
-        eid_x =  3'h0;
-    else
  
+       
+          
+    
      
-  
+ 
             
           
     
 
+            
+          
+    
 
-         if (breakpoint_exception ==  1'b1)
-        eid_x =  3'd1;
-    else
- 
 
   
             
@@ -29475,11 +29577,10 @@ begin
 
 
   
+            
+          
+     
 
-         if (watchpoint_exception ==  1'b1)
-        eid_x =  3'd3;
-    else 
- 
 
   
             
@@ -29491,9 +29592,8 @@ begin
 
          if (   (interrupt_exception ==  1'b1)
   
+                
 
-             && (dc_ss ==  1'b0)
- 
                             
             )
         eid_x =  3'h6;
@@ -29529,19 +29629,18 @@ assign stall_d =   (stall_x ==  1'b1)
                     && (kill_d ==  1'b0)
 		   )
   
+		         
+			   
+		       
+		          
+			   
+			   
+			   
+			   
+		       
+                       
+		   
 
-		|| (   (   (break_d ==  1'b1)
-			|| (bret_d ==  1'b1)
-		       )
-		    && (   (load_q_x ==  1'b1)
-			|| (store_q_x ==  1'b1)
-			|| (load_q_m ==  1'b1)
-			|| (store_q_m ==  1'b1)
-			|| (D_CYC_O ==  1'b1)
-		       )
-                    && (kill_d ==  1'b0)
-		   )
- 
                    
                 || (   (csr_write_enable_d ==  1'b1)
                     && (load_q_x ==  1'b1)
@@ -29603,14 +29702,16 @@ assign stall_m =    (stall_wb_load ==  1'b1)
 
                                     
   
+                         
+                             
 
-                 || (icache_stall_request ==  1'b1)     
-                 || ((I_CYC_O ==  1'b1) && ((branch_m ==  1'b1) || (exception_m ==  1'b1))) 
- 
- 
-                                
 
+  
+
+                 || (I_CYC_O ==  1'b1)            
+ 
 
+ 
                                
   
                                   
@@ -29643,24 +29744,21 @@ assign q_x = (valid_x ==  1'b1) && (kill_x ==  1'b0);
 assign csr_write_enable_q_x = (csr_write_enable_x ==  1'b1) && (q_x ==  1'b1);
 assign eret_q_x = (eret_x ==  1'b1) && (q_x ==  1'b1);
   
+         
 
-assign bret_q_x = (bret_x ==  1'b1) && (q_x ==  1'b1);
- 
 
 assign load_q_x = (load_x ==  1'b1) 
                && (q_x ==  1'b1)
   
+                  
 
-               && (bp_match ==  1'b0)
- 
 
                   ;
 assign store_q_x = (store_x ==  1'b1) 
                && (q_x ==  1'b1)
   
+                  
 
-               && (bp_match ==  1'b0)
- 
 
                   ;
   
@@ -29671,13 +29769,13 @@ assign q_m = (valid_m ==  1'b1) && (kill_m ==  1'b0) && (exception_m ==  1'b0);
 assign load_q_m = (load_m ==  1'b1) && (q_m ==  1'b1);
 assign store_q_m = (store_m ==  1'b1) && (q_m ==  1'b1);
   
-
-assign debug_exception_q_w = ((debug_exception_w ==  1'b1) && (valid_w ==  1'b1));
-assign non_debug_exception_q_w = ((non_debug_exception_w ==  1'b1) && (valid_w ==  1'b1));        
- 
+         
                  
 
 
+assign exception_q_w = ((exception_w ==  1'b1) && (valid_w ==  1'b1));        
+ 
+
 
 assign write_enable_q_x = (write_enable_x ==  1'b1) && (valid_x ==  1'b1) && (branch_flushX_m ==  1'b0);
 assign write_enable_q_m = (write_enable_m ==  1'b1) && (valid_m ==  1'b1);
@@ -29692,12 +29790,12 @@ assign cfg = {
               breakpoints[3:0],
               interrupts[5:0],
   
-
-               1'b1,
- 
               
 
 
+               1'b0,
+ 
+
   
               
 
@@ -29706,26 +29804,26 @@ assign cfg = {
  
 
   
-
-               1'b1,
- 
               
 
 
-  
-
-               1'b1,
+               1'b0,
  
-              
-
 
   
+              
 
-               1'b1,
+
+               1'b0,
  
+
+  
               
 
 
+               1'b0,
+ 
+
   
               
 
@@ -29797,22 +29895,19 @@ assign cfg2 = {
    
 
   
+         
+                    
+                    
+                    
+                    
 
-assign iflush = (   (csr_write_enable_d ==  1'b1) 
-                 && (csr_d ==  5'h3)
-                 && (stall_d ==  1'b0)
-                 && (kill_d ==  1'b0)
-                 && (valid_d ==  1'b1))
-
-  
-
-             ||
-                (   (jtag_csr_write_enable ==  1'b1)
-		 && (jtag_csr ==  5'h3))
  
+             
+                     
+		    
+
+		 
 
-		 ;
- 
  
   
          
@@ -29828,7 +29923,7 @@ assign iflush = (   (csr_write_enable_d ==  1'b1)
  
 
 
-assign csr_d = read_idx_0_d[ (5-1):0];
+assign csr_d = read_idx_0_d[ (4 -1):0];
 
 
 always @(*)
@@ -29836,29 +29931,27 @@ begin
     case (csr_x)
   
 
-     5'h0,
-     5'h1,
-     5'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
+     4 'h0,
+     4 'h1,
+     4 'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
  
 
   
          
 
 
-     5'h6:  csr_read_data_x = cfg;
-     5'h7:  csr_read_data_x = {eba, 8'h00};
+     4 'h6:  csr_read_data_x = cfg;
+     4 'h7:  csr_read_data_x = {eba, 8'h00};
   
+        
 
-     5'h9: csr_read_data_x = {deba, 8'h00};
- 
 
   
+          
+        
 
-     5'he:  csr_read_data_x = jtx_csr_read_data;  
-     5'hf:  csr_read_data_x = jrx_csr_read_data;
- 
 
-     5'ha: csr_read_data_x = cfg2;
+     4 'ha: csr_read_data_x = cfg2;
       
     default:        csr_read_data_x = { 32{1'bx}};
     endcase
@@ -29872,40 +29965,36 @@ end
 always @(posedge clk_i  )
 begin
     if (rst_i ==  1'b1)
-        eba <= eba_reset[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+        eba <= eba_reset[ (32-2)+2-1:8];
     else
     begin
-        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  5'h7) && (stall_x ==  1'b0))
-            eba <= operand_1_x[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  4 'h7) && (stall_x ==  1'b0))
+            eba <= operand_1_x[ (32-2)+2-1:8];
   
+               
+              
 
-        if ((jtag_csr_write_enable ==  1'b1) && (jtag_csr ==  5'h7))
-            eba <= jtag_csr_write_data[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
- 
 
     end
 end
 
   
 
+   
 
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-        deba <= deba_reset[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
-    else
-    begin
-        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  5'h9) && (stall_x ==  1'b0))
-            deba <= operand_1_x[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
-  
-
-        if ((jtag_csr_write_enable ==  1'b1) && (jtag_csr ==  5'h9))
-            deba <= jtag_csr_write_data[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+       
+          
+    
+    
+                   
+              
  
+               
+              
+
+    
+
 
-    end
-end
- 
 
 
 
@@ -29940,11 +30029,10 @@ end
 
  
 
-
-  
 
   
  
+ 
 
            
            
@@ -29958,20 +30046,19 @@ end
             
  
 
-
-always @(*)
-begin
-    if (icache_refill_request ==  1'b1) 
-        valid_a =  1'b0;
-    else if (icache_restart_request ==  1'b1) 
-        valid_a =  1'b1;
-    else 
-        valid_a = !icache_refilling;
-end 
  
 
+        
+          
+         
+          
+     
+          
  
- 
+
+
+
+  
  
 
         
@@ -29983,6 +30070,7 @@ end
  
 
 
+ 
 
 
 always @(posedge clk_i  )
@@ -29999,11 +30087,11 @@ begin
     begin    
         if ((kill_f ==  1'b1) || (stall_a ==  1'b0))
   
+                  
 
-            valid_f <= valid_a;    
- 
-              
 
+            valid_f <=  1'b1;
+ 
             
         else if (stall_f ==  1'b0)
             valid_f <=  1'b0;            
@@ -30048,7 +30136,7 @@ begin
         operand_0_x <= { 32{1'b0}};
         operand_1_x <= { 32{1'b0}};
         store_operand_x <= { 32{1'b0}};
-        branch_target_x <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};        
+        branch_target_x <= { (32-2){1'b0}};        
         x_result_sel_csr_x <=  1'b0;
   
           
@@ -30085,7 +30173,7 @@ begin
         m_bypass_enable_x <=  1'b0;
         write_enable_x <=  1'b0;
         write_idx_x <= { 5{1'b0}};
-        csr_x <= { 5{1'b0}};
+        csr_x <= { 4 {1'b0}};
         load_x <=  1'b0;
         store_x <=  1'b0;
         size_x <= { 2{1'b0}};
@@ -30108,16 +30196,14 @@ begin
         branch_predict_taken_x <=  1'b0;
         condition_x <=  3'b000;
   
+          
 
-        break_x <=  1'b0;
- 
 
         scall_x <=  1'b0;
         eret_x <=  1'b0;
   
+          
 
-        bret_x <=  1'b0;
- 
 
   
           
@@ -30126,7 +30212,7 @@ begin
 
         csr_write_enable_x <=  1'b0;
         operand_m <= { 32{1'b0}};
-        branch_target_m <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
+        branch_target_m <= { (32-2){1'b0}};
         m_result_sel_compare_m <=  1'b0;
   
 
@@ -30159,10 +30245,9 @@ begin
 
 
   
+          
+                  
 
-        debug_exception_m <=  1'b0;
-        non_debug_exception_m <=  1'b0;        
- 
 
         operand_w <= { 32{1'b0}};        
         w_result_sel_load_w <=  1'b0;
@@ -30174,13 +30259,13 @@ begin
         write_idx_w <= { 5{1'b0}};        
         write_enable_w <=  1'b0;
   
-
-        debug_exception_w <=  1'b0;
-        non_debug_exception_w <=  1'b0;        
- 
           
+                  
 
 
+        exception_w <=  1'b0;
+ 
+
   
           
 
@@ -30199,7 +30284,7 @@ begin
             operand_0_x <= d_result_0;
             operand_1_x <= d_result_1;
             store_operand_x <= bypass_data_1;
-            branch_target_x <= branch_reg_d ==  1'b1 ? bypass_data_0[ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] : branch_target_d;            
+            branch_target_x <= branch_reg_d ==  1'b1 ? bypass_data_0[ ((32-2)+2-1):2] : branch_target_d;            
             x_result_sel_csr_x <= x_result_sel_csr_d;
   
               
@@ -30258,9 +30343,8 @@ begin
             condition_x <= condition_d;
             csr_write_enable_x <= csr_write_enable_d;
   
+              
 
-            break_x <= break_d;
- 
 
             scall_x <= scall_d;
   
@@ -30269,9 +30353,8 @@ begin
 
             eret_x <= eret_d;
   
+               
 
-            bret_x <= bret_d; 
- 
 
             write_enable_x <= write_enable_d;
         end
@@ -30323,40 +30406,40 @@ begin
  
 
   
-
 	   
 	   
 	   
 	   
 	   
-            if (non_debug_exception_x ==  1'b1) 
-                write_idx_m <=  5'd30;
-            else if (debug_exception_x ==  1'b1)
-                write_idx_m <=  5'd31;
-            else 
-                write_idx_m <= write_idx_x;
- 
-               
+                
+                  
+                
                   
              
                   
 
 
+            if (exception_x ==  1'b1)
+                write_idx_m <=  5'd30;
+            else 
+                write_idx_m <= write_idx_x;
+ 
+
             condition_met_m <= condition_met_x;
   
+	      
+	        
+		     
+		        
+	           
+	     
+	           
+	   
+	       
 
-	   if (exception_x ==  1'b1)
-	     if ((dc_re ==  1'b1)
-		 || ((debug_exception_x ==  1'b1) 
-		     && (non_debug_exception_x ==  1'b0)))
-	       branch_target_m <= {deba, eid_x, {3{1'b0}}};
-	     else
-	       branch_target_m <= {eba, eid_x, {3{1'b0}}};
-	   else
-	     branch_target_m <= branch_target_x;
- 
-                      
 
+            branch_target_m <= exception_x ==  1'b1 ? {eba, eid_x, {3{1'b0}}} : branch_target_x;
+ 
 
   
               
@@ -30368,16 +30451,14 @@ begin
 
             eret_m <= eret_q_x;
   
+               
 
-            bret_m <= bret_q_x; 
- 
 
             write_enable_m <= exception_x ==  1'b1 ?  1'b1 : write_enable_x;            
   
+              
+                      
 
-            debug_exception_m <= debug_exception_x;
-            non_debug_exception_m <= non_debug_exception_x;        
- 
 
         end
         
@@ -30423,13 +30504,13 @@ begin
 
         write_enable_w <= write_enable_m;
   
-
-        debug_exception_w <= debug_exception_m;
-        non_debug_exception_w <= non_debug_exception_m;
- 
+          
           
 
 
+        exception_w <= exception_m;
+ 
+
   
               
                    
@@ -30836,7 +30917,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -30973,7 +31054,7 @@ endmodule
 
 
 
-module lm32_load_store_unit_medium_debug (
+module lm32_load_store_unit_medium (
     
     clk_i,
     rst_i,
@@ -32050,7 +32131,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -32285,7 +32366,7 @@ endmodule
 
 
 
-module lm32_decoder_medium_debug (
+module lm32_decoder_medium (
     
     instruction,
     
@@ -32364,16 +32445,14 @@ module lm32_decoder_medium_debug (
     bi_conditional,
     bi_unconditional,
   
+    
 
-    break_opcode,
- 
 
     scall,
     eret,
   
+    
 
-    bret,
- 
 
   
     
@@ -32457,8 +32536,8 @@ output [ (5-1):0] write_idx;
 wire   [ (5-1):0] write_idx;
 output [ (32-1):0] immediate;
 wire   [ (32-1):0] immediate;
-output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_offset;
-wire   [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_offset;
+output [ ((32-2)+2-1):2] branch_offset;
+wire   [ ((32-2)+2-1):2] branch_offset;
 output load;
 wire   load;
 output store;
@@ -32507,20 +32586,18 @@ wire bi_conditional;
 output bi_unconditional;
 wire bi_unconditional;
   
-
-output break_opcode;
-wire   break_opcode;
  
+   
+
 
 output scall;
 wire   scall;
 output eret;
 wire   eret;
   
-
-output bret;
-wire   bret;
  
+   
+
 
   
   
@@ -32542,6 +32619,90 @@ wire sign_extend_immediate;
 wire select_high_immediate;                     
 wire select_call_immediate;                     
 
+wire op_add;
+wire op_and;
+wire op_andhi;
+wire op_b;
+wire op_bi;
+wire op_be;
+wire op_bg;
+wire op_bge;
+wire op_bgeu;
+wire op_bgu;
+wire op_bne;
+wire op_call;
+wire op_calli;
+wire op_cmpe;
+wire op_cmpg;
+wire op_cmpge;
+wire op_cmpgeu;
+wire op_cmpgu;
+wire op_cmpne;
+  
+ 
+
+
+wire op_lb;
+wire op_lbu;
+wire op_lh;
+wire op_lhu;
+wire op_lw;
+  
+ 
+
+
+  
+
+wire op_mul;
+ 
+
+wire op_nor;
+wire op_or;
+wire op_orhi;
+wire op_raise;
+wire op_rcsr;
+wire op_sb;
+  
+
+wire op_sextb;
+wire op_sexth;
+ 
+
+wire op_sh;
+  
+
+wire op_sl;
+ 
+
+wire op_sr;
+wire op_sru;
+wire op_sub;
+wire op_sw;
+wire op_user;
+wire op_wcsr;
+wire op_xnor;
+wire op_xor;
+
+wire arith;
+wire logical;
+wire cmp;
+wire bra;
+wire call;
+  
+
+wire shift;
+ 
+
+  
+ 
+
+
+  
+
+wire sext;
+ 
+
+
 
 
 
@@ -32697,9 +32858,8 @@ assign sext = op_sextb | op_sexth;
  
 
   
+   
 
-assign multiply = op_mul;
- 
 
   
     
@@ -32874,16 +33034,14 @@ assign branch = bra | call;
 assign branch_reg = op_call | op_b;
 assign condition = instruction[28:26];      
   
+     
 
-assign break_opcode = op_raise & ~instruction[2];
- 
 
 assign scall = op_raise & instruction[2];
 assign eret = op_b & (instruction[25:21] == 5'd30);
   
+       
 
-assign bret = op_b & (instruction[25:21] == 5'd31);
- 
 
   
 
@@ -33137,7 +33295,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -33272,499 +33430,426 @@ endmodule
 
   
 
+           
+              
+              
+              
+
+           
+             
+           
+             
 
-  
+                
+                  
+              
+            
 
-  
+                 
+          
+               
+               
+              
 
-  
 
-  
 
 
-  
 
-  
+   
+    
+    
+        
+    
+    
+    
+    
+    
+    
+    
+    
+ 
+    
 
-  
+    
+    
+    
+    
+    
+    
+    
+    
+    
+    
 
-  
 
 
-  
 
-  
 
-  
+                               
+                                      
+                             
+                                
+                                       
 
-  
+   
+   
+   
+   
+   
+   
+   
+   
+   
 
 
-  
 
-  
 
-  
 
-  
+                                         
+                                         
 
-  
+                                       
+                                       
+
+                                       
+                        
+   
+                       
+                       
+                                 
+
+                                  
+            
 
+                                        
+ 
+                                      
 
+   
 
 
 
 
-module lm32_icache_medium_debug ( 
+                                
+   
+                              
     
-    clk_i,
-    rst_i,    
-    stall_a,
-    stall_f,
-    address_a,
-    address_f,
-    read_enable_f,
-    refill_ready,
-    refill_data,
-    iflush,
-  
+                               
+   
+                 
+                    
+                                    
+    
+                  
     
 
 
-    valid_d,
-    branch_predict_taken_d,
-    
-    stall_request,
-    restart_request,
-    refill_request,
-    refill_address,
-    refilling,
-    inst
-    );
 
 
 
+ 
+  
+  
+  
+  
+  
+ 
 
+  
+  
+  
+  
+  
 
-parameter associativity = 1;                            
-parameter sets = 512;                                   
-parameter bytes_per_line = 16;                          
-parameter base_address = 0;                             
-parameter limit = 0;                                    
+  
+ 
+ 
+ 
 
-localparam addr_offset_width = clogb2(bytes_per_line)-1-2;
-localparam addr_set_width = clogb2(sets)-1;
-localparam addr_offset_lsb = 2;
-localparam addr_offset_msb = (addr_offset_lsb+addr_offset_width-1);
-localparam addr_set_lsb = (addr_offset_msb+1);
-localparam addr_set_msb = (addr_set_lsb+addr_set_width-1);
-localparam addr_tag_lsb = (addr_set_msb+1);
-localparam addr_tag_msb = clogb2( 32'h7fffffff- 32'h0)-1;
-localparam addr_tag_width = (addr_tag_msb-addr_tag_lsb+1);
+  
+  
+ 
+  
 
+ 
 
 
 
 
-input clk_i;                                        
-input rst_i;                                        
 
-input stall_a;                                      
-input stall_f;                                      
+ 
 
-input valid_d;                                      
-input branch_predict_taken_d;                       
-   
-input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] address_a;                     
-input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] address_f;                     
-input read_enable_f;                                
 
-input refill_ready;                                 
-input [ (32-1):0] refill_data;          
 
-input iflush;                                       
-  
-                                      
 
 
    
+                 
+	  
+	   
+	    
+	     
+	       
+	                        
+	                     
 
+ 
+	    
+	     
+	      
+	                         
+	                        
+	                            
+	                     
+	                      
+	                    
+	                     
+	                     
+	                           
+	      
+	                        
+	      
+	   
+	    
+	     
+	       
+	                        
+	                     
 
+	        
+	    
+	     
+	      
+	                         
+	                        
+	                            
+	                     
+	                      
+	                    
+	                     
+	                       
+	                       
+	      
+	                         
+	      
+	   
+	
 
 
-output stall_request;                               
-wire   stall_request;
-output restart_request;                             
-reg    restart_request;
-output refill_request;                              
-wire   refill_request;
-output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] refill_address;               
-reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] refill_address;               
-output refilling;                                   
-reg    refilling;
-output [ (32-1):0] inst;                
-wire   [ (32-1):0] inst;
 
 
 
 
 
-wire enable;
-wire [0:associativity-1] way_mem_we;
-wire [ (32-1):0] way_data[0:associativity-1];
-wire [ ((addr_tag_width+1)-1):1] way_tag[0:associativity-1];
-wire [0:associativity-1] way_valid;
-wire [0:associativity-1] way_match;
-wire miss;
 
-wire [ (addr_set_width-1):0] tmem_read_address;
-wire [ (addr_set_width-1):0] tmem_write_address;
-wire [ ((addr_offset_width+addr_set_width)-1):0] dmem_read_address;
-wire [ ((addr_offset_width+addr_set_width)-1):0] dmem_write_address;
-wire [ ((addr_tag_width+1)-1):0] tmem_write_data;
+               
+      
+       
+    
 
-reg [ 3:0] state;
-wire flushing;
-wire check;
-wire refill;
 
-reg [associativity-1:0] refill_way_select;
-reg [ addr_offset_msb:addr_offset_lsb] refill_offset;
-wire last_refill;
-reg [ (addr_set_width-1):0] flush_set;
 
-genvar i;
 
+       
+      
+       
+    
+        
+	   
+           
+    
 
 
 
+ 
+       
+    
+    
+   
 
-  
+    
+   
 
 
+   
+    
+                                 
+                                 
 
 
+ 
+                                   
+     
+    
+   
 
 
 
+     
 
 
 
+        
+           
+     
+    
+    
+      
+         
+         
+    
+                     
 
 
+     
+   
 
 
+   
+   
+   
 
+               
+     
+     
+                      
 
 
 
 
 
 
+        
+            
+   
 
+       
+           
+    
+            
+           
+               
+    
 
+    
 
 
 
+   
 
-
-					  
-function integer clogb2;
-input [31:0] value;
-begin
-   for (clogb2 = 0; value > 0; clogb2 = clogb2 + 1)
-        value = value >> 1;
-end
-endfunction 
-
-function integer clogb2_v1;
-input [31:0] value;
-reg   [31:0] i;
-reg   [31:0] temp;
-begin
-   temp = 0;
-   i    = 0;
-   for (i = 0; temp < value; i = i + 1)  
-	temp = 1<<i;
-   clogb2_v1 = i-1;
-end
-endfunction
-
-
+       
+          
+    
+          
 
 
 
+   
 
+       
+    
+          
+          
+          
+          
+    
+     
+    
+         
 
+        
+        
+                    
+               
+                  
+                
+        
 
-   generate
-      for (i = 0; i < associativity; i = i + 1)
-	begin : memories
-	   
-	   lm32_ram 
-	     #(
+        
+        
+                    
+               
+ 
 	       
-	       .data_width                 (32),
-	       .address_width              ( (addr_offset_width+addr_set_width))
-
-) 
-	   way_0_data_ram 
-	     (
-	      
-	      .read_clk                   (clk_i),
-	      .write_clk                  (clk_i),
-	      .reset                      (rst_i),
-	      .read_address               (dmem_read_address),
-	      .enable_read                (enable),
-	      .write_address              (dmem_write_address),
-	      .enable_write               ( 1'b1),
-	      .write_enable               (way_mem_we[i]),
-	      .write_data                 (refill_data),    
+                  
 	      
-	      .read_data                  (way_data[i])
-	      );
-	   
-	   lm32_ram 
-	     #(
-	       
-	       .data_width                 ( (addr_tag_width+1)),
-	       .address_width              ( addr_set_width)
 
-	       ) 
-	   way_0_tag_ram 
-	     (
-	      
-	      .read_clk                   (clk_i),
-	      .write_clk                  (clk_i),
-	      .reset                      (rst_i),
-	      .read_address               (tmem_read_address),
-	      .enable_read                (enable),
-	      .write_address              (tmem_write_address),
-	      .enable_write               ( 1'b1),
-	      .write_enable               (way_mem_we[i] | flushing),
-	      .write_data                 (tmem_write_data),
-	      
-	      .read_data                  ({way_tag[i], way_valid[i]})
-	      );
+		  
 	   
-	end
-endgenerate
-
-
-
-
-
-
-generate
-    for (i = 0; i < associativity; i = i + 1)
-    begin : match
-assign way_match[i] = ({way_tag[i], way_valid[i]} == {address_f[ addr_tag_msb:addr_tag_lsb],  1'b1});
-    end
-endgenerate
-
-
-generate
-    if (associativity == 1)
-    begin : inst_1
-assign inst = way_match[0] ? way_data[0] : 32'b0;
-    end
-    else if (associativity == 2)
-	 begin : inst_2
-assign inst = way_match[0] ? way_data[0] : (way_match[1] ? way_data[1] : 32'b0);
-    end
-endgenerate
-
-
-generate 
-    if (bytes_per_line > 4)
-assign dmem_write_address = {refill_address[ addr_set_msb:addr_set_lsb], refill_offset};
-    else
-assign dmem_write_address = refill_address[ addr_set_msb:addr_set_lsb];
-endgenerate
-    
-assign dmem_read_address = address_a[ addr_set_msb:addr_offset_lsb];
-
-
-assign tmem_read_address = address_a[ addr_set_msb:addr_set_lsb];
-assign tmem_write_address = flushing 
-                                ? flush_set
-                                : refill_address[ addr_set_msb:addr_set_lsb];
-
-
-generate 
-    if (bytes_per_line > 4)                            
-assign last_refill = refill_offset == {addr_offset_width{1'b1}};
-    else
-assign last_refill =  1'b1;
-endgenerate
-
-
-assign enable = (stall_a ==  1'b0);
-
-
-generate
-    if (associativity == 1) 
-    begin : we_1     
-assign way_mem_we[0] = (refill_ready ==  1'b1);
-    end
-    else
-    begin : we_2
-assign way_mem_we[0] = (refill_ready ==  1'b1) && (refill_way_select[0] ==  1'b1);
-assign way_mem_we[1] = (refill_ready ==  1'b1) && (refill_way_select[1] ==  1'b1);
-    end
-endgenerate                     
-
-
-assign tmem_write_data[ 0] = last_refill & !flushing;
-assign tmem_write_data[ ((addr_tag_width+1)-1):1] = refill_address[ addr_tag_msb:addr_tag_lsb];
-
-
-assign flushing = |state[1:0];
-assign check = state[2];
-assign refill = state[3];
+                
+        
+        
+        
+        
+                    
+               
+                  
+               
+            
+                  
+                  
+            
+                
+            
+                  
+                  
+            
+        
 
-assign miss = (~(|way_match)) && (read_enable_f ==  1'b1) && (stall_f ==  1'b0) && !(valid_d && branch_predict_taken_d);
-assign stall_request = (check ==  1'b0);
-assign refill_request = (refill ==  1'b1);
+        
+        
+                    
+               
+            
+                   
+                
                       
+                      
+                
+            
+        
 
+                
+    
 
 
+ 
+       
+    
 
+   
 
-generate
-    if (associativity >= 2) 
-    begin : way_select      
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-        refill_way_select <= {{associativity-1{1'b0}}, 1'b1};
-    else
-    begin        
-        if (miss ==  1'b1)
-            refill_way_select <= {refill_way_select[0], refill_way_select[1]};
-    end
-end
-    end
-endgenerate
-
-
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-        refilling <=  1'b0;
-    else
-        refilling <= refill;
-end
-
-
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        state <=  4'b0001;
-        flush_set <= { addr_set_width{1'b1}};
-        refill_address <= { (clogb2(32'h7fffffff-32'h0)-2){1'bx}};
-        restart_request <=  1'b0;
-    end
-    else 
-    begin
-        case (state)
-
+       
+          
+     
+    
+         
         
-         4'b0001:
-        begin            
-            if (flush_set == { addr_set_width{1'b0}})
-                state <=  4'b0100;
-            flush_set <= flush_set - 1'b1;
-        end
-
         
-         4'b0010:
-        begin            
-            if (flush_set == { addr_set_width{1'b0}})
-  
-	       
+        
+                    
+               
                   
-	      
-
+                
+                  
+        
 
-		state <=  4'b0100;
-	   
-            flush_set <= flush_set - 1'b1;
-        end
         
         
-         4'b0100:
-        begin            
-            if (stall_a ==  1'b0)
-                restart_request <=  1'b0;
-            if (iflush ==  1'b1)
-            begin
-                refill_address <= address_f;
-                state <=  4'b0010;
-            end
-            else if (miss ==  1'b1)
-            begin
-                refill_address <= address_f;
-                state <=  4'b1000;
-            end
-        end
-
+                    
+               
+                    
         
-         4'b1000:
-        begin            
-            if (refill_ready ==  1'b1)
-            begin
-                if (last_refill ==  1'b1)
-                begin
-                    restart_request <=  1'b1;
-                    state <=  4'b0100;
-                end
-            end
-        end
 
-        endcase        
-    end
-end
+                
+    
 
-generate 
-    if (bytes_per_line > 4)
-    begin
+    
 
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-        refill_offset <= {addr_offset_width{1'b0}};
-    else 
-    begin
-        case (state)
-        
-        
-         4'b0100:
-        begin            
-            if (iflush ==  1'b1)
-                refill_offset <= {addr_offset_width{1'b0}};
-            else if (miss ==  1'b1)
-                refill_offset <= {addr_offset_width{1'b0}};
-        end
+   
 
-        
-         4'b1000:
-        begin            
-            if (refill_ready ==  1'b1)
-                refill_offset <= refill_offset + 1'b1;
-        end
 
-        endcase        
-    end
-end
-    end
-endgenerate
-   
-endmodule
 
- 
 
 
 
@@ -33985,7 +34070,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -34812,7 +34897,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -34948,165 +35033,127 @@ endmodule
   
 
 
+                  
+                 
+         
+     
+     
+              
 
-  
-
-  
 
-  
 
-  
 
-  
 
   
-
-
-
-
-
-
-module lm32_debug_medium_debug (
     
-    clk_i, 
-    rst_i,
-    pc_x,
-    load_x,
-    store_x,
-    load_store_address_x,
-    csr_write_enable_x,
-    csr_write_data,
-    csr_x,
-  
-
-    jtag_csr_write_enable,
-    jtag_csr_write_data,
-    jtag_csr,
+     
+    
+    
+    
+    
+    
+    
+    
+    
  
-
-  
-
-    eret_q_x,
-    bret_q_x,
-    stall_x,
-    exception_x,
-    q_x,
-  
     
-
+    
+    
 
  
-
     
-  
-
-    dc_ss,
+    
+    
+    
+    
  
-
-    dc_re,
-    bp_match,
-    wp_match
-    );
     
 
 
+    
+ 
+    
 
+    
+    
+    
+    
+    
 
-parameter breakpoints = 0;                      
-parameter watchpoints = 0;                      
 
 
 
+                         
+                         
 
 
-input clk_i;                                    
-input rst_i;                                    
 
-input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_x;                      
-input load_x;                                   
-input store_x;                                  
-input [ (32-1):0] load_store_address_x;    
-input csr_write_enable_x;                       
-input [ (32-1):0] csr_write_data;          
-input [ (5-1):0] csr_x;                    
-  
 
-input jtag_csr_write_enable;                    
-input [ (32-1):0] jtag_csr_write_data;     
-input [ (5-1):0] jtag_csr;                 
- 
 
-  
+                                     
+                                     
 
-input eret_q_x;                                 
-input bret_q_x;                                 
-input stall_x;                                  
-input exception_x;                              
-input q_x;                                      
-  
+                        
+                                    
+                                   
+      
+                        
+            
+                      
+ 
                      
-
+       
+                   
 
  
-
-
-
-
-
-
-  
-
-output dc_ss;                                   
-reg    dc_ss;
+                                  
+                                  
+                                   
+                               
+                                       
  
+                     
 
-output dc_re;                                   
-reg    dc_re;
-output bp_match;                                
-wire   bp_match;        
-output wp_match;                                
-wire   wp_match;
-
-
-
-
-
-genvar i;                                       
-
-
-
-reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] bp_a[0:breakpoints-1];       
-reg bp_e[0:breakpoints-1];                      
-wire [0:breakpoints-1]bp_match_n;               
 
-reg [ 1:0] wpc_c[0:watchpoints-1];   
-reg [ (32-1):0] wp[0:watchpoints-1];       
-wire [0:watchpoints]wp_match_n;               
 
-wire debug_csr_write_enable;                    
-wire [ (32-1):0] debug_csr_write_data;     
-wire [ (5-1):0] debug_csr;                 
 
-  
 
 
-reg [ 2:0] state;           
 
  
+                                    
+    
 
+                                    
+    
+                                 
+           
+                                 
+   
 
 
 
 
 
-  
+                                        
 
 
 
+         
+                       
+                
 
+     
+         
+                
 
+                     
+       
+                   
 
+ 
 
+             
 
 
 
@@ -35114,6 +35161,7 @@ reg [ 2:0] state;
 
 
 
+ 
 
 
 
@@ -35121,35 +35169,48 @@ reg [ 2:0] state;
 
 
 
+               
+      
+         
+    
 
+ 
+ 
+        
+       
+    
+     
 
+        
+   
+    
+   
 
+    
+               
 
+ 
+               
+      
+             
+                   
 
 
+        
+                   
+    
+   
 
-					  
-function integer clogb2;
-input [31:0] value;
-begin
-   for (clogb2 = 0; value > 0; clogb2 = clogb2 + 1)
-        value = value >> 1;
-end
-endfunction 
+                
+                 
 
-function integer clogb2_v1;
-input [31:0] value;
-reg   [31:0] i;
-reg   [31:0] temp;
-begin
-   temp = 0;
-   i    = 0;
-   for (i = 0; temp < value; i = i + 1)  
-	temp = 1<<i;
-   clogb2_v1 = i-1;
-end
-endfunction
+         
+         
+         
 
+   
+   
+   
 
 
 
@@ -35158,191 +35219,132 @@ endfunction
 
 
 
-generate
-    for (i = 0; i < breakpoints; i = i + 1)
-    begin : bp_comb
-assign bp_match_n[i] = ((bp_a[i] == pc_x) && (bp_e[i] ==  1'b1));
-    end
-endgenerate
-generate 
-  
+               
+      
+   
 
-    if (breakpoints > 0) 
-assign bp_match = (|bp_match_n) || (state ==  3'b011);
-    else
-assign bp_match = state ==  3'b011;
- 
+       
+    
+          
+          
+    
+    
+    
+                 
+        
+              
+              
         
-   
     
-   
+    
+    
 
 
-endgenerate    
-               
 
-generate 
-    for (i = 0; i < watchpoints; i = i + 1)
-    begin : wp_comb
-assign wp_match_n[i] = (wp[i] == load_store_address_x) && ((load_x & wpc_c[i][0]) | (store_x & wpc_c[i][1]));
-    end               
-endgenerate
-generate
-    if (watchpoints > 0) 
-assign wp_match = |wp_match_n;                
-    else
-assign wp_match =  1'b0;
-endgenerate
-                
-  
-                
 
-assign debug_csr_write_enable = (csr_write_enable_x ==  1'b1) || (jtag_csr_write_enable ==  1'b1);
-assign debug_csr_write_data = jtag_csr_write_enable ==  1'b1 ? jtag_csr_write_data : csr_write_data;
-assign debug_csr = jtag_csr_write_enable ==  1'b1 ? jtag_csr : csr_x;
- 
-   
-   
+               
+      
    
 
+       
+    
+          
+          
+    
+    
+    
+           
+        
+               
+                  
+                 
+                  
+        
+      
 
+    
 
 
 
+   
 
+       
+          
+    
+    
+               
+              
+    
+    
 
+ 
 
-generate
-    for (i = 0; i < breakpoints; i = i + 1)
-    begin : bp_seq
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        bp_a[i] <= { (clogb2(32'h7fffffff-32'h0)-2){1'bx}};
-        bp_e[i] <=  1'b0;
-    end
-    else
-    begin
-        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h10 + i))
-        begin
-            bp_a[i] <= debug_csr_write_data[ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2];
-            bp_e[i] <= debug_csr_write_data[0];
-        end
-    end
-end    
-    end
-endgenerate
-
-
-generate
-    for (i = 0; i < watchpoints; i = i + 1)
-    begin : wp_seq
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        wp[i] <= { 32{1'bx}};
-        wpc_c[i] <=  2'b00;
-    end
-    else
-    begin
-        if (debug_csr_write_enable ==  1'b1)
-        begin
-            if (debug_csr ==  5'h8)
-                wpc_c[i] <= debug_csr_write_data[3+i*2:2+i*2];
-            if (debug_csr ==  5'h18 + i)
-                wp[i] <= debug_csr_write_data;
-        end
-    end  
-end
-    end
-endgenerate
-
-
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-        dc_re <=  1'b0;
-    else
-    begin
-        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h8))
-            dc_re <= debug_csr_write_data[1];
-    end
-end    
-
-  
-
+   
 
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        state <=  3'b000;
-        dc_ss <=  1'b0;
-    end
-    else
-    begin
-        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h8))
-        begin
-            dc_ss <= debug_csr_write_data[0];
-            if (debug_csr_write_data[0] ==  1'b0) 
-                state <=  3'b000;
-            else 
-                state <=  3'b001;
-        end
-        case (state)
-         3'b001:
-        begin
+       
+    
+          
+          
+    
+    
+    
+               
+        
+              
+                
+                  
+             
+                  
+        
+         
+        
+        
             
-            if (   (   (eret_q_x ==  1'b1)
-                    || (bret_q_x ==  1'b1)
-                    )
-                && (stall_x ==  1'b0)
-               )
-                state <=  3'b010; 
-        end
-         3'b010:
-        begin
+                     
+                       
+                    
+                   
+               
+                   
+        
+        
+        
             
-            if ((q_x ==  1'b1) && (stall_x ==  1'b0))
-                state <=  3'b011;
-        end
-         3'b011:
-        begin
+                   
+                  
+        
+        
+        
             
-  
+ 
                
                   
              
 
-
-                 if ((exception_x ==  1'b1) && (q_x ==  1'b1) && (stall_x ==  1'b0))
-            begin
-                dc_ss <=  1'b0;
-                state <=  3'b100;
-            end
-        end
-         3'b100:
-        begin
+                            
             
-  
+                  
+                  
+            
+        
+        
+        
+            
+ 
                
                   
              
 
+                  
+        
+        
+    
+
+
 
-                state <=  3'b000;
-        end
-        endcase
-    end
-end
- 
 
 
-endmodule
 
- 
 
 
 
@@ -35578,7 +35580,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -35715,7 +35717,7 @@ endmodule
 
 
 
-module lm32_instruction_unit_medium_debug (
+module lm32_instruction_unit_medium (
     
     clk_i,
     rst_i,
@@ -35740,9 +35742,8 @@ module lm32_instruction_unit_medium_debug (
     branch_mispredict_taken_m,
     branch_target_m,
   
+    
 
-    iflush,
- 
 
   
     
@@ -35766,12 +35767,11 @@ module lm32_instruction_unit_medium_debug (
  
 
   
+    
+    
+    
+    
 
-    jtag_read_enable,
-    jtag_write_enable,
-    jtag_write_data,
-    jtag_address,
- 
 
     
     
@@ -35781,12 +35781,11 @@ module lm32_instruction_unit_medium_debug (
     pc_m,
     pc_w,
   
+    
+    
+    
+    
 
-    icache_stall_request,
-    icache_restart_request,
-    icache_refill_request,
-    icache_refilling,
- 
 
   
     
@@ -35807,10 +35806,9 @@ module lm32_instruction_unit_medium_debug (
  
 
   
+    
+    
 
-    jtag_read_data,
-    jtag_access_complete,
- 
 
   
     
@@ -35856,7 +35854,7 @@ input valid_d;
 input kill_f;                                           
 
 input branch_predict_taken_d;                           
-input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_predict_address_d;          
+input [ ((32-2)+2-1):2] branch_predict_address_d;          
    
       
                                     
@@ -35866,12 +35864,11 @@ input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_predict_address_d;
 input exception_m;
 input branch_taken_m;                                   
 input branch_mispredict_taken_m;                        
-input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_target_m;                   
+input [ ((32-2)+2-1):2] branch_target_m;                   
 
   
+                                            
 
-input iflush;                                           
- 
 
   
                             
@@ -35897,40 +35894,38 @@ input i_rty_i;
 
 
   
+                                  
+                                 
+                   
+                      
 
-input jtag_read_enable;                                 
-input jtag_write_enable;                                
-input [ 7:0] jtag_write_data;                 
-input [ (32-1):0] jtag_address;                    
- 
 
 
 
 
 
         
-output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_f;                             
-reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_f;
-output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_d;                             
-reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_d;
-output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_x;                             
-reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_x;
-output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_m;                             
-reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_m;
-output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_w;                             
-reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_w;
+output [ ((32-2)+2-1):2] pc_f;                             
+reg    [ ((32-2)+2-1):2] pc_f;
+output [ ((32-2)+2-1):2] pc_d;                             
+reg    [ ((32-2)+2-1):2] pc_d;
+output [ ((32-2)+2-1):2] pc_x;                             
+reg    [ ((32-2)+2-1):2] pc_x;
+output [ ((32-2)+2-1):2] pc_m;                             
+reg    [ ((32-2)+2-1):2] pc_m;
+output [ ((32-2)+2-1):2] pc_w;                             
+reg    [ ((32-2)+2-1):2] pc_w;
 
   
+                             
+   
+                           
+   
+                            
+   
+                                 
+   
 
-output icache_stall_request;                            
-wire   icache_stall_request;
-output icache_restart_request;                          
-wire   icache_restart_request;
-output icache_refill_request;                           
-wire   icache_refill_request;
-output icache_refilling;                                
-wire   icache_refilling;
- 
 
 
   
@@ -35943,11 +35938,11 @@ wire   icache_refilling;
 
 output [ (32-1):0] i_dat_o;                        
   
+     
 
-reg    [ (32-1):0] i_dat_o;
- 
-    
 
+wire   [ (32-1):0] i_dat_o;
+ 
 
 output [ (32-1):0] i_adr_o;                        
 reg    [ (32-1):0] i_adr_o;
@@ -35955,21 +35950,21 @@ output i_cyc_o;
 reg    i_cyc_o; 
 output [ (4-1):0] i_sel_o;                 
   
+     
 
-reg    [ (4-1):0] i_sel_o;
- 
-    
 
+wire   [ (4-1):0] i_sel_o;
+ 
 
 output i_stb_o;                                         
 reg    i_stb_o;
 output i_we_o;                                          
   
+    
 
-reg    i_we_o;
- 
-   
 
+wire   i_we_o;
+ 
 
 output [ (3-1):0] i_cti_o;                       
 reg    [ (3-1):0] i_cti_o;
@@ -35981,12 +35976,11 @@ wire   [ (2-1):0] i_bte_o;
 
 
   
+                   
+     
+                             
+   
 
-output [ 7:0] jtag_read_data;                 
-reg    [ 7:0] jtag_read_data;
-output jtag_access_complete;                            
-wire   jtag_access_complete;
- 
 
 
   
@@ -36007,30 +36001,31 @@ reg    [ (32-1):0] instruction_d;
 
 
 
-reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_a;                                
+reg [ ((32-2)+2-1):2] pc_a;                                
 
   
+                       
 
-reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] restart_address;                     
- 
 
 
   
+                               
+                
+                                 
+           
+               
+                  
+                   
+                                          
+                        
 
-wire icache_read_enable_f;                              
-wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] icache_refill_address;              
-reg icache_refill_ready;                                
-reg [ (32-1):0] icache_refill_data;         
-wire [ (32-1):0] icache_data_f;             
-wire [ (3-1):0] first_cycle_type;                
-wire [ (3-1):0] next_cycle_type;                 
-wire last_word;                                         
-wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] first_address;                      
- 
- 
-                    
 
+  
+
+reg [ (32-1):0] wb_data_f;                  
+ 
 
+ 
 
   
                                       
@@ -36050,9 +36045,8 @@ wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] first_address;
 
 
   
+                                         
 
-reg jtag_access;                                        
- 
 
 
 
@@ -36169,57 +36163,53 @@ endfunction
  
   
 
-
-lm32_icache_medium_debug #(
-    .associativity          (associativity),
-    .sets                   (sets),
-    .bytes_per_line         (bytes_per_line),
-    .base_address           (base_address),
-    .limit                  (limit)
-    ) icache ( 
+ 
+              
+                       
+             
+               
+                      
+       
     
-    .clk_i                  (clk_i),
-    .rst_i                  (rst_i),      
-    .stall_a                (stall_a),
-    .stall_f                (stall_f),
-    .branch_predict_taken_d (branch_predict_taken_d),
-    .valid_d                (valid_d),
-    .address_a              (pc_a),
-    .address_f              (pc_f),
-    .read_enable_f          (icache_read_enable_f),
-    .refill_ready           (icache_refill_ready),
-    .refill_data            (icache_refill_data),
-    .iflush                 (iflush),
+                      
+                            
+                    
+                    
+     
+                    
+                  
+                  
+              
+               
+                
+                     
+    
+              
+            
+             
+             
+                  
+                       
     
-    .stall_request          (icache_stall_request),
-    .restart_request        (icache_restart_request),
-    .refill_request         (icache_refill_request),
-    .refill_address         (icache_refill_address),
-    .refilling              (icache_refilling),
-    .inst                   (icache_data_f)
-    );
- 
-
 
 
 
 
 
-  
 
 
-assign icache_read_enable_f =    (valid_f ==  1'b1)
-                              && (kill_f ==  1'b0)
   
-                                 
 
+        
+                                 
+ 
+                                 
                          
-   
+  
                                  
-
        
-                              ;
- 
+                              
+
 
 
 
@@ -36247,11 +36237,10 @@ begin
 	  pc_a = branch_predict_address_d;
 	else
   
+             
+              
+	   
 
-          if (icache_restart_request ==  1'b1)
-            pc_a = restart_address;
-	  else 
- 
         
             pc_a = pc_f + 1'b1;
 end
@@ -36264,25 +36253,25 @@ end
                      
 
   
-
-  
+ 
          
 
+   
 
-assign instruction_f = icache_data_f;
- 
 
- 
- 
+
+  
  
          
 
    
 
 
-   
 
+assign instruction_f = wb_data_f;
+ 
 
+ 
 
 
 
@@ -36290,11 +36279,11 @@ assign instruction_f = icache_data_f;
 
   
 
- 
-   
-   
-   
 
+assign i_dat_o = 32'd0;
+assign i_we_o =  1'b0;
+assign i_sel_o = 4'b1111;
+ 
 
 assign i_bte_o =  2'b00;
  
@@ -36303,32 +36292,31 @@ assign i_bte_o =  2'b00;
   
 
 
-generate
-    case (bytes_per_line)
-    4:
-    begin
-assign first_cycle_type =  3'b111;
-assign next_cycle_type =  3'b111;
-assign last_word =  1'b1;
-assign first_address = icache_refill_address;
-    end
-    8:
-    begin
-assign first_cycle_type =  3'b010;
-assign next_cycle_type =  3'b111;
-assign last_word = i_adr_o[addr_offset_msb:addr_offset_lsb] == 1'b1;
-assign first_address = {icache_refill_address[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:addr_offset_msb+1], {addr_offset_width{1'b0}}};
-    end
-    16:
-    begin
-assign first_cycle_type =  3'b010;
-assign next_cycle_type = i_adr_o[addr_offset_msb] == 1'b1 ?  3'b111 :  3'b010;
-assign last_word = i_adr_o[addr_offset_msb:addr_offset_lsb] == 2'b11;
-assign first_address = {icache_refill_address[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:addr_offset_msb+1], {addr_offset_width{1'b0}}};
-    end
-    endcase
-endgenerate
- 
+     
+    
+    
+   
+   
+   
+   
+    
+    
+    
+   
+   
+     
+    
+    
+    
+    
+   
+         
+     
+    
+    
+    
+
+
 
                      
 
@@ -36341,10 +36329,10 @@ begin
     if (rst_i ==  1'b1)
     begin
         pc_f <= ( 32'h00000000-4)/4;
-        pc_d <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
-        pc_x <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
-        pc_m <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
-        pc_w <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
+        pc_d <= { (32-2){1'b0}};
+        pc_x <= { (32-2){1'b0}};
+        pc_m <= { (32-2){1'b0}};
+        pc_w <= { (32-2){1'b0}};
     end
     else
     begin
@@ -36362,14 +36350,13 @@ end
 
   
 
+   
 
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-        restart_address <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
-    else
-    begin
-  
+       
+          
+    
+    
+ 
          
             
                
@@ -36381,18 +36368,14 @@ begin
                   
 
 
+         
+               
+                  
 
-  
-        
-            if (icache_refill_request ==  1'b1)
-                restart_address <= icache_refill_address;
- 
 
- 
+    
+
 
-    end
-end
- 
 
 
 
@@ -36411,152 +36394,23 @@ end
 
 
   
-
-assign jtag_access_complete = (i_cyc_o ==  1'b1) && ((i_ack_i ==  1'b1) || (i_err_i ==  1'b1)) && (jtag_access ==  1'b1);
-always @(*)
-begin
-    case (jtag_address[1:0])
-    2'b00: jtag_read_data = i_dat_i[ 31:24];
-    2'b01: jtag_read_data = i_dat_i[ 23:16];
-    2'b10: jtag_read_data = i_dat_i[ 15:8];
-    2'b11: jtag_read_data = i_dat_i[ 7:0];
-    endcase 
-end
- 
-
-
-  
-
-
-  
-                
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        i_cyc_o <=  1'b0;
-        i_stb_o <=  1'b0;
-        i_adr_o <= { 32{1'b0}};
-        i_cti_o <=  3'b111;
-        i_lock_o <=  1'b0;
-        icache_refill_data <= { 32{1'b0}};
-        icache_refill_ready <=  1'b0;
-  
-          
-
-
-  
-
-        i_we_o <=  1'b0;
-        i_sel_o <= 4'b1111;
-        jtag_access <=  1'b0;
- 
-
-    end
-    else
-    begin   
-        icache_refill_ready <=  1'b0;
-        
-        if (i_cyc_o ==  1'b1)
-        begin
-            
-            if ((i_ack_i ==  1'b1) || (i_err_i ==  1'b1))
-            begin
-  
-
-                if (jtag_access ==  1'b1)
-                begin
-                    i_cyc_o <=  1'b0;
-                    i_stb_o <=  1'b0;       
-                    i_we_o <=  1'b0;  
-                    jtag_access <=  1'b0;    
-                end
-                else
+                 
  
 
-                begin
-                    if (last_word ==  1'b1)
-                    begin
-                        
-                        i_cyc_o <=  1'b0;
-                        i_stb_o <=  1'b0;
-                        i_lock_o <=  1'b0;
-                    end
-                    
-                    i_adr_o[addr_offset_msb:addr_offset_lsb] <= i_adr_o[addr_offset_msb:addr_offset_lsb] + 1'b1;
-                    i_cti_o <= next_cycle_type;
-                    
-                    icache_refill_ready <=  1'b1;
-                    icache_refill_data <= i_dat_i;
-                end
-            end
-  
-               
-            
-                  
-                  
-            
-
-
-        end
-        else
-        begin
-            if ((icache_refill_request ==  1'b1) && (icache_refill_ready ==  1'b0))
-            begin
-                
-  
      
-                i_sel_o <= 4'b1111;
- 
+       
+       
+       
+       
+     
 
-                i_adr_o <= {first_address, 2'b00};
-                i_cyc_o <=  1'b1;
-                i_stb_o <=  1'b1;                
-                i_cti_o <= first_cycle_type;
-                
-  
-                  
 
 
-            end
-  
 
-            else
-            begin
-                if ((jtag_read_enable ==  1'b1) || (jtag_write_enable ==  1'b1))
-                begin
-                    case (jtag_address[1:0])
-                    2'b00: i_sel_o <= 4'b1000;
-                    2'b01: i_sel_o <= 4'b0100;
-                    2'b10: i_sel_o <= 4'b0010;
-                    2'b11: i_sel_o <= 4'b0001;
-                    endcase
-                    i_adr_o <= jtag_address;
-                    i_dat_o <= {4{jtag_write_data}};
-                    i_cyc_o <=  1'b1;
-                    i_stb_o <=  1'b1;
-                    i_we_o <= jtag_write_enable;
-                    i_cti_o <=  3'b111;
-                    jtag_access <=  1'b1;
-                end
-            end 
- 
-                    
   
-            
-            
-     
-               
-                  
-
-               
-                  
 
 
-        end
-    end
-end
- 
+                  
    
 
        
@@ -36567,23 +36421,50 @@ end
           
           
           
+          
+ 
+          
+
  
           
+          
+          
 
     
     
        
+          
         
            
         
             
-                  
+                   
             
+ 
+                   
                 
-                  
-                  
+                      
+                             
+                        
+                          
+                
+                
+
+                
+                       
+                    
+                        
+                          
+                          
+                          
+                    
+                    
+                        
+                      
+                    
+                      
+                      
                 
-                  
             
  
                
@@ -36595,12 +36476,7 @@ end
         
         
         
-            
-                   
-  
                    
-       
-               
             
                 
       
@@ -36608,45 +36484,146 @@ end
 
                    
                   
+                                  
                   
+                
  
                   
 
             
-	    
-	    
-	               
-  
-		       
-       
-	           
-		
- 
-		      
-
-		
-	    
-        
-    
-
-
-
  
-
-
-
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        instruction_d <= { 32{1'b0}};
-  
-          
-
-
-    end
-    else
-    begin
+            
+            
+                       
+                
+                     
+                       
+                       
+                       
+                       
+                    
+                      
+                      
+                      
+                      
+                      
+                      
+                      
+                
+             
+                    
+ 
+            
+            
+     
+               
+                  
+
+               
+                  
+
+        
+    
+
+
+
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        i_cyc_o <=  1'b0;
+        i_stb_o <=  1'b0;
+        i_adr_o <= { 32{1'b0}};
+        i_cti_o <=  3'b111;
+        i_lock_o <=  1'b0;
+        wb_data_f <= { 32{1'b0}};
+  
+          
+
+
+    end
+    else
+    begin   
+        
+        if (i_cyc_o ==  1'b1)
+        begin
+            
+            if((i_ack_i ==  1'b1) || (i_err_i ==  1'b1))
+            begin
+                
+                i_cyc_o <=  1'b0;
+                i_stb_o <=  1'b0;
+                
+                wb_data_f <= i_dat_i;
+            end
+  
+               
+            
+                  
+                  
+            
+
+
+        end
+        else
+        begin
+            
+            if (   (stall_a ==  1'b0) 
+   
+                   
+
+       
+               )
+            begin
+                
+       
+                  
+
+
+                i_adr_o <= {pc_a, 2'b00};
+                i_cyc_o <=  1'b1;
+                i_stb_o <=  1'b1;
+  
+                  
+
+
+            end
+	    else
+	    begin
+	        if (   (stall_a ==  1'b0) 
+   
+		       
+
+       
+	           )
+		begin
+  
+		      
+
+
+		end
+	    end
+        end
+    end
+end
+ 
+
+ 
+
+
+
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        instruction_d <= { 32{1'b0}};
+  
+          
+
+
+    end
+    else
+    begin
         if (stall_d ==  1'b0)
         begin
             instruction_d <= instruction_f;
@@ -36875,7 +36852,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -37010,523 +36987,443 @@ endmodule
 
   
 
+                              
+                              
+                              
 
-  
-
-  
-
-  
-
-
-
-  
-
-  
-
-  
-
-  
-
-  
-
-  
-
-  
-
-  
-
-
-
-  
-
-  
 
-  
+                          
+                  
+                 
+              
+             
+                    
+                        
+                        
 
-  
 
-  
+                  
+         
+          
+          
+          
+          
+          
+      
+      
+         
 
-  
 
-  
 
-  
 
-  
 
   
-
-
-
-
-
-
-module lm32_jtag_medium_debug (
     
-    clk_i,
-    rst_i,
-    jtag_clk, 
-    jtag_update,
-    jtag_reg_q,
-    jtag_reg_addr_q,
-  
-
-    csr,
-    csr_write_enable,
-    csr_write_data,
-    stall_x,
+    
+    
+     
+    
+    
+    
  
+    
+    
+    
+    
 
-  
-
-    jtag_read_data,
-    jtag_access_complete,
  
+    
+    
 
-  
-
-    exception_q_w,
  
-
     
-  
 
-    jtx_csr_read_data,
-    jrx_csr_read_data,
+    
  
+    
+    
 
-  
-
-    jtag_csr_write_enable,
-    jtag_csr_write_data,
-    jtag_csr,
-    jtag_read_enable,
-    jtag_write_enable,
-    jtag_write_data,
-    jtag_address,
  
+    
+    
+    
+    
+    
+    
+    
 
-  
-
-    jtag_break,
-    jtag_reset,
  
+    
+    
 
-    jtag_reg_d,
-    jtag_reg_addr_d
-    );
-
+    
+    
+    
 
 
 
 
-input clk_i;                                            
-input rst_i;                                            
 
-input jtag_clk;                                         
-input jtag_update;                                      
-input [ 7:0] jtag_reg_q;                      
-input [2:0] jtag_reg_addr_q;                            
+                                             
+                                             
 
-  
+                                          
+                                       
+                        
+                              
 
-input [ (5-1):0] csr;                              
-input csr_write_enable;                                 
-input [ (32-1):0] csr_write_data;                  
-input stall_x;                                          
  
+                                
+                                  
+                    
+                                           
 
-  
-
-input [ 7:0] jtag_read_data;                  
-input jtag_access_complete;                             
  
+                    
+                              
 
-  
-
-input exception_q_w;                                    
  
+                                     
 
 
 
 
 
        
-  
-
-output [ (32-1):0] jtx_csr_read_data;              
-wire   [ (32-1):0] jtx_csr_read_data;
-output [ (32-1):0] jrx_csr_read_data;              
-wire   [ (32-1):0] jrx_csr_read_data;
  
+                
+    
+                
+    
 
-  
-
-output jtag_csr_write_enable;                           
-reg    jtag_csr_write_enable;
-output [ (32-1):0] jtag_csr_write_data;            
-wire   [ (32-1):0] jtag_csr_write_data;
-output [ (5-1):0] jtag_csr;                        
-wire   [ (5-1):0] jtag_csr;
-output jtag_read_enable;                                
-reg    jtag_read_enable;
-output jtag_write_enable;                               
-reg    jtag_write_enable;
-output [ 7:0] jtag_write_data;                
-wire   [ 7:0] jtag_write_data;        
-output [ (32-1):0] jtag_address;                   
-wire   [ (32-1):0] jtag_address;
  
+                            
+    
+              
+    
+                          
+    
+                                 
+    
+                                
+    
+                  
+            
+                     
+    
 
-  
-
-output jtag_break;                                      
-reg    jtag_break;
-output jtag_reset;                                      
-reg    jtag_reset;
  
+                                       
+    
+                                       
+    
 
-output [ 7:0] jtag_reg_d;
-reg    [ 7:0] jtag_reg_d;
-output [2:0] jtag_reg_addr_d;
-wire   [2:0] jtag_reg_addr_d;
+  
+     
+  
+    
              
 
 
 
 
-reg rx_update;                          
-reg rx_update_r;                        
-reg rx_update_r_r;                      
-reg rx_update_r_r_r;                    
-
+                           
+                         
+                       
+                     
 
 
-wire [ 7:0] rx_byte;   
-wire [2:0] rx_addr;
 
+     
   
-                 
-reg [ 7:0] uart_tx_byte;      
-reg uart_tx_valid;                      
-reg [ 7:0] uart_rx_byte;      
-reg uart_rx_valid;                      
- 
 
+                  
+        
+                       
+        
+                       
 
-reg [ 3:0] command;             
-  
 
-reg [ 7:0] jtag_byte_0;       
-reg [ 7:0] jtag_byte_1;
-reg [ 7:0] jtag_byte_2;
-reg [ 7:0] jtag_byte_3;
-reg [ 7:0] jtag_byte_4;
-reg processing;                         
+               
  
+         
+  
+  
+  
+  
+                          
 
 
-reg [ 3:0] state;       
-
+         
 
 
 
 
-  
 
-assign jtag_csr_write_data = {jtag_byte_0, jtag_byte_1, jtag_byte_2, jtag_byte_3};
-assign jtag_csr = jtag_byte_4[ (5-1):0];
-assign jtag_address = {jtag_byte_0, jtag_byte_1, jtag_byte_2, jtag_byte_3};
-assign jtag_write_data = jtag_byte_4;
  
+      
+   
+      
+   
 
                  
 
-  
-                 
-assign jtag_reg_addr_d[1:0] = {uart_rx_valid, uart_tx_valid};         
- 
-   
-
+                  
+             
 
-  
+   
 
-assign jtag_reg_addr_d[2] = processing;
  
    
 
+   
 
 
-  
-                 
-assign jtx_csr_read_data = {{ 32-9{1'b0}}, uart_tx_valid, 8'h00};
-assign jrx_csr_read_data = {{ 32-9{1'b0}}, uart_rx_valid, uart_rx_byte};
- 
+                  
+     
+     
          
                  
 
 
 
 
-assign rx_byte = jtag_reg_q;
-assign rx_addr = jtag_reg_addr_q;
+   
+   
 
 
 
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        rx_update <= 1'b0;
-        rx_update_r <= 1'b0;
-        rx_update_r_r <= 1'b0;
-        rx_update_r_r_r <= 1'b0;
-    end
-    else
-    begin
-        rx_update <= jtag_update;
-        rx_update_r <= rx_update;
-        rx_update_r_r <= rx_update_r;
-        rx_update_r_r_r <= rx_update_r_r;
-    end
-end
+   
 
+       
+    
+          
+          
+          
+          
+    
+    
+    
+          
+          
+          
+          
+    
 
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        state <=  4'h0;
-        command <= 4'b0000;
-        jtag_reg_d <= 8'h00;
-  
 
-        processing <=  1'b0;
-        jtag_csr_write_enable <=  1'b0;
-        jtag_read_enable <=  1'b0;
-        jtag_write_enable <=  1'b0;
- 
 
-  
+   
 
-        jtag_break <=  1'b0;
-        jtag_reset <=  1'b0;
+       
+    
+          
+          
+          
  
+          
+          
+          
+          
 
-  
-                 
-        uart_tx_byte <= 8'h00;
-        uart_tx_valid <=  1'b0;
-        uart_rx_byte <= 8'h00;
-        uart_rx_valid <=  1'b0;
  
+          
+          
 
-    end
-    else
-    begin
-  
-                 
-        if ((csr_write_enable ==  1'b1) && (stall_x ==  1'b0))
-        begin
-            case (csr)
-             5'he:
-            begin
-                
-                uart_tx_byte <= csr_write_data[ 7:0];
-                uart_tx_valid <=  1'b1;
-            end
-             5'hf:
-            begin
-                
-                uart_rx_valid <=  1'b0;
-            end
-            endcase
-        end
- 
-
-  
+                  
+          
+          
+          
+          
 
+    
+    
+    
+                  
+               
         
-        if (exception_q_w ==  1'b1)
-        begin
-            jtag_break <=  1'b0;
-            jtag_reset <=  1'b0;
-        end
+             
+            
+            
+                
+                  
+                  
+            
+            
+            
+                
+                  
+            
+            
+        
+
  
+        
+           
+        
+              
+              
+        
 
-        case (state)
-         4'h0:
-        begin
+         
+        
+        
             
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                command <= rx_byte[7:4];                
-                case (rx_addr)
-  
+                 
+            
+                                  
+                 
+ 
+                
+                
+                     
+ 
+                    
+                          
+                    
+                    
+                              
+                          
+                    
+                    
+                          
+                    
+                    
+                              
+                          
+                    
+                    
+                          
+                    
+                    
+                    
+      
+                              
+                                   
 
-                 3'b000:
-                begin
-                    case (rx_byte[7:4])
-  
+                          
+                    
+                    
+                    
+      
+                              
+                                   
 
-                     4'b0001:
-                        state <=  4'h1;
-                     4'b0011:
-                    begin
-                        {jtag_byte_2, jtag_byte_3} <= {jtag_byte_2, jtag_byte_3} + 1'b1;
-                        state <=  4'h6;
-                    end
-                     4'b0010:
-                        state <=  4'h1;
-                     4'b0100:
-                    begin
-                        {jtag_byte_2, jtag_byte_3} <= {jtag_byte_2, jtag_byte_3} + 1'b1;
-                        state <= 5;
-                    end
-                     4'b0101:
-                        state <=  4'h1;
- 
+                          
                     
-                     4'b0110:
-                    begin
-  
-     
-                        uart_rx_valid <=  1'b0;    
-                        uart_tx_valid <=  1'b0;         
- 
+                                                   
+                
 
-                        jtag_break <=  1'b1;
-                    end
-                     4'b0111:
-                    begin
-  
-     
-                        uart_rx_valid <=  1'b0;    
-                        uart_tx_valid <=  1'b0;         
- 
+                  
+                
+                
+                      
+                      
+                                    
+                
+                
+                      
+                      
+                
 
-                        jtag_reset <=  1'b1;
-                    end
-                    endcase                               
-                end
+                
+                    
+                                
+            
+        
  
-
-  
+        
+        
                  
-                 3'b001:
-                begin
-                    uart_rx_byte <= rx_byte;
-                    uart_rx_valid <=  1'b1;
-                end                    
-                 3'b010:
-                begin
-                    jtag_reg_d <= uart_tx_byte;
-                    uart_tx_valid <=  1'b0;
-                end
- 
+            
+                  
+                  
+            
+        
+        
+        
+                 
+            
+                  
+                  
+            
+        
+        
+        
+                 
+            
+                  
+                  
+            
+        
+        
+        
+                 
+            
+                  
+                   
+                      
+                 
+                      
+            
+        
+        
+        
+                 
+            
+                  
+                  
+            
+        
+        
+        
+             
+            
+            
+            
+                  
+                  
+                  
+            
+            
+            
+            
+                  
+                  
+                  
+            
+            
+            
+                  
+                  
+                  
+            
+            
+        
+        
+        
+               
+                      
+                  
+                  
+                    
+                  
+                  
+            
+            
+        
+        
+              
+              
+              
+            
+
+        
+    
 
-                default:
-                    ;
-                endcase                
-            end
-        end
   
 
-         4'h1:
-        begin
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                jtag_byte_0 <= rx_byte;
-                state <=  4'h2;
-            end
-        end
-         4'h2:
-        begin
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                jtag_byte_1 <= rx_byte;
-                state <=  4'h3;
-            end
-        end
-         4'h3:
-        begin
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                jtag_byte_2 <= rx_byte;
-                state <=  4'h4;
-            end
-        end
-         4'h4:
-        begin
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                jtag_byte_3 <= rx_byte;
-                if (command ==  4'b0001)
-                    state <=  4'h6;
-                else 
-                    state <=  4'h5;
-            end
-        end
-         4'h5:
-        begin
-            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
-            begin
-                jtag_byte_4 <= rx_byte;
-                state <=  4'h6;
-            end
-        end
-         4'h6:
-        begin
-            case (command)
-             4'b0001,
-             4'b0011:
-            begin
-                jtag_read_enable <=  1'b1;
-                processing <=  1'b1;
-                state <=  4'h7;
-            end
-             4'b0010,
-             4'b0100:
-            begin
-                jtag_write_enable <=  1'b1;
-                processing <=  1'b1;
-                state <=  4'h7;
-            end
-             4'b0101:
-            begin
-                jtag_csr_write_enable <=  1'b1;
-                processing <=  1'b1;
-                state <=  4'h8;
-            end
-            endcase
-        end
-         4'h7:
-        begin
-            if (jtag_access_complete ==  1'b1)
-            begin          
-                jtag_read_enable <=  1'b0;
-                jtag_reg_d <= jtag_read_data;
-                jtag_write_enable <=  1'b0;  
-                processing <=  1'b0;
-                state <=  4'h0;
-            end
-        end    
-         4'h8:
-        begin
-            jtag_csr_write_enable <=  1'b0;
-            processing <=  1'b0;
-            state <=  4'h0;
-        end    
- 
 
-        endcase
-    end
-end
-  
-endmodule
 
- 
 
 
 
@@ -37744,7 +37641,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -37881,7 +37778,7 @@ endmodule
 
 
 
-module lm32_interrupt_medium_debug (
+module lm32_interrupt_medium (
     
     clk_i, 
     rst_i,
@@ -37890,18 +37787,17 @@ module lm32_interrupt_medium_debug (
     
     stall_x,
   
-
-    non_debug_exception,
-    debug_exception,
- 
     
+    
+
 
+    exception,
+ 
 
     eret_q_x,
   
+    
 
-    bret_q_x,
- 
 
     csr,
     csr_write_data,
@@ -37930,21 +37826,20 @@ input [interrupts-1:0] interrupt;
 input stall_x;                                  
 
   
+                       
+                           
 
-input non_debug_exception;                      
-input debug_exception;                          
- 
-                                 
 
+input exception;                                
+ 
 
 input eret_q_x;                                 
   
+                                  
 
-input bret_q_x;                                 
- 
 
 
-input [ (5-1):0] csr;                      
+input [ (4 -1):0] csr;                      
 input [ (32-1):0] csr_write_data;          
 input csr_write_enable;                         
 
@@ -37965,15 +37860,17 @@ reg    [ (32-1):0] csr_read_data;
 wire [interrupts-1:0] asserted;                 
 
 wire [interrupts-1:0] interrupt_n_exception;
+wire [interrupts-1:0] ie_csr_read_data;
+wire [interrupts-1:0] ip_csr_read_data;
+wire [interrupts-1:0] im_csr_read_data;
 
 
 
 reg ie;                                         
 reg eie;                                        
   
+                                         
 
-reg bie;                                        
- 
 
 reg [interrupts-1:0] ip;                        
 reg [interrupts-1:0] im;                        
@@ -37993,11 +37890,11 @@ assign asserted = ip | interrupt;
        
 assign ie_csr_read_data = {{ 32-3{1'b0}}, 
   
-
-                           bie,
- 
                            
 
+
+                           1'b0,
+ 
                              
                            eie, 
                            ie
@@ -38011,19 +37908,19 @@ generate
 always @(*)
 begin
     case (csr)
-     5'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     4 'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
+                                    
 
-                                    bie,
- 
-                                                                         
 
+                                    1'b0,                                     
+ 
 
                                     eie, 
                                     ie
                                    };
-     5'h2:  csr_read_data = ip;
-     5'h1:  csr_read_data = im;
+     4 'h2:  csr_read_data = ip;
+     4 'h1:  csr_read_data = im;
     default:       csr_read_data = { 32{1'bx}};
     endcase
 end
@@ -38034,18 +37931,18 @@ end
 always @(*)
 begin
     case (csr)
-     5'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     4 'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
+                                     
 
-                                    bie, 
- 
-                                                                        
 
+                                    1'b0,                                    
+ 
 
                                     eie, 
                                     ie
                                    };
-     5'h2:  csr_read_data = ip;
+     4 'h2:  csr_read_data = ip;
     default:       csr_read_data = { 32{1'bx}};
       endcase
 end
@@ -38074,9 +37971,8 @@ always @(posedge clk_i  )
         ie                   <=  1'b0;
         eie                  <=  1'b0;
   
+                           
 
-        bie                  <=  1'b0;
- 
 
         im                   <= {interrupts{1'b0}};
         ip                   <= {interrupts{1'b0}};
@@ -38088,21 +37984,13 @@ always @(posedge clk_i  )
         
         ip                   <= asserted;
   
-
-        if (non_debug_exception ==  1'b1)
-        begin
+           
+        
             
-            eie              <= ie;
-            ie               <=  1'b0;
-        end
-        else if (debug_exception ==  1'b1)
-        begin
+                           
+                            
+        
             
-            bie              <= ie;
-            ie               <=  1'b0;
-        end
- 
-           
         
             
                            
@@ -38110,6 +37998,14 @@ always @(posedge clk_i  )
         
 
 
+        if (exception ==  1'b1)
+        begin
+            
+            eie              <= ie;
+            ie               <=  1'b0;
+        end
+ 
+
         else if (stall_x ==  1'b0)
         begin
 
@@ -38127,28 +38023,26 @@ always @(posedge clk_i  )
                       
            
   
-
-            else if (bret_q_x ==  1'b1)
                 
-                ie      <= bie;
- 
+                
+                       
+
 
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  5'h0)
+                if (csr ==  4 'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
   
+                      
 
-                    bie <= csr_write_data[2];
- 
 
                 end
-                if (csr ==  5'h1)
+                if (csr ==  4 'h1)
                     im  <= csr_write_data[interrupts-1:0];
-                if (csr ==  5'h2)
+                if (csr ==  4 'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -38165,9 +38059,8 @@ always @(posedge clk_i  )
         ie              <=  1'b0;
         eie             <=  1'b0;
   
+                      
 
-        bie             <=  1'b0;
- 
 
         ip              <= {interrupts{1'b0}};
        eie_delay        <= 0;
@@ -38177,21 +38070,13 @@ always @(posedge clk_i  )
         
         ip              <= asserted;
   
-
-        if (non_debug_exception ==  1'b1)
-        begin
+           
+        
             
-            eie         <= ie;
-            ie          <=  1'b0;
-        end
-        else if (debug_exception ==  1'b1)
-        begin
+                      
+                       
+        
             
-            bie         <= ie;
-            ie          <=  1'b0;
-        end
- 
-           
         
             
                       
@@ -38199,6 +38084,14 @@ always @(posedge clk_i  )
         
 
 
+        if (exception ==  1'b1)
+        begin
+            
+            eie         <= ie;
+            ie          <=  1'b0;
+        end
+ 
+
         else if (stall_x ==  1'b0)
           begin
 
@@ -38214,26 +38107,24 @@ always @(posedge clk_i  )
              end
            
   
-
-            else if (bret_q_x ==  1'b1)
                 
-                ie      <= bie;
- 
+                
+                       
+
 
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  5'h0)
+                if (csr ==  4 'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
   
+                      
 
-                    bie <= csr_write_data[2];
- 
 
                 end
-                if (csr ==  5'h2)
+                if (csr ==  4 'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -38599,7 +38490,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -38817,7 +38708,7 @@ endmodule
 
 
 
-module lm32_top_medium_icache_debug (
+module lm32_top_medium_debug (
     
     clk_i,
     rst_i,
@@ -39061,7 +38952,7 @@ endfunction
 
    
 
-lm32_cpu_medium_icache_debug cpu (
+lm32_cpu_medium_debug cpu (
     
     .clk_i                 (clk_i),
   
@@ -39389,7 +39280,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -39541,7 +39432,7 @@ endmodule
 
 
 
-module lm32_mc_arithmetic_medium_icache_debug (
+module lm32_mc_arithmetic_medium_debug (
     
     clk_i,
     rst_i,
@@ -40060,7 +39951,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -40197,7 +40088,7 @@ endmodule
 
 
 
-module lm32_cpu_medium_icache_debug (
+module lm32_cpu_medium_debug (
     
     clk_i,
   
@@ -40512,6 +40403,9 @@ reg load_x;
 reg load_m;
 wire load_q_x;
 wire store_q_x;
+wire q_m;
+wire load_q_m;
+wire store_q_m;
 wire store_d;                                   
 reg store_x;
 reg store_m;
@@ -40542,6 +40436,7 @@ wire [ 1:0] d_result_sel_1_d;
 wire x_result_sel_csr_d;                        
 reg x_result_sel_csr_x;
   
+ 
                     
  
 
@@ -40918,6 +40813,8 @@ wire dc_ss;
  
 
 wire dc_re;                                     
+wire bp_match;
+wire wp_match;
 wire exception_x;                               
 reg exception_m;                                
 wire debug_exception_x;                         
@@ -41035,7 +40932,7 @@ endfunction
 
 
 
-lm32_instruction_unit_medium_icache_debug #(
+lm32_instruction_unit_medium_debug #(
     .associativity          (icache_associativity),
     .sets                   (icache_sets),
     .bytes_per_line         (icache_bytes_per_line),
@@ -41151,7 +41048,7 @@ lm32_instruction_unit_medium_icache_debug #(
     );
 
 
-lm32_decoder_medium_icache_debug decoder (
+lm32_decoder_medium_debug decoder (
     
     .instruction            (instruction_d),
     
@@ -41249,7 +41146,7 @@ lm32_decoder_medium_icache_debug decoder (
     ); 
 
 
-lm32_load_store_unit_medium_icache_debug #(
+lm32_load_store_unit_medium_debug #(
     .associativity          (dcache_associativity),
     .sets                   (dcache_sets),
     .bytes_per_line         (dcache_bytes_per_line),
@@ -41415,7 +41312,7 @@ lm32_multiplier multiplier (
   
 
 
-lm32_interrupt_medium_icache_debug interrupt_unit (
+lm32_interrupt_medium_debug interrupt_unit (
     
     .clk_i                  (clk_i), 
     .rst_i                  (rst_i),
@@ -41451,7 +41348,7 @@ lm32_interrupt_medium_icache_debug interrupt_unit (
   
 
 
-lm32_jtag_medium_icache_debug jtag (
+lm32_jtag_medium_debug jtag (
     
     .clk_i                  (clk_i),
     .rst_i                  (rst_i),
@@ -41515,7 +41412,7 @@ lm32_jtag_medium_icache_debug jtag (
   
 
 
-lm32_debug_medium_icache_debug #(
+lm32_debug_medium_debug #(
     .breakpoints            (breakpoints),
     .watchpoints            (watchpoints)
   ) hw_debug (
@@ -43549,7 +43446,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -43686,7 +43583,7 @@ endmodule
 
 
 
-module lm32_load_store_unit_medium_icache_debug (
+module lm32_load_store_unit_medium_debug (
     
     clk_i,
     rst_i,
@@ -44763,7 +44660,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -44998,7 +44895,7 @@ endmodule
 
 
 
-module lm32_decoder_medium_icache_debug (
+module lm32_decoder_medium_debug (
     
     instruction,
     
@@ -45255,6 +45152,90 @@ wire sign_extend_immediate;
 wire select_high_immediate;                     
 wire select_call_immediate;                     
 
+wire op_add;
+wire op_and;
+wire op_andhi;
+wire op_b;
+wire op_bi;
+wire op_be;
+wire op_bg;
+wire op_bge;
+wire op_bgeu;
+wire op_bgu;
+wire op_bne;
+wire op_call;
+wire op_calli;
+wire op_cmpe;
+wire op_cmpg;
+wire op_cmpge;
+wire op_cmpgeu;
+wire op_cmpgu;
+wire op_cmpne;
+  
+ 
+
+
+wire op_lb;
+wire op_lbu;
+wire op_lh;
+wire op_lhu;
+wire op_lw;
+  
+ 
+
+
+  
+
+wire op_mul;
+ 
+
+wire op_nor;
+wire op_or;
+wire op_orhi;
+wire op_raise;
+wire op_rcsr;
+wire op_sb;
+  
+
+wire op_sextb;
+wire op_sexth;
+ 
+
+wire op_sh;
+  
+
+wire op_sl;
+ 
+
+wire op_sr;
+wire op_sru;
+wire op_sub;
+wire op_sw;
+wire op_user;
+wire op_wcsr;
+wire op_xnor;
+wire op_xor;
+
+wire arith;
+wire logical;
+wire cmp;
+wire bra;
+wire call;
+  
+
+wire shift;
+ 
+
+  
+ 
+
+
+  
+
+wire sext;
+ 
+
+
 
 
 
@@ -45410,9 +45391,8 @@ assign sext = op_sextb | op_sexth;
  
 
   
+   
 
-assign multiply = op_mul;
- 
 
   
     
@@ -45850,7 +45830,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -46028,7 +46008,7 @@ endmodule
 
 
 
-module lm32_icache_medium_icache_debug ( 
+module lm32_icache_medium_debug ( 
     
     clk_i,
     rst_i,    
@@ -46698,7 +46678,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -47525,7 +47505,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -47679,7 +47659,7 @@ endmodule
 
 
 
-module lm32_debug_medium_icache_debug (
+module lm32_debug_medium_debug (
     
     clk_i, 
     rst_i,
@@ -48291,7 +48271,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -48428,7 +48408,7 @@ endmodule
 
 
 
-module lm32_instruction_unit_medium_icache_debug (
+module lm32_instruction_unit_medium_debug (
     
     clk_i,
     rst_i,
@@ -48883,7 +48863,7 @@ endfunction
   
 
 
-lm32_icache_medium_icache_debug #(
+lm32_icache_medium_debug #(
     .associativity          (associativity),
     .sets                   (sets),
     .bytes_per_line         (bytes_per_line),
@@ -49588,7 +49568,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -49775,7 +49755,7 @@ endmodule
 
 
 
-module lm32_jtag_medium_icache_debug (
+module lm32_jtag_medium_debug (
     
     clk_i,
     rst_i,
@@ -50457,7 +50437,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -50594,7 +50574,7 @@ endmodule
 
 
 
-module lm32_interrupt_medium_icache_debug (
+module lm32_interrupt_medium_debug (
     
     clk_i, 
     rst_i,
@@ -50678,6 +50658,9 @@ reg    [ (32-1):0] csr_read_data;
 wire [interrupts-1:0] asserted;                 
 
 wire [interrupts-1:0] interrupt_n_exception;
+wire [interrupts-1:0] ie_csr_read_data;
+wire [interrupts-1:0] ip_csr_read_data;
+wire [interrupts-1:0] im_csr_read_data;
 
 
 
@@ -52075,7 +52058,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -52746,7 +52729,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -53193,6 +53176,9 @@ reg load_x;
 reg load_m;
 wire load_q_x;
 wire store_q_x;
+wire q_m;
+wire load_q_m;
+wire store_q_m;
 wire store_d;                                   
 reg store_x;
 reg store_m;
@@ -53223,6 +53209,7 @@ wire [ 1:0] d_result_sel_1_d;
 wire x_result_sel_csr_d;                        
 reg x_result_sel_csr_x;
   
+ 
                     
  
 
@@ -53291,8 +53278,8 @@ wire [ (5-1):0] write_idx_d;
 reg [ (5-1):0] write_idx_x;            
 reg [ (5-1):0] write_idx_m;
 reg [ (5-1):0] write_idx_w;
-wire [ (3-1):0] csr_d;                     
-reg  [ (3-1):0] csr_x;                  
+wire [ (4 -1):0] csr_d;                     
+reg  [ (4 -1):0] csr_x;                  
 wire [ (3-1):0] condition_d;         
 reg [ (3-1):0] condition_x;          
   
@@ -53585,6 +53572,8 @@ reg [ (3-1):0] eid_x;
                                       
 
                                       
+ 
+ 
                                 
                                  
                           
@@ -55133,7 +55122,7 @@ assign cfg2 = {
   
 
 assign iflush = (   (csr_write_enable_d ==  1'b1) 
-                 && (csr_d ==  3'h3)
+                 && (csr_d ==  4 'h3)
                  && (stall_d ==  1'b0)
                  && (kill_d ==  1'b0)
                  && (valid_d ==  1'b1))
@@ -55161,7 +55150,7 @@ assign iflush = (   (csr_write_enable_d ==  1'b1)
  
 
 
-assign csr_d = read_idx_0_d[ (3-1):0];
+assign csr_d = read_idx_0_d[ (4 -1):0];
 
 
 always @(*)
@@ -55169,17 +55158,17 @@ begin
     case (csr_x)
   
 
-     3'h0,
-     3'h1,
-     3'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
+     4 'h0,
+     4 'h1,
+     4 'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
  
 
   
          
 
 
-     3'h6:  csr_read_data_x = cfg;
-     3'h7:  csr_read_data_x = {eba, 8'h00};
+     4 'h6:  csr_read_data_x = cfg;
+     4 'h7:  csr_read_data_x = {eba, 8'h00};
   
         
 
@@ -55189,7 +55178,7 @@ begin
         
 
 
-     3'ha: csr_read_data_x = cfg2;
+     4 'ha: csr_read_data_x = cfg2;
       
     default:        csr_read_data_x = { 32{1'bx}};
     endcase
@@ -55206,7 +55195,7 @@ begin
         eba <= eba_reset[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
     else
     begin
-        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  3'h7) && (stall_x ==  1'b0))
+        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  4 'h7) && (stall_x ==  1'b0))
             eba <= operand_1_x[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
   
                
@@ -55412,7 +55401,7 @@ begin
         m_bypass_enable_x <=  1'b0;
         write_enable_x <=  1'b0;
         write_idx_x <= { 5{1'b0}};
-        csr_x <= { 3{1'b0}};
+        csr_x <= { 4 {1'b0}};
         load_x <=  1'b0;
         store_x <=  1'b0;
         size_x <= { 2{1'b0}};
@@ -56156,7 +56145,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -57370,7 +57359,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -57858,6 +57847,90 @@ wire sign_extend_immediate;
 wire select_high_immediate;                     
 wire select_call_immediate;                     
 
+wire op_add;
+wire op_and;
+wire op_andhi;
+wire op_b;
+wire op_bi;
+wire op_be;
+wire op_bg;
+wire op_bge;
+wire op_bgeu;
+wire op_bgu;
+wire op_bne;
+wire op_call;
+wire op_calli;
+wire op_cmpe;
+wire op_cmpg;
+wire op_cmpge;
+wire op_cmpgeu;
+wire op_cmpgu;
+wire op_cmpne;
+  
+ 
+
+
+wire op_lb;
+wire op_lbu;
+wire op_lh;
+wire op_lhu;
+wire op_lw;
+  
+ 
+
+
+  
+
+wire op_mul;
+ 
+
+wire op_nor;
+wire op_or;
+wire op_orhi;
+wire op_raise;
+wire op_rcsr;
+wire op_sb;
+  
+
+wire op_sextb;
+wire op_sexth;
+ 
+
+wire op_sh;
+  
+
+wire op_sl;
+ 
+
+wire op_sr;
+wire op_sru;
+wire op_sub;
+wire op_sw;
+wire op_user;
+wire op_wcsr;
+wire op_xnor;
+wire op_xor;
+
+wire arith;
+wire logical;
+wire cmp;
+wire bra;
+wire call;
+  
+
+wire shift;
+ 
+
+  
+ 
+
+
+  
+
+wire sext;
+ 
+
+
 
 
 
@@ -58013,9 +58086,8 @@ assign sext = op_sextb | op_sexth;
  
 
   
+   
 
-assign multiply = op_mul;
- 
 
   
     
@@ -58451,7 +58523,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -59299,7 +59371,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -60126,7 +60198,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -60809,7 +60881,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -62096,7 +62168,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -62885,7 +62957,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -63083,7 +63155,7 @@ input eret_q_x;
 
 
 
-input [ (3-1):0] csr;                      
+input [ (4 -1):0] csr;                      
 input [ (32-1):0] csr_write_data;          
 input csr_write_enable;                         
 
@@ -63104,6 +63176,9 @@ reg    [ (32-1):0] csr_read_data;
 wire [interrupts-1:0] asserted;                 
 
 wire [interrupts-1:0] interrupt_n_exception;
+wire [interrupts-1:0] ie_csr_read_data;
+wire [interrupts-1:0] ip_csr_read_data;
+wire [interrupts-1:0] im_csr_read_data;
 
 
 
@@ -63149,7 +63224,7 @@ generate
 always @(*)
 begin
     case (csr)
-     3'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     4 'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
                                     
 
@@ -63160,8 +63235,8 @@ begin
                                     eie, 
                                     ie
                                    };
-     3'h2:  csr_read_data = ip;
-     3'h1:  csr_read_data = im;
+     4 'h2:  csr_read_data = ip;
+     4 'h1:  csr_read_data = im;
     default:       csr_read_data = { 32{1'bx}};
     endcase
 end
@@ -63172,7 +63247,7 @@ end
 always @(*)
 begin
     case (csr)
-     3'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     4 'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
                                      
 
@@ -63183,7 +63258,7 @@ begin
                                     eie, 
                                     ie
                                    };
-     3'h2:  csr_read_data = ip;
+     4 'h2:  csr_read_data = ip;
     default:       csr_read_data = { 32{1'bx}};
       endcase
 end
@@ -63272,7 +63347,7 @@ always @(posedge clk_i  )
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  3'h0)
+                if (csr ==  4 'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
@@ -63281,9 +63356,9 @@ always @(posedge clk_i  )
 
 
                 end
-                if (csr ==  3'h1)
+                if (csr ==  4 'h1)
                     im  <= csr_write_data[interrupts-1:0];
-                if (csr ==  3'h2)
+                if (csr ==  4 'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -63356,7 +63431,7 @@ always @(posedge clk_i  )
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  3'h0)
+                if (csr ==  4 'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
@@ -63365,7 +63440,7 @@ always @(posedge clk_i  )
 
 
                 end
-                if (csr ==  3'h2)
+                if (csr ==  4 'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -63422,6 +63497,10 @@ endmodule
 
   
 
+  
+
+  
+
 	  
 
 	  
@@ -63447,13 +63526,20 @@ endmodule
 	  
 
 	  
-	 
-	 
-	 
-	 
+
+	  
+
 	  
+
+	  
+
+	  
+
+	  
+
 	  
-	
+
+	 
 
  
 
@@ -63553,18 +63639,16 @@ endmodule
 
 
   
-                    
-
-
-  
 
   
 
  
+ 
+                    
+
                     
 
 
- 
 
   
 
@@ -63593,24 +63677,25 @@ endmodule
 
 
   
- 
 
+  
+
+ 
 
  
 
 
 
   
- 
-
 
   
+
+ 
+ 
  
 
 
- 
 
- 
 
 
 
@@ -63711,24 +63796,34 @@ endmodule
 
 
   
-                   
-                     
 
+  
 
   
+
+ 
+ 
                    
                      
 
+                    
+                     
+
+
+
+
 
   
 
   
 
- 
+  
 
- 
+  
 
+  
 
+  
 
   
 
@@ -63740,6 +63835,8 @@ endmodule
 
   
 
+ 
+
   
 
   
@@ -63747,28 +63844,29 @@ endmodule
   
 
   
-                      
-                    
 
+ 
 
   
 
   
-                     
-                     
 
+  
+
+  
+
+  
+
+  
+
+  
+
+  
 
   
-                     
-                     
-                     
-                     
-                     
-                     
-                     
-                     
 
  
+ 
 
 
   
@@ -63829,14 +63927,14 @@ endmodule
 
 
   
- 
-
 
   
+
+ 
+ 
  
 
 
- 
 
 
 
@@ -63926,7 +64024,7 @@ endmodule
 
 
 
-module lm32_top_medium (
+module lm32_top_medium_icache_debug (
     
     clk_i,
     rst_i,
@@ -64083,14 +64181,15 @@ wire   [ (2-1):0] D_BTE_O;
  
   
 
-  
-  
- 
-  
-  
- 
- 
 
+wire [ 7:0] jtag_reg_d;
+wire [ 7:0] jtag_reg_q;
+wire jtag_update;
+wire [2:0] jtag_reg_addr_d;
+wire [2:0] jtag_reg_addr_q;
+wire jtck;
+wire jrstn;
+ 
 
 
 
@@ -64169,7 +64268,7 @@ endfunction
 
    
 
-lm32_cpu_medium cpu (
+lm32_cpu_medium_icache_debug cpu (
     
     .clk_i                 (clk_i),
   
@@ -64190,12 +64289,13 @@ lm32_cpu_medium cpu (
 
      
   
-    
-                  
-               
-                
-           
 
+    
+    .jtag_clk              (jtck),
+    .jtag_update           (jtag_update),
+    .jtag_reg_q            (jtag_reg_q),
+    .jtag_reg_addr_q       (jtag_reg_addr_q),
+ 
 
   
 
@@ -64224,9 +64324,10 @@ lm32_cpu_medium cpu (
 
 
   
-                
-           
 
+    .jtag_reg_d            (jtag_reg_d),
+    .jtag_reg_addr_d       (jtag_reg_addr_d),
+ 
 
       
                 
@@ -64261,20 +64362,21 @@ lm32_cpu_medium cpu (
     .D_BTE_O               (D_BTE_O)
     );
    
-  		   
-
   
+		   
+
+jtag_cores jtag_cores (
     
-                     
-                
-    
-                
-                     
-                
-                      
-                     
+    .reg_d                 (jtag_reg_d),
+    .reg_addr_d            (jtag_reg_addr_d),
     
-
+    .reg_update            (jtag_update),
+    .reg_q                 (jtag_reg_q),
+    .reg_addr_q            (jtag_reg_addr_q),
+    .jtck                  (jtck),
+    .jrstn                 (jrstn)
+    );
+ 
         
    
 endmodule
@@ -64494,7 +64596,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -64646,7 +64748,7 @@ endmodule
 
 
 
-module lm32_mc_arithmetic_medium (
+module lm32_mc_arithmetic_medium_icache_debug (
     
     clk_i,
     rst_i,
@@ -65165,7 +65267,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -65302,7 +65404,7 @@ endmodule
 
 
 
-module lm32_cpu_medium (
+module lm32_cpu_medium_icache_debug (
     
     clk_i,
   
@@ -65323,12 +65425,13 @@ module lm32_cpu_medium (
 
      
   
-    
-    
-     
-    
-    
 
+    
+    jtag_clk,
+    jtag_update, 
+    jtag_reg_q,
+    jtag_reg_addr_q,
+ 
 
   
 
@@ -65357,9 +65460,10 @@ module lm32_cpu_medium (
 
 
   
-    
-    
 
+    jtag_reg_d,
+    jtag_reg_addr_d,
+ 
 
       
     
@@ -65400,24 +65504,25 @@ module lm32_cpu_medium (
 
 parameter eba_reset =  32'h00000000;                           
   
-                            
 
+parameter deba_reset =  32'h10000000;                         
+ 
 
 
   
-        
-                          
-      
-          
-                        
 
-
-parameter icache_associativity = 1;    
-parameter icache_sets = 512;                      
-parameter icache_bytes_per_line = 16;  
-parameter icache_base_address = 0;      
-parameter icache_limit = 0;                    
+parameter icache_associativity =  1;     
+parameter icache_sets =  256;                       
+parameter icache_bytes_per_line =  16;   
+parameter icache_base_address =  32'h0;       
+parameter icache_limit =  32'h7fffffff;                     
  
+       
+                         
+     
+         
+                       
+
 
 
   
@@ -65437,11 +65542,11 @@ parameter dcache_limit = 0;
 
 
   
-                          
-
 
-parameter watchpoints = 0;
+parameter watchpoints =  32'h4;                       
  
+   
+
 
   
                           
@@ -65483,11 +65588,12 @@ input [ (32-1):0] interrupt;
     
 
   
-                                  
-                               
-                
-  
 
+input jtag_clk;                                 
+input jtag_update;                              
+input [ 7:0] jtag_reg_q;              
+input [2:0] jtag_reg_addr_q;
+ 
 
 
   
@@ -65527,11 +65633,12 @@ input D_RTY_I;
 
 
   
-  
-    
-  
-    
 
+output [ 7:0] jtag_reg_d;
+wire   [ 7:0] jtag_reg_d;
+output [2:0] jtag_reg_addr_d;
+wire   [2:0] jtag_reg_addr_d;
+ 
 
 
   
@@ -65595,8 +65702,9 @@ wire   [ (2-1):0] D_BTE_O;
 
 
   
-                                     
 
+reg valid_a;                                    
+ 
 
 reg valid_f;                                    
 reg valid_d;                                    
@@ -65611,6 +65719,9 @@ reg load_x;
 reg load_m;
 wire load_q_x;
 wire store_q_x;
+wire q_m;
+wire load_q_m;
+wire store_q_m;
 wire store_d;                                   
 reg store_x;
 reg store_m;
@@ -65619,8 +65730,8 @@ reg [ 1:0] size_x;
 wire branch_d;                                  
 wire branch_predict_d;                          
 wire branch_predict_taken_d;                    
-wire [ ((32-2)+2-1):2] branch_predict_address_d;   
-wire [ ((32-2)+2-1):2] branch_target_d;
+wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_predict_address_d;   
+wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_target_d;
 wire bi_unconditional;
 wire bi_conditional;
 reg branch_x;                                   
@@ -65632,15 +65743,16 @@ reg branch_predict_taken_m;
 wire branch_mispredict_taken_m;                 
 wire branch_flushX_m;                           
 wire branch_reg_d;                              
-wire [ ((32-2)+2-1):2] branch_offset_d;            
-reg [ ((32-2)+2-1):2] branch_target_x;             
-reg [ ((32-2)+2-1):2] branch_target_m;
+wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_offset_d;            
+reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_target_x;             
+reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_target_m;
 wire [ 0:0] d_result_sel_0_d; 
 wire [ 1:0] d_result_sel_1_d; 
 
 wire x_result_sel_csr_d;                        
 reg x_result_sel_csr_x;
   
+ 
                     
  
 
@@ -65709,14 +65821,15 @@ wire [ (5-1):0] write_idx_d;
 reg [ (5-1):0] write_idx_x;            
 reg [ (5-1):0] write_idx_m;
 reg [ (5-1):0] write_idx_w;
-wire [ (3-1):0] csr_d;                     
-reg  [ (3-1):0] csr_x;                  
+wire [ (5-1):0] csr_d;                     
+reg  [ (5-1):0] csr_x;                  
 wire [ (3-1):0] condition_d;         
 reg [ (3-1):0] condition_x;          
   
-                                    
-                                     
 
+wire break_d;                                   
+reg break_x;                                    
+ 
 
 wire scall_d;                                   
 reg scall_x;    
@@ -65729,14 +65842,16 @@ reg eret_m;
 
 
   
-                                     
- 
- 
- 
- 
+
+wire bret_d;                                    
+reg bret_x;
+wire bret_q_x;
+reg bret_m;
+  
  
 
 
+ 
 
 wire csr_write_enable_d;                        
 reg csr_write_enable_x;
@@ -65888,11 +66003,11 @@ wire [ (32-1):0] cfg2;
 reg [ (32-1):0] csr_read_data_x;           
 
 
-wire [ ((32-2)+2-1):2] pc_f;                       
-wire [ ((32-2)+2-1):2] pc_d;                       
-wire [ ((32-2)+2-1):2] pc_x;                       
-wire [ ((32-2)+2-1):2] pc_m;                       
-wire [ ((32-2)+2-1):2] pc_w;                       
+wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_f;                       
+wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_d;                       
+wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_x;                       
+wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_m;                       
+wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_w;                       
   
                           
 
@@ -65906,12 +66021,13 @@ wire [ (32-1):0] instruction_f;
 
 wire [ (32-1):0] instruction_d;     
   
-                                     
-                       
-                     
-                      
-                           
 
+wire iflush;                                    
+wire icache_stall_request;                      
+wire icache_restart_request;                    
+wire icache_refill_request;                     
+wire icache_refilling;                          
+ 
 
   
           
@@ -65937,25 +66053,32 @@ wire stall_wb_load;
 
 
   
- 
-          
-          
 
- 
-                      
-        
-                    
-                           
   
+
+wire [ (32-1):0] jtx_csr_read_data;        
+wire [ (32-1):0] jrx_csr_read_data;        
  
+
   
-  
- 
 
+wire jtag_csr_write_enable;                     
+wire [ (32-1):0] jtag_csr_write_data;      
+wire [ (5-1):0] jtag_csr;                  
+wire jtag_read_enable;                          
+wire [ 7:0] jtag_read_data;
+wire jtag_write_enable;
+wire [ 7:0] jtag_write_data;
+wire [ (32-1):0] jtag_address;
+wire jtag_access_complete;
  
-                                 
 
+  
 
+wire jtag_break;                                
+ 
+
+ 
 
 
 
@@ -65985,10 +66108,11 @@ wire kill_x;
 wire kill_m;                                    
 wire kill_w;                                    
 
-reg [ (32-2)+2-1:8] eba;                 
+reg [ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8] eba;                 
   
-                  
 
+reg [ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8] deba;                
+ 
 
 reg [ (3-1):0] eid_x;                      
   
@@ -65998,34 +66122,41 @@ reg [ (3-1):0] eid_x;
 
 
   
- 
-                                      
 
-                                      
-                                
-                                 
-                          
- 
+  
+
+wire dc_ss;                                     
  
+
+wire dc_re;                                     
+wire bp_match;
+wire wp_match;
+wire exception_x;                               
+reg exception_m;                                
+wire debug_exception_x;                         
+reg debug_exception_m;
+reg debug_exception_w;
+wire debug_exception_q_w;
+wire non_debug_exception_x;                     
+reg non_debug_exception_m;
+reg non_debug_exception_w;
+wire non_debug_exception_q_w;
  
-                      
+                                
  
  
  
 
 
-wire exception_x;                               
-reg exception_m;
-reg exception_w;
-wire exception_q_w;
- 
 
+  
 
   
- 
-                            
 
+wire reset_exception;                           
+ 
 
+ 
 
   
 
@@ -66033,9 +66164,10 @@ wire interrupt_exception;
  
 
   
-                       
-                       
 
+wire breakpoint_exception;                      
+wire watchpoint_exception;                      
+ 
 
   
             
@@ -66116,7 +66248,7 @@ endfunction
 
 
 
-lm32_instruction_unit_medium #(
+lm32_instruction_unit_medium_icache_debug #(
     .associativity          (icache_associativity),
     .sets                   (icache_sets),
     .bytes_per_line         (icache_bytes_per_line),
@@ -66147,8 +66279,9 @@ lm32_instruction_unit_medium #(
     .branch_mispredict_taken_m (branch_mispredict_taken_m),
     .branch_target_m        (branch_target_m),
   
-                     
 
+    .iflush                 (iflush),
+ 
 
   
           
@@ -66172,11 +66305,12 @@ lm32_instruction_unit_medium #(
  
 
   
-           
-          
-            
-               
 
+    .jtag_read_enable       (jtag_read_enable),
+    .jtag_write_enable      (jtag_write_enable),
+    .jtag_write_data        (jtag_write_data),
+    .jtag_address           (jtag_address),
+ 
 
     
     
@@ -66186,11 +66320,12 @@ lm32_instruction_unit_medium #(
     .pc_m                   (pc_m),
     .pc_w                   (pc_w),
   
-       
-     
-      
-           
 
+    .icache_stall_request   (icache_stall_request),
+    .icache_restart_request (icache_restart_request),
+    .icache_refill_request  (icache_refill_request),
+    .icache_refilling       (icache_refilling),
+ 
 
   
                 
@@ -66211,9 +66346,10 @@ lm32_instruction_unit_medium #(
  
 
   
-             
-       
 
+    .jtag_read_data         (jtag_read_data),
+    .jtag_access_complete   (jtag_access_complete),
+ 
 
   
                 
@@ -66228,7 +66364,7 @@ lm32_instruction_unit_medium #(
     );
 
 
-lm32_decoder_medium decoder (
+lm32_decoder_medium_icache_debug decoder (
     
     .instruction            (instruction_d),
     
@@ -66307,14 +66443,16 @@ lm32_decoder_medium decoder (
     .branch_reg             (branch_reg_d),
     .condition              (condition_d),
   
-               
 
+    .break_opcode           (break_d),
+ 
 
     .scall                  (scall_d),
     .eret                   (eret_d),
   
-                       
 
+    .bret                   (bret_d),
+ 
 
   
                 
@@ -66324,7 +66462,7 @@ lm32_decoder_medium decoder (
     ); 
 
 
-lm32_load_store_unit_medium #(
+lm32_load_store_unit_medium_icache_debug #(
     .associativity          (dcache_associativity),
     .sets                   (dcache_sets),
     .bytes_per_line         (dcache_bytes_per_line),
@@ -66490,7 +66628,7 @@ lm32_multiplier multiplier (
   
 
 
-lm32_interrupt_medium interrupt_unit (
+lm32_interrupt_medium_icache_debug interrupt_unit (
     
     .clk_i                  (clk_i), 
     .rst_i                  (rst_i),
@@ -66499,17 +66637,18 @@ lm32_interrupt_medium interrupt_unit (
     
     .stall_x                (stall_x),
   
-         
-            
-
 
-    .exception              (exception_q_w), 
+    .non_debug_exception    (non_debug_exception_q_w), 
+    .debug_exception        (debug_exception_q_w),
  
+                   
+
 
     .eret_q_x               (eret_q_x),
   
-                   
 
+    .bret_q_x               (bret_q_x),
+ 
 
     .csr                    (csr_x),
     .csr_write_data         (operand_1_x),
@@ -66524,95 +66663,116 @@ lm32_interrupt_medium interrupt_unit (
 
   
 
-  
+
+lm32_jtag_medium_icache_debug jtag (
     
-                      
-                      
+    .clk_i                  (clk_i),
+    .rst_i                  (rst_i),
     
-                   
-                
-                 
-            
+    .jtag_clk               (jtag_clk),
+    .jtag_update            (jtag_update),
+    .jtag_reg_q             (jtag_reg_q),
+    .jtag_reg_addr_q        (jtag_reg_addr_q),
     
+  
+
+    .csr                    (csr_x),
+    .csr_write_data         (operand_1_x),
+    .csr_write_enable       (csr_write_enable_q_x),
+    .stall_x                (stall_x),
  
-                        
-             
-           
-                    
 
+  
+
+    .jtag_read_data         (jtag_read_data),
+    .jtag_access_complete   (jtag_access_complete),
  
-             
-       
 
+  
+
+    .exception_q_w          (debug_exception_q_w || non_debug_exception_q_w),
  
-                
     
     
     
+  
+
+    .jtx_csr_read_data      (jtx_csr_read_data),
+    .jrx_csr_read_data      (jrx_csr_read_data),
  
-          
-          
 
+  
+
+    .jtag_csr_write_enable  (jtag_csr_write_enable),
+    .jtag_csr_write_data    (jtag_csr_write_data),
+    .jtag_csr               (jtag_csr),
+    .jtag_read_enable       (jtag_read_enable),
+    .jtag_write_enable      (jtag_write_enable),
+    .jtag_write_data        (jtag_write_data),
+    .jtag_address           (jtag_address),
  
-      
-        
-                   
-           
-          
-            
-               
 
+  
+
+    .jtag_break             (jtag_break),
+    .jtag_reset             (reset_exception),
  
-                 
-                 
 
     
-                 
-            
-    
-
+    .jtag_reg_d             (jtag_reg_d),
+    .jtag_reg_addr_d        (jtag_reg_addr_d)
+    );
+ 
 
 
   
 
- 
-                
-                
-    
+
+lm32_debug_medium_icache_debug #(
+    .breakpoints            (breakpoints),
+    .watchpoints            (watchpoints)
+  ) hw_debug (
     
-                       
-                      
-                       
-                     
-                    
-       
-         
-             
-                      
- 
-      
-        
-                   
+    .clk_i                  (clk_i), 
+    .rst_i                  (rst_i),
+    .pc_x                   (pc_x),
+    .load_x                 (load_x),
+    .store_x                (store_x),
+    .load_store_address_x   (adder_result_x),
+    .csr_write_enable_x     (csr_write_enable_q_x),
+    .csr_write_data         (operand_1_x),
+    .csr_x                  (csr_x),
+  
 
+    .jtag_csr_write_enable  (jtag_csr_write_enable),
+    .jtag_csr_write_data    (jtag_csr_write_data),
+    .jtag_csr               (jtag_csr),
  
-                   
-                   
-                    
-                
-                        
- 
+
+  
+
+    .eret_q_x               (eret_q_x),
+    .bret_q_x               (bret_q_x),
+    .stall_x                (stall_x),
+    .exception_x            (exception_x),
+    .q_x                    (q_x),
+  
       
 
 
-    
  
-                      
 
-                      
-                   
-                   
     
+  
+
+    .dc_ss                  (dc_ss),
+ 
 
+    .dc_re                  (dc_re),
+    .bp_match               (bp_match),
+    .wp_match               (wp_match)
+    );
+ 
 
 
 
@@ -67057,8 +67217,9 @@ assign kill_f =    (   (valid_d ==  1'b1)
 
 
   
-                    
 
+                || (icache_refill_request ==  1'b1) 
+ 
 
                   
                    
@@ -67071,8 +67232,9 @@ assign kill_d =    (branch_taken_m ==  1'b1)
 
 
   
-                        
 
+                || (icache_refill_request ==  1'b1)     
+ 
                 
                   
                    
@@ -67101,21 +67263,25 @@ assign kill_w =     1'b0
 
 
   
-              
-				         
-				     
-				     
-				 
- 
-                                 
 
-                              
+assign breakpoint_exception =    (   (   (break_x ==  1'b1)
+				      || (bp_match ==  1'b1)
+				     )
+				  && (valid_x ==  1'b1)
+				 )
+  
 
+                              || (jtag_break ==  1'b1)
+ 
+
+                              ;
+ 
 
 
   
-     
 
+assign watchpoint_exception = wp_match ==  1'b1;
+ 
 
 
   
@@ -67139,38 +67305,17 @@ assign system_call_exception = (   (scall_x ==  1'b1)
 			       );
 
   
-      
-                            
-                         
 
-     
- 
-                               
-
- 
-                               
-                               
+assign debug_exception_x =  (breakpoint_exception ==  1'b1)
+                         || (watchpoint_exception ==  1'b1)
+                         ;
 
- 
-                               
+assign non_debug_exception_x = (system_call_exception ==  1'b1)
+  
 
+                            || (reset_exception ==  1'b1)
  
-                                  
- 
-                                   
-                            
- 
- 				   
-				   
-
-                               
-
-                            
 
-         
-
-
-assign exception_x =           (system_call_exception ==  1'b1)
   
                                
                                
@@ -67184,8 +67329,9 @@ assign exception_x =           (system_call_exception ==  1'b1)
 
                             || (   (interrupt_exception ==  1'b1)
   
-                                   
 
+                                && (dc_ss ==  1'b0)
+ 
                             
   
  				   
@@ -67196,27 +67342,54 @@ assign exception_x =           (system_call_exception ==  1'b1)
  
 
                             ;
+
+assign exception_x = (debug_exception_x ==  1'b1) || (non_debug_exception_x ==  1'b1);
+ 
+               
  
+                               
+                               
+
+ 
+                               
+
+ 
+                                  
+ 
+                                   
+                            
+ 
+ 				   
+				   
+
+                               
+
+                            
+
 
 
 
 always @(*)
 begin
   
+
+  
+
+    if (reset_exception ==  1'b1)
+        eid_x =  3'h0;
+    else
  
-       
-          
-    
      
- 
+  
             
           
     
 
-            
-          
-    
 
+         if (breakpoint_exception ==  1'b1)
+        eid_x =  3'd1;
+    else
+ 
 
   
             
@@ -67228,10 +67401,11 @@ begin
 
 
   
-            
-          
-     
 
+         if (watchpoint_exception ==  1'b1)
+        eid_x =  3'd3;
+    else 
+ 
 
   
             
@@ -67243,8 +67417,9 @@ begin
 
          if (   (interrupt_exception ==  1'b1)
   
-                
 
+             && (dc_ss ==  1'b0)
+ 
                             
             )
         eid_x =  3'h6;
@@ -67280,18 +67455,19 @@ assign stall_d =   (stall_x ==  1'b1)
                     && (kill_d ==  1'b0)
 		   )
   
-		         
-			   
-		       
-		          
-			   
-			   
-			   
-			   
-		       
-                       
-		   
 
+		|| (   (   (break_d ==  1'b1)
+			|| (bret_d ==  1'b1)
+		       )
+		    && (   (load_q_x ==  1'b1)
+			|| (store_q_x ==  1'b1)
+			|| (load_q_m ==  1'b1)
+			|| (store_q_m ==  1'b1)
+			|| (D_CYC_O ==  1'b1)
+		       )
+                    && (kill_d ==  1'b0)
+		   )
+ 
                    
                 || (   (csr_write_enable_d ==  1'b1)
                     && (load_q_x ==  1'b1)
@@ -67353,16 +67529,14 @@ assign stall_m =    (stall_wb_load ==  1'b1)
 
                                     
   
-                         
-                             
-
-
-  
 
-                 || (I_CYC_O ==  1'b1)            
+                 || (icache_stall_request ==  1'b1)     
+                 || ((I_CYC_O ==  1'b1) && ((branch_m ==  1'b1) || (exception_m ==  1'b1))) 
  
-
  
+                                
+
+
                                
   
                                   
@@ -67395,21 +67569,24 @@ assign q_x = (valid_x ==  1'b1) && (kill_x ==  1'b0);
 assign csr_write_enable_q_x = (csr_write_enable_x ==  1'b1) && (q_x ==  1'b1);
 assign eret_q_x = (eret_x ==  1'b1) && (q_x ==  1'b1);
   
-         
 
+assign bret_q_x = (bret_x ==  1'b1) && (q_x ==  1'b1);
+ 
 
 assign load_q_x = (load_x ==  1'b1) 
                && (q_x ==  1'b1)
   
-                  
 
+               && (bp_match ==  1'b0)
+ 
 
                   ;
 assign store_q_x = (store_x ==  1'b1) 
                && (q_x ==  1'b1)
   
-                  
 
+               && (bp_match ==  1'b0)
+ 
 
                   ;
   
@@ -67420,12 +67597,12 @@ assign q_m = (valid_m ==  1'b1) && (kill_m ==  1'b0) && (exception_m ==  1'b0);
 assign load_q_m = (load_m ==  1'b1) && (q_m ==  1'b1);
 assign store_q_m = (store_m ==  1'b1) && (q_m ==  1'b1);
   
-         
-                 
 
-
-assign exception_q_w = ((exception_w ==  1'b1) && (valid_w ==  1'b1));        
+assign debug_exception_q_w = ((debug_exception_w ==  1'b1) && (valid_w ==  1'b1));
+assign non_debug_exception_q_w = ((non_debug_exception_w ==  1'b1) && (valid_w ==  1'b1));        
  
+                 
+
 
 
 assign write_enable_q_x = (write_enable_x ==  1'b1) && (valid_x ==  1'b1) && (branch_flushX_m ==  1'b0);
@@ -67441,19 +67618,12 @@ assign cfg = {
               breakpoints[3:0],
               interrupts[5:0],
   
-              
-
 
-               1'b0,
+               1'b1,
  
-
-  
               
 
 
-               1'b0,
- 
-
   
               
 
@@ -67462,18 +67632,25 @@ assign cfg = {
  
 
   
-              
 
-
-               1'b0,
+               1'b1,
  
+              
+
 
   
+
+               1'b1,
+ 
               
 
 
-               1'b0,
+  
+
+               1'b1,
  
+              
+
 
   
               
@@ -67546,19 +67723,22 @@ assign cfg2 = {
    
 
   
-         
-                    
-                    
-                    
-                    
 
- 
-             
-                     
-		    
+assign iflush = (   (csr_write_enable_d ==  1'b1) 
+                 && (csr_d ==  5'h3)
+                 && (stall_d ==  1'b0)
+                 && (kill_d ==  1'b0)
+                 && (valid_d ==  1'b1))
 
-		 
+  
+
+             ||
+                (   (jtag_csr_write_enable ==  1'b1)
+		 && (jtag_csr ==  5'h3))
+ 
 
+		 ;
+ 
  
   
          
@@ -67574,7 +67754,7 @@ assign cfg2 = {
  
 
 
-assign csr_d = read_idx_0_d[ (3-1):0];
+assign csr_d = read_idx_0_d[ (5-1):0];
 
 
 always @(*)
@@ -67582,27 +67762,29 @@ begin
     case (csr_x)
   
 
-     3'h0,
-     3'h1,
-     3'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
+     5'h0,
+     5'h1,
+     5'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
  
 
   
          
 
 
-     3'h6:  csr_read_data_x = cfg;
-     3'h7:  csr_read_data_x = {eba, 8'h00};
+     5'h6:  csr_read_data_x = cfg;
+     5'h7:  csr_read_data_x = {eba, 8'h00};
   
-        
 
+     5'h9: csr_read_data_x = {deba, 8'h00};
+ 
 
   
-          
-        
 
+     5'he:  csr_read_data_x = jtx_csr_read_data;  
+     5'hf:  csr_read_data_x = jrx_csr_read_data;
+ 
 
-     3'ha: csr_read_data_x = cfg2;
+     5'ha: csr_read_data_x = cfg2;
       
     default:        csr_read_data_x = { 32{1'bx}};
     endcase
@@ -67616,36 +67798,40 @@ end
 always @(posedge clk_i  )
 begin
     if (rst_i ==  1'b1)
-        eba <= eba_reset[ (32-2)+2-1:8];
+        eba <= eba_reset[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
     else
     begin
-        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  3'h7) && (stall_x ==  1'b0))
-            eba <= operand_1_x[ (32-2)+2-1:8];
+        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  5'h7) && (stall_x ==  1'b0))
+            eba <= operand_1_x[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
   
-               
-              
 
+        if ((jtag_csr_write_enable ==  1'b1) && (jtag_csr ==  5'h7))
+            eba <= jtag_csr_write_data[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+ 
 
     end
 end
 
   
 
-   
-
-       
-          
-    
-    
-                   
-              
- 
-               
-              
 
-    
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+        deba <= deba_reset[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+    else
+    begin
+        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  5'h9) && (stall_x ==  1'b0))
+            deba <= operand_1_x[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+  
 
+        if ((jtag_csr_write_enable ==  1'b1) && (jtag_csr ==  5'h9))
+            deba <= jtag_csr_write_data[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:8];
+ 
 
+    end
+end
+ 
 
 
 
@@ -67682,7 +67868,8 @@ end
 
 
   
- 
+
+  
  
 
            
@@ -67697,19 +67884,20 @@ end
             
  
 
- 
 
-        
-          
-         
-          
-     
-          
+always @(*)
+begin
+    if (icache_refill_request ==  1'b1) 
+        valid_a =  1'b0;
+    else if (icache_restart_request ==  1'b1) 
+        valid_a =  1'b1;
+    else 
+        valid_a = !icache_refilling;
+end 
  
 
-
-
-  
+ 
+ 
  
 
         
@@ -67721,7 +67909,6 @@ end
  
 
 
- 
 
 
 always @(posedge clk_i  )
@@ -67738,11 +67925,11 @@ begin
     begin    
         if ((kill_f ==  1'b1) || (stall_a ==  1'b0))
   
-                  
 
-
-            valid_f <=  1'b1;
+            valid_f <= valid_a;    
  
+              
+
             
         else if (stall_f ==  1'b0)
             valid_f <=  1'b0;            
@@ -67787,7 +67974,7 @@ begin
         operand_0_x <= { 32{1'b0}};
         operand_1_x <= { 32{1'b0}};
         store_operand_x <= { 32{1'b0}};
-        branch_target_x <= { (32-2){1'b0}};        
+        branch_target_x <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};        
         x_result_sel_csr_x <=  1'b0;
   
           
@@ -67824,7 +68011,7 @@ begin
         m_bypass_enable_x <=  1'b0;
         write_enable_x <=  1'b0;
         write_idx_x <= { 5{1'b0}};
-        csr_x <= { 3{1'b0}};
+        csr_x <= { 5{1'b0}};
         load_x <=  1'b0;
         store_x <=  1'b0;
         size_x <= { 2{1'b0}};
@@ -67847,14 +68034,16 @@ begin
         branch_predict_taken_x <=  1'b0;
         condition_x <=  3'b000;
   
-          
 
+        break_x <=  1'b0;
+ 
 
         scall_x <=  1'b0;
         eret_x <=  1'b0;
   
-          
 
+        bret_x <=  1'b0;
+ 
 
   
           
@@ -67863,7 +68052,7 @@ begin
 
         csr_write_enable_x <=  1'b0;
         operand_m <= { 32{1'b0}};
-        branch_target_m <= { (32-2){1'b0}};
+        branch_target_m <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
         m_result_sel_compare_m <=  1'b0;
   
 
@@ -67896,9 +68085,10 @@ begin
 
 
   
-          
-                  
 
+        debug_exception_m <=  1'b0;
+        non_debug_exception_m <=  1'b0;        
+ 
 
         operand_w <= { 32{1'b0}};        
         w_result_sel_load_w <=  1'b0;
@@ -67910,12 +68100,12 @@ begin
         write_idx_w <= { 5{1'b0}};        
         write_enable_w <=  1'b0;
   
-          
-                  
 
-
-        exception_w <=  1'b0;
+        debug_exception_w <=  1'b0;
+        non_debug_exception_w <=  1'b0;        
  
+          
+
 
   
           
@@ -67935,7 +68125,7 @@ begin
             operand_0_x <= d_result_0;
             operand_1_x <= d_result_1;
             store_operand_x <= bypass_data_1;
-            branch_target_x <= branch_reg_d ==  1'b1 ? bypass_data_0[ ((32-2)+2-1):2] : branch_target_d;            
+            branch_target_x <= branch_reg_d ==  1'b1 ? bypass_data_0[ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] : branch_target_d;            
             x_result_sel_csr_x <= x_result_sel_csr_d;
   
               
@@ -67994,8 +68184,9 @@ begin
             condition_x <= condition_d;
             csr_write_enable_x <= csr_write_enable_d;
   
-              
 
+            break_x <= break_d;
+ 
 
             scall_x <= scall_d;
   
@@ -68004,8 +68195,9 @@ begin
 
             eret_x <= eret_d;
   
-               
 
+            bret_x <= bret_d; 
+ 
 
             write_enable_x <= write_enable_d;
         end
@@ -68057,40 +68249,40 @@ begin
  
 
   
+
 	   
 	   
 	   
 	   
 	   
-                
-                  
-                
-                  
-             
-                  
-
-
-            if (exception_x ==  1'b1)
+            if (non_debug_exception_x ==  1'b1) 
                 write_idx_m <=  5'd30;
+            else if (debug_exception_x ==  1'b1)
+                write_idx_m <=  5'd31;
             else 
                 write_idx_m <= write_idx_x;
  
+               
+                  
+             
+                  
+
 
             condition_met_m <= condition_met_x;
   
-	      
-	        
-		     
-		        
-	           
-	     
-	           
-	   
-	       
-
 
-            branch_target_m <= exception_x ==  1'b1 ? {eba, eid_x, {3{1'b0}}} : branch_target_x;
+	   if (exception_x ==  1'b1)
+	     if ((dc_re ==  1'b1)
+		 || ((debug_exception_x ==  1'b1) 
+		     && (non_debug_exception_x ==  1'b0)))
+	       branch_target_m <= {deba, eid_x, {3{1'b0}}};
+	     else
+	       branch_target_m <= {eba, eid_x, {3{1'b0}}};
+	   else
+	     branch_target_m <= branch_target_x;
  
+                      
+
 
   
               
@@ -68102,14 +68294,16 @@ begin
 
             eret_m <= eret_q_x;
   
-               
 
+            bret_m <= bret_q_x; 
+ 
 
             write_enable_m <= exception_x ==  1'b1 ?  1'b1 : write_enable_x;            
   
-              
-                      
 
+            debug_exception_m <= debug_exception_x;
+            non_debug_exception_m <= non_debug_exception_x;        
+ 
 
         end
         
@@ -68155,12 +68349,12 @@ begin
 
         write_enable_w <= write_enable_m;
   
-          
-          
-
 
-        exception_w <= exception_m;
+        debug_exception_w <= debug_exception_m;
+        non_debug_exception_w <= non_debug_exception_m;
  
+          
+
 
   
               
@@ -68568,7 +68762,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -68705,7 +68899,7 @@ endmodule
 
 
 
-module lm32_load_store_unit_medium (
+module lm32_load_store_unit_medium_icache_debug (
     
     clk_i,
     rst_i,
@@ -69782,7 +69976,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -70017,7 +70211,7 @@ endmodule
 
 
 
-module lm32_decoder_medium (
+module lm32_decoder_medium_icache_debug (
     
     instruction,
     
@@ -70096,14 +70290,16 @@ module lm32_decoder_medium (
     bi_conditional,
     bi_unconditional,
   
-    
 
+    break_opcode,
+ 
 
     scall,
     eret,
   
-    
 
+    bret,
+ 
 
   
     
@@ -70187,8 +70383,8 @@ output [ (5-1):0] write_idx;
 wire   [ (5-1):0] write_idx;
 output [ (32-1):0] immediate;
 wire   [ (32-1):0] immediate;
-output [ ((32-2)+2-1):2] branch_offset;
-wire   [ ((32-2)+2-1):2] branch_offset;
+output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_offset;
+wire   [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_offset;
 output load;
 wire   load;
 output store;
@@ -70237,18 +70433,20 @@ wire bi_conditional;
 output bi_unconditional;
 wire bi_unconditional;
   
- 
-   
 
+output break_opcode;
+wire   break_opcode;
+ 
 
 output scall;
 wire   scall;
 output eret;
 wire   eret;
   
- 
-   
 
+output bret;
+wire   bret;
+ 
 
   
   
@@ -70270,6 +70468,90 @@ wire sign_extend_immediate;
 wire select_high_immediate;                     
 wire select_call_immediate;                     
 
+wire op_add;
+wire op_and;
+wire op_andhi;
+wire op_b;
+wire op_bi;
+wire op_be;
+wire op_bg;
+wire op_bge;
+wire op_bgeu;
+wire op_bgu;
+wire op_bne;
+wire op_call;
+wire op_calli;
+wire op_cmpe;
+wire op_cmpg;
+wire op_cmpge;
+wire op_cmpgeu;
+wire op_cmpgu;
+wire op_cmpne;
+  
+ 
+
+
+wire op_lb;
+wire op_lbu;
+wire op_lh;
+wire op_lhu;
+wire op_lw;
+  
+ 
+
+
+  
+
+wire op_mul;
+ 
+
+wire op_nor;
+wire op_or;
+wire op_orhi;
+wire op_raise;
+wire op_rcsr;
+wire op_sb;
+  
+
+wire op_sextb;
+wire op_sexth;
+ 
+
+wire op_sh;
+  
+
+wire op_sl;
+ 
+
+wire op_sr;
+wire op_sru;
+wire op_sub;
+wire op_sw;
+wire op_user;
+wire op_wcsr;
+wire op_xnor;
+wire op_xor;
+
+wire arith;
+wire logical;
+wire cmp;
+wire bra;
+wire call;
+  
+
+wire shift;
+ 
+
+  
+ 
+
+
+  
+
+wire sext;
+ 
+
+
 
 
 
@@ -70425,9 +70707,8 @@ assign sext = op_sextb | op_sexth;
  
 
   
+   
 
-assign multiply = op_mul;
- 
 
   
     
@@ -70602,14 +70883,16 @@ assign branch = bra | call;
 assign branch_reg = op_call | op_b;
 assign condition = instruction[28:26];      
   
-     
 
+assign break_opcode = op_raise & ~instruction[2];
+ 
 
 assign scall = op_raise & instruction[2];
 assign eret = op_b & (instruction[25:21] == 5'd30);
   
-       
 
+assign bret = op_b & (instruction[25:21] == 5'd31);
+ 
 
   
 
@@ -70863,7 +71146,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -70998,210 +71281,187 @@ endmodule
 
   
 
-           
-              
-              
-              
 
-           
-             
-           
-             
+  
 
-                
-                  
-              
-            
+  
 
-                 
-          
-               
-               
-              
+  
 
+  
 
 
+  
 
+  
 
-   
-    
-    
-        
-    
-    
-    
-    
-    
-    
-    
-    
- 
-    
+  
 
+  
+
+
+  
+
+  
+
+  
+
+  
+
+
+  
+
+  
+
+  
+
+  
+
+  
+
+
+
+
+
+
+module lm32_icache_medium_icache_debug ( 
     
+    clk_i,
+    rst_i,    
+    stall_a,
+    stall_f,
+    address_a,
+    address_f,
+    read_enable_f,
+    refill_ready,
+    refill_data,
+    iflush,
+  
     
+
+
+    valid_d,
+    branch_predict_taken_d,
     
-    
-    
-    
-    
-    
-    
-    
+    stall_request,
+    restart_request,
+    refill_request,
+    refill_address,
+    refilling,
+    inst
+    );
 
 
 
 
 
-                               
-                                      
-                             
-                                
-                                       
+parameter associativity = 1;                            
+parameter sets = 512;                                   
+parameter bytes_per_line = 16;                          
+parameter base_address = 0;                             
+parameter limit = 0;                                    
 
-   
-   
-   
-   
-   
-   
-   
-   
-   
+localparam addr_offset_width = clogb2(bytes_per_line)-1-2;
+localparam addr_set_width = clogb2(sets)-1;
+localparam addr_offset_lsb = 2;
+localparam addr_offset_msb = (addr_offset_lsb+addr_offset_width-1);
+localparam addr_set_lsb = (addr_offset_msb+1);
+localparam addr_set_msb = (addr_set_lsb+addr_set_width-1);
+localparam addr_tag_lsb = (addr_set_msb+1);
+localparam addr_tag_msb = clogb2( 32'h7fffffff- 32'h0)-1;
+localparam addr_tag_width = (addr_tag_msb-addr_tag_lsb+1);
 
 
 
 
 
-                                         
-                                         
+input clk_i;                                        
+input rst_i;                                        
 
-                                       
-                                       
+input stall_a;                                      
+input stall_f;                                      
 
-                                       
-                        
+input valid_d;                                      
+input branch_predict_taken_d;                       
    
-                       
-                       
-                                 
+input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] address_a;                     
+input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] address_f;                     
+input read_enable_f;                                
 
-                                  
-            
+input refill_ready;                                 
+input [ (32-1):0] refill_data;          
 
-                                        
- 
+input iflush;                                       
+  
                                       
 
+
    
 
 
 
 
-                                
-   
-                              
-    
-                               
-   
-                 
-                    
-                                    
-    
-                  
-    
+output stall_request;                               
+wire   stall_request;
+output restart_request;                             
+reg    restart_request;
+output refill_request;                              
+wire   refill_request;
+output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] refill_address;               
+reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] refill_address;               
+output refilling;                                   
+reg    refilling;
+output [ (32-1):0] inst;                
+wire   [ (32-1):0] inst;
 
 
 
 
 
- 
-  
-  
-  
-  
-  
- 
+wire enable;
+wire [0:associativity-1] way_mem_we;
+wire [ (32-1):0] way_data[0:associativity-1];
+wire [ ((addr_tag_width+1)-1):1] way_tag[0:associativity-1];
+wire [0:associativity-1] way_valid;
+wire [0:associativity-1] way_match;
+wire miss;
+
+wire [ (addr_set_width-1):0] tmem_read_address;
+wire [ (addr_set_width-1):0] tmem_write_address;
+wire [ ((addr_offset_width+addr_set_width)-1):0] dmem_read_address;
+wire [ ((addr_offset_width+addr_set_width)-1):0] dmem_write_address;
+wire [ ((addr_tag_width+1)-1):0] tmem_write_data;
+
+reg [ 3:0] state;
+wire flushing;
+wire check;
+wire refill;
+
+reg [associativity-1:0] refill_way_select;
+reg [ addr_offset_msb:addr_offset_lsb] refill_offset;
+wire last_refill;
+reg [ (addr_set_width-1):0] flush_set;
+
+genvar i;
+
+
 
-  
-  
-  
-  
-  
 
-  
- 
- 
- 
 
-  
-  
- 
   
 
- 
 
 
 
 
 
- 
 
 
 
 
 
-   
-                 
-	  
-	   
-	    
-	     
-	       
-	                        
-	                     
 
- 
-	    
-	     
-	      
-	                         
-	                        
-	                            
-	                     
-	                      
-	                    
-	                     
-	                     
-	                           
-	      
-	                        
-	      
-	   
-	    
-	     
-	       
-	                        
-	                     
 
-	        
-	    
-	     
-	      
-	                         
-	                        
-	                            
-	                     
-	                      
-	                    
-	                     
-	                       
-	                       
-	      
-	                         
-	      
-	   
-	
 
 
 
@@ -71210,214 +71470,310 @@ endmodule
 
 
 
-               
-      
-       
-    
 
 
 
 
-       
-      
-       
-    
-        
-	   
-           
-    
 
 
 
- 
-       
-    
-    
-   
+					  
+function integer clogb2;
+input [31:0] value;
+begin
+   for (clogb2 = 0; value > 0; clogb2 = clogb2 + 1)
+        value = value >> 1;
+end
+endfunction 
 
-    
-   
+function integer clogb2_v1;
+input [31:0] value;
+reg   [31:0] i;
+reg   [31:0] temp;
+begin
+   temp = 0;
+   i    = 0;
+   for (i = 0; temp < value; i = i + 1)  
+	temp = 1<<i;
+   clogb2_v1 = i-1;
+end
+endfunction
 
 
-   
-    
-                                 
-                                 
 
 
- 
-                                   
-     
-    
-   
 
 
 
-     
 
+   generate
+      for (i = 0; i < associativity; i = i + 1)
+	begin : memories
+	   
+	   lm32_ram 
+	     #(
+	       
+	       .data_width                 (32),
+	       .address_width              ( (addr_offset_width+addr_set_width))
 
+) 
+	   way_0_data_ram 
+	     (
+	      
+	      .read_clk                   (clk_i),
+	      .write_clk                  (clk_i),
+	      .reset                      (rst_i),
+	      .read_address               (dmem_read_address),
+	      .enable_read                (enable),
+	      .write_address              (dmem_write_address),
+	      .enable_write               ( 1'b1),
+	      .write_enable               (way_mem_we[i]),
+	      .write_data                 (refill_data),    
+	      
+	      .read_data                  (way_data[i])
+	      );
+	   
+	   lm32_ram 
+	     #(
+	       
+	       .data_width                 ( (addr_tag_width+1)),
+	       .address_width              ( addr_set_width)
 
-        
-           
-     
-    
-    
-      
-         
-         
+	       ) 
+	   way_0_tag_ram 
+	     (
+	      
+	      .read_clk                   (clk_i),
+	      .write_clk                  (clk_i),
+	      .reset                      (rst_i),
+	      .read_address               (tmem_read_address),
+	      .enable_read                (enable),
+	      .write_address              (tmem_write_address),
+	      .enable_write               ( 1'b1),
+	      .write_enable               (way_mem_we[i] | flushing),
+	      .write_data                 (tmem_write_data),
+	      
+	      .read_data                  ({way_tag[i], way_valid[i]})
+	      );
+	   
+	end
+endgenerate
+
+
+
+
+
+
+generate
+    for (i = 0; i < associativity; i = i + 1)
+    begin : match
+assign way_match[i] = ({way_tag[i], way_valid[i]} == {address_f[ addr_tag_msb:addr_tag_lsb],  1'b1});
+    end
+endgenerate
+
+
+generate
+    if (associativity == 1)
+    begin : inst_1
+assign inst = way_match[0] ? way_data[0] : 32'b0;
+    end
+    else if (associativity == 2)
+	 begin : inst_2
+assign inst = way_match[0] ? way_data[0] : (way_match[1] ? way_data[1] : 32'b0);
+    end
+endgenerate
+
+
+generate 
+    if (bytes_per_line > 4)
+assign dmem_write_address = {refill_address[ addr_set_msb:addr_set_lsb], refill_offset};
+    else
+assign dmem_write_address = refill_address[ addr_set_msb:addr_set_lsb];
+endgenerate
     
-                     
+assign dmem_read_address = address_a[ addr_set_msb:addr_offset_lsb];
 
 
-     
-   
+assign tmem_read_address = address_a[ addr_set_msb:addr_set_lsb];
+assign tmem_write_address = flushing 
+                                ? flush_set
+                                : refill_address[ addr_set_msb:addr_set_lsb];
 
 
-   
-   
-   
+generate 
+    if (bytes_per_line > 4)                            
+assign last_refill = refill_offset == {addr_offset_width{1'b1}};
+    else
+assign last_refill =  1'b1;
+endgenerate
 
-               
-     
-     
-                      
 
+assign enable = (stall_a ==  1'b0);
 
 
+generate
+    if (associativity == 1) 
+    begin : we_1     
+assign way_mem_we[0] = (refill_ready ==  1'b1);
+    end
+    else
+    begin : we_2
+assign way_mem_we[0] = (refill_ready ==  1'b1) && (refill_way_select[0] ==  1'b1);
+assign way_mem_we[1] = (refill_ready ==  1'b1) && (refill_way_select[1] ==  1'b1);
+    end
+endgenerate                     
 
 
+assign tmem_write_data[ 0] = last_refill & !flushing;
+assign tmem_write_data[ ((addr_tag_width+1)-1):1] = refill_address[ addr_tag_msb:addr_tag_lsb];
 
-        
-            
-   
 
-       
-           
-    
-            
-           
-               
-    
+assign flushing = |state[1:0];
+assign check = state[2];
+assign refill = state[3];
 
-    
+assign miss = (~(|way_match)) && (read_enable_f ==  1'b1) && (stall_f ==  1'b0) && !(valid_d && branch_predict_taken_d);
+assign stall_request = (check ==  1'b0);
+assign refill_request = (refill ==  1'b1);
+                      
 
 
 
-   
 
-       
-          
-    
-          
 
+generate
+    if (associativity >= 2) 
+    begin : way_select      
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+        refill_way_select <= {{associativity-1{1'b0}}, 1'b1};
+    else
+    begin        
+        if (miss ==  1'b1)
+            refill_way_select <= {refill_way_select[0], refill_way_select[1]};
+    end
+end
+    end
+endgenerate
 
 
-   
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+        refilling <=  1'b0;
+    else
+        refilling <= refill;
+end
 
-       
-    
-          
-          
-          
-          
-    
-     
-    
-         
 
-        
-        
-                    
-               
-                  
-                
-        
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        state <=  4'b0001;
+        flush_set <= { addr_set_width{1'b1}};
+        refill_address <= { (clogb2(32'h7fffffff-32'h0)-2){1'bx}};
+        restart_request <=  1'b0;
+    end
+    else 
+    begin
+        case (state)
 
         
+         4'b0001:
+        begin            
+            if (flush_set == { addr_set_width{1'b0}})
+                state <=  4'b0100;
+            flush_set <= flush_set - 1'b1;
+        end
+
         
-                    
-               
- 
+         4'b0010:
+        begin            
+            if (flush_set == { addr_set_width{1'b0}})
+  
 	       
                   
 	      
 
-		  
+
+		state <=  4'b0100;
 	   
-                
-        
-        
-        
+            flush_set <= flush_set - 1'b1;
+        end
         
-                    
-               
-                  
-               
-            
-                  
-                  
-            
-                
-            
-                  
-                  
-            
         
+         4'b0100:
+        begin            
+            if (stall_a ==  1'b0)
+                restart_request <=  1'b0;
+            if (iflush ==  1'b1)
+            begin
+                refill_address <= address_f;
+                state <=  4'b0010;
+            end
+            else if (miss ==  1'b1)
+            begin
+                refill_address <= address_f;
+                state <=  4'b1000;
+            end
+        end
 
         
-        
-                    
-               
-            
-                   
-                
-                      
-                      
-                
-            
-        
-
-                
-    
-
+         4'b1000:
+        begin            
+            if (refill_ready ==  1'b1)
+            begin
+                if (last_refill ==  1'b1)
+                begin
+                    restart_request <=  1'b1;
+                    state <=  4'b0100;
+                end
+            end
+        end
 
- 
-       
-    
+        endcase        
+    end
+end
 
-   
+generate 
+    if (bytes_per_line > 4)
+    begin
 
-       
-          
-     
-    
-         
-        
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+        refill_offset <= {addr_offset_width{1'b0}};
+    else 
+    begin
+        case (state)
         
         
-                    
-               
-                  
-                
-                  
-        
+         4'b0100:
+        begin            
+            if (iflush ==  1'b1)
+                refill_offset <= {addr_offset_width{1'b0}};
+            else if (miss ==  1'b1)
+                refill_offset <= {addr_offset_width{1'b0}};
+        end
 
         
-        
-                    
-               
-                    
-        
-
-                
-    
-
-    
+         4'b1000:
+        begin            
+            if (refill_ready ==  1'b1)
+                refill_offset <= refill_offset + 1'b1;
+        end
 
+        endcase        
+    end
+end
+    end
+endgenerate
    
+endmodule
 
-
-
+ 
 
 
 
@@ -71638,7 +71994,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -72465,7 +72821,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -72601,135 +72957,160 @@ endmodule
   
 
 
-                  
-                 
-         
-     
-     
-              
 
+  
 
+  
 
+  
 
+  
 
   
-    
-     
-    
-    
-    
-    
-    
-    
-    
-    
- 
-    
-    
-    
 
- 
-    
-    
-    
-    
+  
+
+
+
+
+
+
+module lm32_debug_medium_icache_debug (
     
+    clk_i, 
+    rst_i,
+    pc_x,
+    load_x,
+    store_x,
+    load_store_address_x,
+    csr_write_enable_x,
+    csr_write_data,
+    csr_x,
+  
+
+    jtag_csr_write_enable,
+    jtag_csr_write_data,
+    jtag_csr,
  
-    
 
+  
 
+    eret_q_x,
+    bret_q_x,
+    stall_x,
+    exception_x,
+    q_x,
+  
     
+
+
  
-    
 
     
-    
-    
-    
+  
+
+    dc_ss,
+ 
+
+    dc_re,
+    bp_match,
+    wp_match
+    );
     
 
 
 
 
-                         
-                         
+parameter breakpoints = 0;                      
+parameter watchpoints = 0;                      
 
 
 
 
 
-                                     
-                                     
+input clk_i;                                    
+input rst_i;                                    
 
-                        
-                                    
-                                   
-      
-                        
-            
-                      
+input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_x;                      
+input load_x;                                   
+input store_x;                                  
+input [ (32-1):0] load_store_address_x;    
+input csr_write_enable_x;                       
+input [ (32-1):0] csr_write_data;          
+input [ (5-1):0] csr_x;                    
+  
+
+input jtag_csr_write_enable;                    
+input [ (32-1):0] jtag_csr_write_data;     
+input [ (5-1):0] jtag_csr;                 
  
+
+  
+
+input eret_q_x;                                 
+input bret_q_x;                                 
+input stall_x;                                  
+input exception_x;                              
+input q_x;                                      
+  
                      
-       
-                   
+
 
  
-                                  
-                                  
-                                   
-                               
-                                       
- 
-                     
 
 
 
 
 
 
+  
 
+output dc_ss;                                   
+reg    dc_ss;
  
-                                    
-    
 
-                                    
-    
-                                 
-           
-                                 
-   
+output dc_re;                                   
+reg    dc_re;
+output bp_match;                                
+wire   bp_match;        
+output wp_match;                                
+wire   wp_match;
 
 
 
 
 
-                                        
+genvar i;                                       
 
 
 
-         
-                       
-                
+reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] bp_a[0:breakpoints-1];       
+reg bp_e[0:breakpoints-1];                      
+wire [0:breakpoints-1]bp_match_n;               
 
-     
-         
-                
+reg [ 1:0] wpc_c[0:watchpoints-1];   
+reg [ (32-1):0] wp[0:watchpoints-1];       
+wire [0:watchpoints]wp_match_n;               
+
+wire debug_csr_write_enable;                    
+wire [ (32-1):0] debug_csr_write_data;     
+wire [ (5-1):0] debug_csr;                 
+
+  
 
-                     
-       
-                   
+
+reg [ 2:0] state;           
 
  
 
-             
 
 
 
 
 
+  
 
 
- 
 
 
 
@@ -72737,48 +73118,15 @@ endmodule
 
 
 
-               
-      
-         
-    
 
- 
- 
-        
-       
-    
-     
 
-        
-   
-    
-   
 
-    
-               
 
- 
-               
-      
-             
-                   
 
 
-        
-                   
-    
-   
 
-                
-                 
 
-         
-         
-         
 
-   
-   
-   
 
 
 
@@ -72787,132 +73135,223 @@ endmodule
 
 
 
-               
-      
-   
 
-       
-    
-          
-          
-    
-    
-    
-                 
-        
-              
-              
-        
-    
-    
-    
 
+					  
+function integer clogb2;
+input [31:0] value;
+begin
+   for (clogb2 = 0; value > 0; clogb2 = clogb2 + 1)
+        value = value >> 1;
+end
+endfunction 
 
+function integer clogb2_v1;
+input [31:0] value;
+reg   [31:0] i;
+reg   [31:0] temp;
+begin
+   temp = 0;
+   i    = 0;
+   for (i = 0; temp < value; i = i + 1)  
+	temp = 1<<i;
+   clogb2_v1 = i-1;
+end
+endfunction
 
 
-               
-      
-   
 
-       
-    
-          
-          
-    
-    
-    
-           
-        
-               
-                  
-                 
-                  
-        
-      
 
-    
 
 
 
-   
 
-       
-          
-    
-    
-               
-              
-    
-    
 
- 
+generate
+    for (i = 0; i < breakpoints; i = i + 1)
+    begin : bp_comb
+assign bp_match_n[i] = ((bp_a[i] == pc_x) && (bp_e[i] ==  1'b1));
+    end
+endgenerate
+generate 
+  
 
+    if (breakpoints > 0) 
+assign bp_match = (|bp_match_n) || (state ==  3'b011);
+    else
+assign bp_match = state ==  3'b011;
+ 
+        
    
-
-       
-    
-          
-          
-    
-    
     
+   
+
+
+endgenerate    
                
-        
-              
+
+generate 
+    for (i = 0; i < watchpoints; i = i + 1)
+    begin : wp_comb
+assign wp_match_n[i] = (wp[i] == load_store_address_x) && ((load_x & wpc_c[i][0]) | (store_x & wpc_c[i][1]));
+    end               
+endgenerate
+generate
+    if (watchpoints > 0) 
+assign wp_match = |wp_match_n;                
+    else
+assign wp_match =  1'b0;
+endgenerate
                 
-                  
-             
-                  
-        
-         
-        
-        
+  
+                
+
+assign debug_csr_write_enable = (csr_write_enable_x ==  1'b1) || (jtag_csr_write_enable ==  1'b1);
+assign debug_csr_write_data = jtag_csr_write_enable ==  1'b1 ? jtag_csr_write_data : csr_write_data;
+assign debug_csr = jtag_csr_write_enable ==  1'b1 ? jtag_csr : csr_x;
+ 
+   
+   
+   
+
+
+
+
+
+
+
+
+generate
+    for (i = 0; i < breakpoints; i = i + 1)
+    begin : bp_seq
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        bp_a[i] <= { (clogb2(32'h7fffffff-32'h0)-2){1'bx}};
+        bp_e[i] <=  1'b0;
+    end
+    else
+    begin
+        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h10 + i))
+        begin
+            bp_a[i] <= debug_csr_write_data[ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2];
+            bp_e[i] <= debug_csr_write_data[0];
+        end
+    end
+end    
+    end
+endgenerate
+
+
+generate
+    for (i = 0; i < watchpoints; i = i + 1)
+    begin : wp_seq
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        wp[i] <= { 32{1'bx}};
+        wpc_c[i] <=  2'b00;
+    end
+    else
+    begin
+        if (debug_csr_write_enable ==  1'b1)
+        begin
+            if (debug_csr ==  5'h8)
+                wpc_c[i] <= debug_csr_write_data[3+i*2:2+i*2];
+            if (debug_csr ==  5'h18 + i)
+                wp[i] <= debug_csr_write_data;
+        end
+    end  
+end
+    end
+endgenerate
+
+
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+        dc_re <=  1'b0;
+    else
+    begin
+        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h8))
+            dc_re <= debug_csr_write_data[1];
+    end
+end    
+
+  
+
+
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        state <=  3'b000;
+        dc_ss <=  1'b0;
+    end
+    else
+    begin
+        if ((debug_csr_write_enable ==  1'b1) && (debug_csr ==  5'h8))
+        begin
+            dc_ss <= debug_csr_write_data[0];
+            if (debug_csr_write_data[0] ==  1'b0) 
+                state <=  3'b000;
+            else 
+                state <=  3'b001;
+        end
+        case (state)
+         3'b001:
+        begin
             
-                     
-                       
-                    
-                   
-               
-                   
-        
-        
-        
+            if (   (   (eret_q_x ==  1'b1)
+                    || (bret_q_x ==  1'b1)
+                    )
+                && (stall_x ==  1'b0)
+               )
+                state <=  3'b010; 
+        end
+         3'b010:
+        begin
             
-                   
-                  
-        
-        
-        
+            if ((q_x ==  1'b1) && (stall_x ==  1'b0))
+                state <=  3'b011;
+        end
+         3'b011:
+        begin
             
- 
+  
                
                   
              
 
-                            
-            
-                  
-                  
-            
-        
-        
-        
+
+                 if ((exception_x ==  1'b1) && (q_x ==  1'b1) && (stall_x ==  1'b0))
+            begin
+                dc_ss <=  1'b0;
+                state <=  3'b100;
+            end
+        end
+         3'b100:
+        begin
             
- 
+  
                
                   
              
 
-                  
-        
-        
-    
-
-
 
+                state <=  3'b000;
+        end
+        endcase
+    end
+end
+ 
 
 
+endmodule
 
+ 
 
 
 
@@ -73148,7 +73587,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -73285,7 +73724,7 @@ endmodule
 
 
 
-module lm32_instruction_unit_medium (
+module lm32_instruction_unit_medium_icache_debug (
     
     clk_i,
     rst_i,
@@ -73310,8 +73749,9 @@ module lm32_instruction_unit_medium (
     branch_mispredict_taken_m,
     branch_target_m,
   
-    
 
+    iflush,
+ 
 
   
     
@@ -73335,11 +73775,12 @@ module lm32_instruction_unit_medium (
  
 
   
-    
-    
-    
-    
 
+    jtag_read_enable,
+    jtag_write_enable,
+    jtag_write_data,
+    jtag_address,
+ 
 
     
     
@@ -73349,11 +73790,12 @@ module lm32_instruction_unit_medium (
     pc_m,
     pc_w,
   
-    
-    
-    
-    
 
+    icache_stall_request,
+    icache_restart_request,
+    icache_refill_request,
+    icache_refilling,
+ 
 
   
     
@@ -73374,9 +73816,10 @@ module lm32_instruction_unit_medium (
  
 
   
-    
-    
 
+    jtag_read_data,
+    jtag_access_complete,
+ 
 
   
     
@@ -73422,7 +73865,7 @@ input valid_d;
 input kill_f;                                           
 
 input branch_predict_taken_d;                           
-input [ ((32-2)+2-1):2] branch_predict_address_d;          
+input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_predict_address_d;          
    
       
                                     
@@ -73432,11 +73875,12 @@ input [ ((32-2)+2-1):2] branch_predict_address_d;
 input exception_m;
 input branch_taken_m;                                   
 input branch_mispredict_taken_m;                        
-input [ ((32-2)+2-1):2] branch_target_m;                   
+input [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] branch_target_m;                   
 
   
-                                            
 
+input iflush;                                           
+ 
 
   
                             
@@ -73462,38 +73906,40 @@ input i_rty_i;
 
 
   
-                                  
-                                 
-                   
-                      
 
+input jtag_read_enable;                                 
+input jtag_write_enable;                                
+input [ 7:0] jtag_write_data;                 
+input [ (32-1):0] jtag_address;                    
+ 
 
 
 
 
 
         
-output [ ((32-2)+2-1):2] pc_f;                             
-reg    [ ((32-2)+2-1):2] pc_f;
-output [ ((32-2)+2-1):2] pc_d;                             
-reg    [ ((32-2)+2-1):2] pc_d;
-output [ ((32-2)+2-1):2] pc_x;                             
-reg    [ ((32-2)+2-1):2] pc_x;
-output [ ((32-2)+2-1):2] pc_m;                             
-reg    [ ((32-2)+2-1):2] pc_m;
-output [ ((32-2)+2-1):2] pc_w;                             
-reg    [ ((32-2)+2-1):2] pc_w;
+output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_f;                             
+reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_f;
+output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_d;                             
+reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_d;
+output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_x;                             
+reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_x;
+output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_m;                             
+reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_m;
+output [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_w;                             
+reg    [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_w;
 
   
-                             
-   
-                           
-   
-                            
-   
-                                 
-   
 
+output icache_stall_request;                            
+wire   icache_stall_request;
+output icache_restart_request;                          
+wire   icache_restart_request;
+output icache_refill_request;                           
+wire   icache_refill_request;
+output icache_refilling;                                
+wire   icache_refilling;
+ 
 
 
   
@@ -73506,11 +73952,11 @@ reg    [ ((32-2)+2-1):2] pc_w;
 
 output [ (32-1):0] i_dat_o;                        
   
-     
-
 
-wire   [ (32-1):0] i_dat_o;
+reg    [ (32-1):0] i_dat_o;
  
+    
+
 
 output [ (32-1):0] i_adr_o;                        
 reg    [ (32-1):0] i_adr_o;
@@ -73518,21 +73964,21 @@ output i_cyc_o;
 reg    i_cyc_o; 
 output [ (4-1):0] i_sel_o;                 
   
-     
-
 
-wire   [ (4-1):0] i_sel_o;
+reg    [ (4-1):0] i_sel_o;
  
+    
+
 
 output i_stb_o;                                         
 reg    i_stb_o;
 output i_we_o;                                          
   
-    
-
 
-wire   i_we_o;
+reg    i_we_o;
  
+   
+
 
 output [ (3-1):0] i_cti_o;                       
 reg    [ (3-1):0] i_cti_o;
@@ -73544,11 +73990,12 @@ wire   [ (2-1):0] i_bte_o;
 
 
   
-                   
-     
-                             
-   
 
+output [ 7:0] jtag_read_data;                 
+reg    [ 7:0] jtag_read_data;
+output jtag_access_complete;                            
+wire   jtag_access_complete;
+ 
 
 
   
@@ -73569,31 +74016,30 @@ reg    [ (32-1):0] instruction_d;
 
 
 
-reg [ ((32-2)+2-1):2] pc_a;                                
+reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] pc_a;                                
 
   
-                       
-
-
 
-  
-                               
-                
-                                 
-           
-               
-                  
-                   
-                                          
-                        
+reg [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] restart_address;                     
+ 
 
 
   
 
-reg [ (32-1):0] wb_data_f;                  
+wire icache_read_enable_f;                              
+wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] icache_refill_address;              
+reg icache_refill_ready;                                
+reg [ (32-1):0] icache_refill_data;         
+wire [ (32-1):0] icache_data_f;             
+wire [ (3-1):0] first_cycle_type;                
+wire [ (3-1):0] next_cycle_type;                 
+wire last_word;                                         
+wire [ ((clogb2(32'h7fffffff-32'h0)-2)+2-1):2] first_address;                      
  
-
  
+                    
+
+
 
   
                                       
@@ -73613,8 +74059,9 @@ reg [ (32-1):0] wb_data_f;
 
 
   
-                                         
 
+reg jtag_access;                                        
+ 
 
 
 
@@ -73731,35 +74178,36 @@ endfunction
  
   
 
- 
-              
-                       
-             
-               
-                      
-       
-    
-                      
-                            
-                    
-                    
-     
-                    
-                  
-                  
-              
-               
-                
-                     
+
+lm32_icache_medium_icache_debug #(
+    .associativity          (associativity),
+    .sets                   (sets),
+    .bytes_per_line         (bytes_per_line),
+    .base_address           (base_address),
+    .limit                  (limit)
+    ) icache ( 
     
-              
-            
-             
-             
-                  
-                       
+    .clk_i                  (clk_i),
+    .rst_i                  (rst_i),      
+    .stall_a                (stall_a),
+    .stall_f                (stall_f),
+    .branch_predict_taken_d (branch_predict_taken_d),
+    .valid_d                (valid_d),
+    .address_a              (pc_a),
+    .address_f              (pc_f),
+    .read_enable_f          (icache_read_enable_f),
+    .refill_ready           (icache_refill_ready),
+    .refill_data            (icache_refill_data),
+    .iflush                 (iflush),
     
-
+    .stall_request          (icache_stall_request),
+    .restart_request        (icache_restart_request),
+    .refill_request         (icache_refill_request),
+    .refill_address         (icache_refill_address),
+    .refilling              (icache_refilling),
+    .inst                   (icache_data_f)
+    );
+ 
 
 
 
@@ -73768,16 +74216,19 @@ endfunction
 
   
 
-        
-                                 
- 
+
+assign icache_read_enable_f =    (valid_f ==  1'b1)
+                              && (kill_f ==  1'b0)
+  
                                  
+
                          
-  
+   
                                  
-       
-                              
 
+       
+                              ;
+ 
 
 
 
@@ -73805,10 +74256,11 @@ begin
 	  pc_a = branch_predict_address_d;
 	else
   
-             
-              
-	   
 
+          if (icache_restart_request ==  1'b1)
+            pc_a = restart_address;
+	  else 
+ 
         
             pc_a = pc_f + 1'b1;
 end
@@ -73821,25 +74273,25 @@ end
                      
 
   
- 
-         
 
-   
+  
+         
 
 
+assign instruction_f = icache_data_f;
+ 
 
-  
+ 
+ 
  
          
 
    
 
 
+   
 
-assign instruction_f = wb_data_f;
- 
 
- 
 
 
 
@@ -73847,11 +74299,11 @@ assign instruction_f = wb_data_f;
 
   
 
-
-assign i_dat_o = 32'd0;
-assign i_we_o =  1'b0;
-assign i_sel_o = 4'b1111;
  
+   
+   
+   
+
 
 assign i_bte_o =  2'b00;
  
@@ -73860,31 +74312,32 @@ assign i_bte_o =  2'b00;
   
 
 
-     
-    
-    
-   
-   
-   
-   
-    
-    
-    
-   
-   
-     
-    
-    
-    
-    
-   
-         
-     
-    
-    
-    
-
-
+generate
+    case (bytes_per_line)
+    4:
+    begin
+assign first_cycle_type =  3'b111;
+assign next_cycle_type =  3'b111;
+assign last_word =  1'b1;
+assign first_address = icache_refill_address;
+    end
+    8:
+    begin
+assign first_cycle_type =  3'b010;
+assign next_cycle_type =  3'b111;
+assign last_word = i_adr_o[addr_offset_msb:addr_offset_lsb] == 1'b1;
+assign first_address = {icache_refill_address[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:addr_offset_msb+1], {addr_offset_width{1'b0}}};
+    end
+    16:
+    begin
+assign first_cycle_type =  3'b010;
+assign next_cycle_type = i_adr_o[addr_offset_msb] == 1'b1 ?  3'b111 :  3'b010;
+assign last_word = i_adr_o[addr_offset_msb:addr_offset_lsb] == 2'b11;
+assign first_address = {icache_refill_address[ (clogb2(32'h7fffffff-32'h0)-2)+2-1:addr_offset_msb+1], {addr_offset_width{1'b0}}};
+    end
+    endcase
+endgenerate
+ 
 
                      
 
@@ -73897,10 +74350,10 @@ begin
     if (rst_i ==  1'b1)
     begin
         pc_f <= ( 32'h00000000-4)/4;
-        pc_d <= { (32-2){1'b0}};
-        pc_x <= { (32-2){1'b0}};
-        pc_m <= { (32-2){1'b0}};
-        pc_w <= { (32-2){1'b0}};
+        pc_d <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
+        pc_x <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
+        pc_m <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
+        pc_w <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
     end
     else
     begin
@@ -73918,13 +74371,14 @@ end
 
   
 
-   
 
-       
-          
-    
-    
- 
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+        restart_address <= { (clogb2(32'h7fffffff-32'h0)-2){1'b0}};
+    else
+    begin
+  
          
             
                
@@ -73936,14 +74390,18 @@ end
                   
 
 
-         
-               
-                  
-
 
-    
+  
+        
+            if (icache_refill_request ==  1'b1)
+                restart_address <= icache_refill_address;
+ 
 
+ 
 
+    end
+end
+ 
 
 
 
@@ -73962,125 +74420,138 @@ end
 
 
   
-                 
- 
 
-     
-       
-       
-       
-       
-     
+assign jtag_access_complete = (i_cyc_o ==  1'b1) && ((i_ack_i ==  1'b1) || (i_err_i ==  1'b1)) && (jtag_access ==  1'b1);
+always @(*)
+begin
+    case (jtag_address[1:0])
+    2'b00: jtag_read_data = i_dat_i[ 31:24];
+    2'b01: jtag_read_data = i_dat_i[ 23:16];
+    2'b10: jtag_read_data = i_dat_i[ 15:8];
+    2'b11: jtag_read_data = i_dat_i[ 7:0];
+    endcase 
+end
+ 
 
 
+  
 
 
   
+                
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        i_cyc_o <=  1'b0;
+        i_stb_o <=  1'b0;
+        i_adr_o <= { 32{1'b0}};
+        i_cti_o <=  3'b111;
+        i_lock_o <=  1'b0;
+        icache_refill_data <= { 32{1'b0}};
+        icache_refill_ready <=  1'b0;
+  
+          
 
 
-                  
-   
-
-       
-    
-          
-          
-          
-          
-          
-          
-          
- 
-          
+  
 
+        i_we_o <=  1'b0;
+        i_sel_o <= 4'b1111;
+        jtag_access <=  1'b0;
  
-          
-          
-          
 
-    
-    
-       
-          
-        
-           
+    end
+    else
+    begin   
+        icache_refill_ready <=  1'b0;
         
+        if (i_cyc_o ==  1'b1)
+        begin
             
-                   
-            
+            if ((i_ack_i ==  1'b1) || (i_err_i ==  1'b1))
+            begin
+  
+
+                if (jtag_access ==  1'b1)
+                begin
+                    i_cyc_o <=  1'b0;
+                    i_stb_o <=  1'b0;       
+                    i_we_o <=  1'b0;  
+                    jtag_access <=  1'b0;    
+                end
+                else
  
-                   
-                
-                      
-                             
-                        
-                          
-                
-                
 
-                
-                       
-                    
+                begin
+                    if (last_word ==  1'b1)
+                    begin
                         
-                          
-                          
-                          
-                    
+                        i_cyc_o <=  1'b0;
+                        i_stb_o <=  1'b0;
+                        i_lock_o <=  1'b0;
+                    end
                     
-                        
-                      
+                    i_adr_o[addr_offset_msb:addr_offset_lsb] <= i_adr_o[addr_offset_msb:addr_offset_lsb] + 1'b1;
+                    i_cti_o <= next_cycle_type;
                     
-                      
-                      
-                
-            
- 
+                    icache_refill_ready <=  1'b1;
+                    icache_refill_data <= i_dat_i;
+                end
+            end
+  
                
             
                   
                   
             
 
-        
-        
-        
-                   
-            
-                
-      
-                  
 
-                   
-                  
-                                  
-                  
+        end
+        else
+        begin
+            if ((icache_refill_request ==  1'b1) && (icache_refill_ready ==  1'b0))
+            begin
                 
+  
+     
+                i_sel_o <= 4'b1111;
  
+
+                i_adr_o <= {first_address, 2'b00};
+                i_cyc_o <=  1'b1;
+                i_stb_o <=  1'b1;                
+                i_cti_o <= first_cycle_type;
+                
+  
                   
 
-            
+
+            end
+  
+
+            else
+            begin
+                if ((jtag_read_enable ==  1'b1) || (jtag_write_enable ==  1'b1))
+                begin
+                    case (jtag_address[1:0])
+                    2'b00: i_sel_o <= 4'b1000;
+                    2'b01: i_sel_o <= 4'b0100;
+                    2'b10: i_sel_o <= 4'b0010;
+                    2'b11: i_sel_o <= 4'b0001;
+                    endcase
+                    i_adr_o <= jtag_address;
+                    i_dat_o <= {4{jtag_write_data}};
+                    i_cyc_o <=  1'b1;
+                    i_stb_o <=  1'b1;
+                    i_we_o <= jtag_write_enable;
+                    i_cti_o <=  3'b111;
+                    jtag_access <=  1'b1;
+                end
+            end 
  
-            
-            
-                       
-                
-                     
-                       
-                       
-                       
-                       
-                    
-                      
-                      
-                      
-                      
-                      
-                      
-                      
-                
-             
                     
- 
+  
             
             
      
@@ -74089,92 +74560,85 @@ end
 
                
                   
-
-        
-    
 
 
+        end
+    end
+end
+ 
+   
 
-always @(posedge clk_i  )
-begin
-    if (rst_i ==  1'b1)
-    begin
-        i_cyc_o <=  1'b0;
-        i_stb_o <=  1'b0;
-        i_adr_o <= { 32{1'b0}};
-        i_cti_o <=  3'b111;
-        i_lock_o <=  1'b0;
-        wb_data_f <= { 32{1'b0}};
-  
+       
+    
+          
+          
+          
+          
+          
+          
+ 
           
 
-
-    end
-    else
-    begin   
+    
+    
+       
+        
+           
         
-        if (i_cyc_o ==  1'b1)
-        begin
             
-            if((i_ack_i ==  1'b1) || (i_err_i ==  1'b1))
-            begin
+                  
+            
                 
-                i_cyc_o <=  1'b0;
-                i_stb_o <=  1'b0;
+                  
+                  
                 
-                wb_data_f <= i_dat_i;
-            end
-  
+                  
+            
+ 
                
             
                   
                   
             
 
-
-        end
-        else
-        begin
+        
+        
+        
             
-            if (   (stall_a ==  1'b0) 
-   
                    
-
+  
+                   
        
-               )
-            begin
+               
+            
                 
-       
+      
                   
 
-
-                i_adr_o <= {pc_a, 2'b00};
-                i_cyc_o <=  1'b1;
-                i_stb_o <=  1'b1;
-  
+                   
+                  
+                  
+ 
                   
 
-
-            end
-	    else
-	    begin
-	        if (   (stall_a ==  1'b0) 
-   
+            
+	    
+	    
+	               
+  
 		       
-
        
-	           )
-		begin
-  
+	           
+		
+ 
 		      
+
+		
+	    
+        
+    
 
 
-		end
-	    end
-        end
-    end
-end
- 
 
  
 
@@ -74420,7 +74884,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -74555,443 +75019,523 @@ endmodule
 
   
 
-                              
-                              
-                              
 
+  
 
-                          
-                  
-                 
-              
-             
-                    
-                        
-                        
+  
 
+  
 
-                  
-         
-          
-          
-          
-          
-          
-      
-      
-         
 
 
+  
 
+  
 
+  
 
   
+
+  
+
+  
+
+  
+
+  
+
+
+
+  
+
+  
+
+  
+
+  
+
+  
+
+  
+
+  
+
+  
+
+  
+
+  
+
+
+
+
+
+
+module lm32_jtag_medium_icache_debug (
     
-    
-    
-     
-    
-    
-    
+    clk_i,
+    rst_i,
+    jtag_clk, 
+    jtag_update,
+    jtag_reg_q,
+    jtag_reg_addr_q,
+  
+
+    csr,
+    csr_write_enable,
+    csr_write_data,
+    stall_x,
  
-    
-    
-    
-    
 
+  
+
+    jtag_read_data,
+    jtag_access_complete,
  
-    
-    
 
+  
+
+    exception_q_w,
  
-    
 
     
+  
+
+    jtx_csr_read_data,
+    jrx_csr_read_data,
  
-    
-    
 
+  
+
+    jtag_csr_write_enable,
+    jtag_csr_write_data,
+    jtag_csr,
+    jtag_read_enable,
+    jtag_write_enable,
+    jtag_write_data,
+    jtag_address,
  
-    
-    
-    
-    
-    
-    
-    
 
+  
+
+    jtag_break,
+    jtag_reset,
  
-    
-    
 
-    
-    
-    
+    jtag_reg_d,
+    jtag_reg_addr_d
+    );
 
 
 
 
 
-                                             
-                                             
+input clk_i;                                            
+input rst_i;                                            
 
-                                          
-                                       
-                        
-                              
+input jtag_clk;                                         
+input jtag_update;                                      
+input [ 7:0] jtag_reg_q;                      
+input [2:0] jtag_reg_addr_q;                            
 
+  
+
+input [ (5-1):0] csr;                              
+input csr_write_enable;                                 
+input [ (32-1):0] csr_write_data;                  
+input stall_x;                                          
  
-                                
-                                  
-                    
-                                           
 
+  
+
+input [ 7:0] jtag_read_data;                  
+input jtag_access_complete;                             
  
-                    
-                              
 
+  
+
+input exception_q_w;                                    
  
-                                     
 
 
 
 
 
        
- 
-                
-    
-                
-    
+  
 
+output [ (32-1):0] jtx_csr_read_data;              
+wire   [ (32-1):0] jtx_csr_read_data;
+output [ (32-1):0] jrx_csr_read_data;              
+wire   [ (32-1):0] jrx_csr_read_data;
  
-                            
-    
-              
-    
-                          
-    
-                                 
-    
-                                
-    
-                  
-            
-                     
-    
 
+  
+
+output jtag_csr_write_enable;                           
+reg    jtag_csr_write_enable;
+output [ (32-1):0] jtag_csr_write_data;            
+wire   [ (32-1):0] jtag_csr_write_data;
+output [ (5-1):0] jtag_csr;                        
+wire   [ (5-1):0] jtag_csr;
+output jtag_read_enable;                                
+reg    jtag_read_enable;
+output jtag_write_enable;                               
+reg    jtag_write_enable;
+output [ 7:0] jtag_write_data;                
+wire   [ 7:0] jtag_write_data;        
+output [ (32-1):0] jtag_address;                   
+wire   [ (32-1):0] jtag_address;
  
-                                       
-    
-                                       
-    
 
   
-     
-  
-    
-             
 
+output jtag_break;                                      
+reg    jtag_break;
+output jtag_reset;                                      
+reg    jtag_reset;
+ 
 
+output [ 7:0] jtag_reg_d;
+reg    [ 7:0] jtag_reg_d;
+output [2:0] jtag_reg_addr_d;
+wire   [2:0] jtag_reg_addr_d;
+             
 
 
-                           
-                         
-                       
-                     
 
 
+reg rx_update;                          
+reg rx_update_r;                        
+reg rx_update_r_r;                      
+reg rx_update_r_r_r;                    
 
-     
-  
 
-                  
-        
-                       
-        
-                       
 
+wire [ 7:0] rx_byte;   
+wire [2:0] rx_addr;
 
-               
- 
-         
-  
-  
   
-  
-                          
+                 
+reg [ 7:0] uart_tx_byte;      
+reg uart_tx_valid;                      
+reg [ 7:0] uart_rx_byte;      
+reg uart_rx_valid;                      
+ 
 
 
-         
+reg [ 3:0] command;             
+  
 
+reg [ 7:0] jtag_byte_0;       
+reg [ 7:0] jtag_byte_1;
+reg [ 7:0] jtag_byte_2;
+reg [ 7:0] jtag_byte_3;
+reg [ 7:0] jtag_byte_4;
+reg processing;                         
+ 
 
 
+reg [ 3:0] state;       
 
 
- 
-      
-   
-      
-   
 
-                 
 
-                  
-             
 
-   
+  
 
+assign jtag_csr_write_data = {jtag_byte_0, jtag_byte_1, jtag_byte_2, jtag_byte_3};
+assign jtag_csr = jtag_byte_4[ (5-1):0];
+assign jtag_address = {jtag_byte_0, jtag_byte_1, jtag_byte_2, jtag_byte_3};
+assign jtag_write_data = jtag_byte_4;
  
-   
-
-   
 
-
-                  
-     
-     
-         
                  
 
+  
+                 
+assign jtag_reg_addr_d[1:0] = {uart_rx_valid, uart_tx_valid};         
+ 
+   
 
 
+  
 
-   
+assign jtag_reg_addr_d[2] = processing;
+ 
    
 
 
 
-   
+  
+                 
+assign jtx_csr_read_data = {{ 32-9{1'b0}}, uart_tx_valid, 8'h00};
+assign jrx_csr_read_data = {{ 32-9{1'b0}}, uart_rx_valid, uart_rx_byte};
+ 
+         
+                 
 
-       
-    
-          
-          
-          
-          
-    
-    
-    
-          
-          
-          
-          
-    
 
 
 
-   
+assign rx_byte = jtag_reg_q;
+assign rx_addr = jtag_reg_addr_q;
 
-       
-    
-          
-          
-          
- 
-          
-          
-          
-          
 
- 
-          
-          
 
-                  
-          
-          
-          
-          
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        rx_update <= 1'b0;
+        rx_update_r <= 1'b0;
+        rx_update_r_r <= 1'b0;
+        rx_update_r_r_r <= 1'b0;
+    end
+    else
+    begin
+        rx_update <= jtag_update;
+        rx_update_r <= rx_update;
+        rx_update_r_r <= rx_update_r;
+        rx_update_r_r_r <= rx_update_r_r;
+    end
+end
 
-    
-    
-    
-                  
-               
-        
-             
-            
-            
-                
-                  
-                  
-            
-            
-            
-                
-                  
-            
-            
-        
 
- 
-        
-           
-        
-              
-              
-        
+always @(posedge clk_i  )
+begin
+    if (rst_i ==  1'b1)
+    begin
+        state <=  4'h0;
+        command <= 4'b0000;
+        jtag_reg_d <= 8'h00;
+  
 
-         
-        
-        
-            
-                 
-            
-                                  
-                 
- 
-                
-                
-                     
- 
-                    
-                          
-                    
-                    
-                              
-                          
-                    
-                    
-                          
-                    
-                    
-                              
-                          
-                    
-                    
-                          
-                    
-                    
-                    
-      
-                              
-                                   
+        processing <=  1'b0;
+        jtag_csr_write_enable <=  1'b0;
+        jtag_read_enable <=  1'b0;
+        jtag_write_enable <=  1'b0;
+ 
 
-                          
-                    
-                    
-                    
-      
-                              
-                                   
+  
 
-                          
-                    
-                                                   
-                
+        jtag_break <=  1'b0;
+        jtag_reset <=  1'b0;
+ 
 
-                  
-                
-                
-                      
-                      
-                                    
-                
+  
+                 
+        uart_tx_byte <= 8'h00;
+        uart_tx_valid <=  1'b0;
+        uart_rx_byte <= 8'h00;
+        uart_rx_valid <=  1'b0;
+ 
+
+    end
+    else
+    begin
+  
+                 
+        if ((csr_write_enable ==  1'b1) && (stall_x ==  1'b0))
+        begin
+            case (csr)
+             5'he:
+            begin
                 
-                      
-                      
+                uart_tx_byte <= csr_write_data[ 7:0];
+                uart_tx_valid <=  1'b1;
+            end
+             5'hf:
+            begin
                 
+                uart_rx_valid <=  1'b0;
+            end
+            endcase
+        end
+ 
+
+  
 
-                
-                    
-                                
-            
         
+        if (exception_q_w ==  1'b1)
+        begin
+            jtag_break <=  1'b0;
+            jtag_reset <=  1'b0;
+        end
  
-        
-        
-                 
-            
-                  
-                  
-            
-        
-        
-        
-                 
-            
-                  
-                  
-            
-        
-        
-        
-                 
-            
-                  
-                  
-            
-        
-        
-        
-                 
-            
-                  
-                   
-                      
-                 
-                      
-            
-        
-        
-        
-                 
-            
-                  
-                  
-            
-        
-        
-        
-             
-            
-            
-            
-                  
-                  
-                  
-            
-            
-            
-            
-                  
-                  
-                  
-            
-            
-            
-                  
-                  
-                  
-            
+
+        case (state)
+         4'h0:
+        begin
             
-        
-        
-        
-               
-                      
-                  
-                  
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                command <= rx_byte[7:4];                
+                case (rx_addr)
+  
+
+                 3'b000:
+                begin
+                    case (rx_byte[7:4])
+  
+
+                     4'b0001:
+                        state <=  4'h1;
+                     4'b0011:
+                    begin
+                        {jtag_byte_2, jtag_byte_3} <= {jtag_byte_2, jtag_byte_3} + 1'b1;
+                        state <=  4'h6;
+                    end
+                     4'b0010:
+                        state <=  4'h1;
+                     4'b0100:
+                    begin
+                        {jtag_byte_2, jtag_byte_3} <= {jtag_byte_2, jtag_byte_3} + 1'b1;
+                        state <= 5;
+                    end
+                     4'b0101:
+                        state <=  4'h1;
+ 
                     
-                  
-                  
-            
-            
-        
-        
-              
-              
-              
-            
+                     4'b0110:
+                    begin
+  
+     
+                        uart_rx_valid <=  1'b0;    
+                        uart_tx_valid <=  1'b0;         
+ 
 
-        
-    
+                        jtag_break <=  1'b1;
+                    end
+                     4'b0111:
+                    begin
+  
+     
+                        uart_rx_valid <=  1'b0;    
+                        uart_tx_valid <=  1'b0;         
+ 
+
+                        jtag_reset <=  1'b1;
+                    end
+                    endcase                               
+                end
+ 
+
+  
+                 
+                 3'b001:
+                begin
+                    uart_rx_byte <= rx_byte;
+                    uart_rx_valid <=  1'b1;
+                end                    
+                 3'b010:
+                begin
+                    jtag_reg_d <= uart_tx_byte;
+                    uart_tx_valid <=  1'b0;
+                end
+ 
 
+                default:
+                    ;
+                endcase                
+            end
+        end
   
 
+         4'h1:
+        begin
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                jtag_byte_0 <= rx_byte;
+                state <=  4'h2;
+            end
+        end
+         4'h2:
+        begin
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                jtag_byte_1 <= rx_byte;
+                state <=  4'h3;
+            end
+        end
+         4'h3:
+        begin
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                jtag_byte_2 <= rx_byte;
+                state <=  4'h4;
+            end
+        end
+         4'h4:
+        begin
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                jtag_byte_3 <= rx_byte;
+                if (command ==  4'b0001)
+                    state <=  4'h6;
+                else 
+                    state <=  4'h5;
+            end
+        end
+         4'h5:
+        begin
+            if ((~rx_update_r_r_r & rx_update_r_r) ==  1'b1)
+            begin
+                jtag_byte_4 <= rx_byte;
+                state <=  4'h6;
+            end
+        end
+         4'h6:
+        begin
+            case (command)
+             4'b0001,
+             4'b0011:
+            begin
+                jtag_read_enable <=  1'b1;
+                processing <=  1'b1;
+                state <=  4'h7;
+            end
+             4'b0010,
+             4'b0100:
+            begin
+                jtag_write_enable <=  1'b1;
+                processing <=  1'b1;
+                state <=  4'h7;
+            end
+             4'b0101:
+            begin
+                jtag_csr_write_enable <=  1'b1;
+                processing <=  1'b1;
+                state <=  4'h8;
+            end
+            endcase
+        end
+         4'h7:
+        begin
+            if (jtag_access_complete ==  1'b1)
+            begin          
+                jtag_read_enable <=  1'b0;
+                jtag_reg_d <= jtag_read_data;
+                jtag_write_enable <=  1'b0;  
+                processing <=  1'b0;
+                state <=  4'h0;
+            end
+        end    
+         4'h8:
+        begin
+            jtag_csr_write_enable <=  1'b0;
+            processing <=  1'b0;
+            state <=  4'h0;
+        end    
+ 
 
+        endcase
+    end
+end
+  
+endmodule
 
+ 
 
 
 
@@ -75209,7 +75753,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -75346,7 +75890,7 @@ endmodule
 
 
 
-module lm32_interrupt_medium (
+module lm32_interrupt_medium_icache_debug (
     
     clk_i, 
     rst_i,
@@ -75355,17 +75899,18 @@ module lm32_interrupt_medium (
     
     stall_x,
   
-    
-    
 
-
-    exception,
+    non_debug_exception,
+    debug_exception,
  
+    
+
 
     eret_q_x,
   
-    
 
+    bret_q_x,
+ 
 
     csr,
     csr_write_data,
@@ -75394,20 +75939,21 @@ input [interrupts-1:0] interrupt;
 input stall_x;                                  
 
   
-                       
-                           
-
 
-input exception;                                
+input non_debug_exception;                      
+input debug_exception;                          
  
+                                 
+
 
 input eret_q_x;                                 
   
-                                  
 
+input bret_q_x;                                 
+ 
 
 
-input [ (3-1):0] csr;                      
+input [ (5-1):0] csr;                      
 input [ (32-1):0] csr_write_data;          
 input csr_write_enable;                         
 
@@ -75428,14 +75974,18 @@ reg    [ (32-1):0] csr_read_data;
 wire [interrupts-1:0] asserted;                 
 
 wire [interrupts-1:0] interrupt_n_exception;
+wire [interrupts-1:0] ie_csr_read_data;
+wire [interrupts-1:0] ip_csr_read_data;
+wire [interrupts-1:0] im_csr_read_data;
 
 
 
 reg ie;                                         
 reg eie;                                        
   
-                                         
 
+reg bie;                                        
+ 
 
 reg [interrupts-1:0] ip;                        
 reg [interrupts-1:0] im;                        
@@ -75455,11 +76005,11 @@ assign asserted = ip | interrupt;
        
 assign ie_csr_read_data = {{ 32-3{1'b0}}, 
   
-                           
-
 
-                           1'b0,
+                           bie,
  
+                           
+
                              
                            eie, 
                            ie
@@ -75473,19 +76023,19 @@ generate
 always @(*)
 begin
     case (csr)
-     3'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     5'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
-                                    
 
-
-                                    1'b0,                                     
+                                    bie,
  
+                                                                         
+
 
                                     eie, 
                                     ie
                                    };
-     3'h2:  csr_read_data = ip;
-     3'h1:  csr_read_data = im;
+     5'h2:  csr_read_data = ip;
+     5'h1:  csr_read_data = im;
     default:       csr_read_data = { 32{1'bx}};
     endcase
 end
@@ -75496,18 +76046,18 @@ end
 always @(*)
 begin
     case (csr)
-     3'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     5'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
-                                     
-
 
-                                    1'b0,                                    
+                                    bie, 
  
+                                                                        
+
 
                                     eie, 
                                     ie
                                    };
-     3'h2:  csr_read_data = ip;
+     5'h2:  csr_read_data = ip;
     default:       csr_read_data = { 32{1'bx}};
       endcase
 end
@@ -75536,8 +76086,9 @@ always @(posedge clk_i  )
         ie                   <=  1'b0;
         eie                  <=  1'b0;
   
-                           
 
+        bie                  <=  1'b0;
+ 
 
         im                   <= {interrupts{1'b0}};
         ip                   <= {interrupts{1'b0}};
@@ -75549,13 +76100,21 @@ always @(posedge clk_i  )
         
         ip                   <= asserted;
   
-           
-        
+
+        if (non_debug_exception ==  1'b1)
+        begin
             
-                           
-                            
-        
+            eie              <= ie;
+            ie               <=  1'b0;
+        end
+        else if (debug_exception ==  1'b1)
+        begin
             
+            bie              <= ie;
+            ie               <=  1'b0;
+        end
+ 
+           
         
             
                            
@@ -75563,14 +76122,6 @@ always @(posedge clk_i  )
         
 
 
-        if (exception ==  1'b1)
-        begin
-            
-            eie              <= ie;
-            ie               <=  1'b0;
-        end
- 
-
         else if (stall_x ==  1'b0)
         begin
 
@@ -75588,26 +76139,28 @@ always @(posedge clk_i  )
                       
            
   
-                
-                
-                       
 
+            else if (bret_q_x ==  1'b1)
+                
+                ie      <= bie;
+ 
 
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  3'h0)
+                if (csr ==  5'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
   
-                      
 
+                    bie <= csr_write_data[2];
+ 
 
                 end
-                if (csr ==  3'h1)
+                if (csr ==  5'h1)
                     im  <= csr_write_data[interrupts-1:0];
-                if (csr ==  3'h2)
+                if (csr ==  5'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -75624,8 +76177,9 @@ always @(posedge clk_i  )
         ie              <=  1'b0;
         eie             <=  1'b0;
   
-                      
 
+        bie             <=  1'b0;
+ 
 
         ip              <= {interrupts{1'b0}};
        eie_delay        <= 0;
@@ -75635,13 +76189,21 @@ always @(posedge clk_i  )
         
         ip              <= asserted;
   
-           
-        
+
+        if (non_debug_exception ==  1'b1)
+        begin
             
-                      
-                       
-        
+            eie         <= ie;
+            ie          <=  1'b0;
+        end
+        else if (debug_exception ==  1'b1)
+        begin
             
+            bie         <= ie;
+            ie          <=  1'b0;
+        end
+ 
+           
         
             
                       
@@ -75649,14 +76211,6 @@ always @(posedge clk_i  )
         
 
 
-        if (exception ==  1'b1)
-        begin
-            
-            eie         <= ie;
-            ie          <=  1'b0;
-        end
- 
-
         else if (stall_x ==  1'b0)
           begin
 
@@ -75672,24 +76226,26 @@ always @(posedge clk_i  )
              end
            
   
-                
-                
-                       
 
+            else if (bret_q_x ==  1'b1)
+                
+                ie      <= bie;
+ 
 
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  3'h0)
+                if (csr ==  5'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
   
-                      
 
+                    bie <= csr_write_data[2];
+ 
 
                 end
-                if (csr ==  3'h2)
+                if (csr ==  5'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -76814,7 +77370,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -77485,7 +78041,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -77931,6 +78487,9 @@ reg load_x;
 reg load_m;
 wire load_q_x;
 wire store_q_x;
+wire q_m;
+wire load_q_m;
+wire store_q_m;
 wire store_d;                                   
 reg store_x;
 reg store_m;
@@ -77961,6 +78520,7 @@ wire [ 1:0] d_result_sel_1_d;
 wire x_result_sel_csr_d;                        
 reg x_result_sel_csr_x;
   
+ 
                     
  
 
@@ -78027,8 +78587,8 @@ wire [ (5-1):0] write_idx_d;
 reg [ (5-1):0] write_idx_x;            
 reg [ (5-1):0] write_idx_m;
 reg [ (5-1):0] write_idx_w;
-wire [ (3-1):0] csr_d;                     
-reg  [ (3-1):0] csr_x;                  
+wire [ (4 -1):0] csr_d;                     
+reg  [ (4 -1):0] csr_x;                  
 wire [ (3-1):0] condition_d;         
 reg [ (3-1):0] condition_x;          
   
@@ -78317,6 +78877,8 @@ reg [ (3-1):0] eid_x;
                                       
 
                                       
+ 
+ 
                                 
                                  
                           
@@ -79882,7 +80444,7 @@ assign cfg2 = {
  
 
 
-assign csr_d = read_idx_0_d[ (3-1):0];
+assign csr_d = read_idx_0_d[ (4 -1):0];
 
 
 always @(*)
@@ -79890,17 +80452,17 @@ begin
     case (csr_x)
   
 
-     3'h0,
-     3'h1,
-     3'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
+     4 'h0,
+     4 'h1,
+     4 'h2:   csr_read_data_x = interrupt_csr_read_data_x;  
  
 
   
          
 
 
-     3'h6:  csr_read_data_x = cfg;
-     3'h7:  csr_read_data_x = {eba, 8'h00};
+     4 'h6:  csr_read_data_x = cfg;
+     4 'h7:  csr_read_data_x = {eba, 8'h00};
   
         
 
@@ -79910,7 +80472,7 @@ begin
         
 
 
-     3'ha: csr_read_data_x = cfg2;
+     4 'ha: csr_read_data_x = cfg2;
       
     default:        csr_read_data_x = { 32{1'bx}};
     endcase
@@ -79927,7 +80489,7 @@ begin
         eba <= eba_reset[ (32-2)+2-1:8];
     else
     begin
-        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  3'h7) && (stall_x ==  1'b0))
+        if ((csr_write_enable_q_x ==  1'b1) && (csr_x ==  4 'h7) && (stall_x ==  1'b0))
             eba <= operand_1_x[ (32-2)+2-1:8];
   
                
@@ -80130,7 +80692,7 @@ begin
         m_bypass_enable_x <=  1'b0;
         write_enable_x <=  1'b0;
         write_idx_x <= { 5{1'b0}};
-        csr_x <= { 3{1'b0}};
+        csr_x <= { 4 {1'b0}};
         load_x <=  1'b0;
         store_x <=  1'b0;
         size_x <= { 2{1'b0}};
@@ -80861,7 +81423,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -82075,7 +82637,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -82557,6 +83119,86 @@ wire sign_extend_immediate;
 wire select_high_immediate;                     
 wire select_call_immediate;                     
 
+wire op_add;
+wire op_and;
+wire op_andhi;
+wire op_b;
+wire op_bi;
+wire op_be;
+wire op_bg;
+wire op_bge;
+wire op_bgeu;
+wire op_bgu;
+wire op_bne;
+wire op_call;
+wire op_calli;
+wire op_cmpe;
+wire op_cmpg;
+wire op_cmpge;
+wire op_cmpgeu;
+wire op_cmpgu;
+wire op_cmpne;
+  
+ 
+
+
+wire op_lb;
+wire op_lbu;
+wire op_lh;
+wire op_lhu;
+wire op_lw;
+  
+ 
+
+
+  
+ 
+
+
+wire op_nor;
+wire op_or;
+wire op_orhi;
+wire op_raise;
+wire op_rcsr;
+wire op_sb;
+  
+ 
+ 
+
+
+wire op_sh;
+  
+ 
+
+
+wire op_sr;
+wire op_sru;
+wire op_sub;
+wire op_sw;
+wire op_user;
+wire op_wcsr;
+wire op_xnor;
+wire op_xor;
+
+wire arith;
+wire logical;
+wire cmp;
+wire bra;
+wire call;
+  
+ 
+
+
+  
+
+wire shift;
+ 
+
+  
+ 
+
+
+
 
 
 
@@ -83141,7 +83783,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -83916,7 +84558,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -84743,7 +85385,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -85426,7 +86068,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -86698,7 +87340,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -87487,7 +88129,7 @@ endmodule
                    
                      
 
-                   
+                    
                      
 
 
@@ -87685,7 +88327,7 @@ input eret_q_x;
 
 
 
-input [ (3-1):0] csr;                      
+input [ (4 -1):0] csr;                      
 input [ (32-1):0] csr_write_data;          
 input csr_write_enable;                         
 
@@ -87706,6 +88348,9 @@ reg    [ (32-1):0] csr_read_data;
 wire [interrupts-1:0] asserted;                 
 
 wire [interrupts-1:0] interrupt_n_exception;
+wire [interrupts-1:0] ie_csr_read_data;
+wire [interrupts-1:0] ip_csr_read_data;
+wire [interrupts-1:0] im_csr_read_data;
 
 
 
@@ -87751,7 +88396,7 @@ generate
 always @(*)
 begin
     case (csr)
-     3'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     4 'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
                                     
 
@@ -87762,8 +88407,8 @@ begin
                                     eie, 
                                     ie
                                    };
-     3'h2:  csr_read_data = ip;
-     3'h1:  csr_read_data = im;
+     4 'h2:  csr_read_data = ip;
+     4 'h1:  csr_read_data = im;
     default:       csr_read_data = { 32{1'bx}};
     endcase
 end
@@ -87774,7 +88419,7 @@ end
 always @(*)
 begin
     case (csr)
-     3'h0:  csr_read_data = {{ 32-3{1'b0}}, 
+     4 'h0:  csr_read_data = {{ 32-3{1'b0}}, 
   
                                      
 
@@ -87785,7 +88430,7 @@ begin
                                     eie, 
                                     ie
                                    };
-     3'h2:  csr_read_data = ip;
+     4 'h2:  csr_read_data = ip;
     default:       csr_read_data = { 32{1'bx}};
       endcase
 end
@@ -87874,7 +88519,7 @@ always @(posedge clk_i  )
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  3'h0)
+                if (csr ==  4 'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
@@ -87883,9 +88528,9 @@ always @(posedge clk_i  )
 
 
                 end
-                if (csr ==  3'h1)
+                if (csr ==  4 'h1)
                     im  <= csr_write_data[interrupts-1:0];
-                if (csr ==  3'h2)
+                if (csr ==  4 'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
@@ -87958,7 +88603,7 @@ always @(posedge clk_i  )
             else if (csr_write_enable ==  1'b1)
             begin
                 
-                if (csr ==  3'h0)
+                if (csr ==  4 'h0)
                 begin
                     ie  <= csr_write_data[0];
                     eie <= csr_write_data[1];
@@ -87967,7 +88612,7 @@ always @(posedge clk_i  )
 
 
                 end
-                if (csr ==  3'h2)
+                if (csr ==  4 'h2)
                     ip  <= asserted & ~csr_write_data[interrupts-1:0];
             end
         end
diff --git a/modules/wishbone/wb_lm32/src/lm32_cpu.v b/modules/wishbone/wb_lm32/src/lm32_cpu.v
index 3810ecf1..e9276e58 100644
--- a/modules/wishbone/wb_lm32/src/lm32_cpu.v
+++ b/modules/wishbone/wb_lm32/src/lm32_cpu.v
@@ -341,6 +341,9 @@ reg load_x;
 reg load_m;
 wire load_q_x;
 wire store_q_x;
+wire q_m;
+wire load_q_m;
+wire store_q_m;
 wire store_d;                                   // Indicates a store instruction
 reg store_x;
 reg store_m;
@@ -371,6 +374,7 @@ wire [`LM32_D_RESULT_SEL_1_RNG] d_result_sel_1_d; // Which result should be sele
 wire x_result_sel_csr_d;                        // Select X stage result from CSRs
 reg x_result_sel_csr_x;
 `ifdef LM32_MC_ARITHMETIC_ENABLED
+wire q_d;
 wire x_result_sel_mc_arith_d;                   // Select X stage result from multi-cycle arithmetic unit
 reg x_result_sel_mc_arith_x;
 `endif
@@ -689,6 +693,8 @@ reg [`LM32_EID_RNG] eid_w;                      // Exception ID in W stage
 wire dc_ss;                                     // Is single-step enabled
 `endif
 wire dc_re;                                     // Remap all exceptions
+wire bp_match;
+wire wp_match;
 wire exception_x;                               // An exception occured in the X stage
 reg exception_m;                                // An instruction that caused an exception is in the M stage
 wire debug_exception_x;                         // Indicates if a debug exception has occured
diff --git a/modules/wishbone/wb_lm32/src/lm32_decoder.v b/modules/wishbone/wb_lm32/src/lm32_decoder.v
index d54375f0..57d50f70 100644
--- a/modules/wishbone/wb_lm32/src/lm32_decoder.v
+++ b/modules/wishbone/wb_lm32/src/lm32_decoder.v
@@ -308,6 +308,77 @@ wire sign_extend_immediate;                     // Whether the immediate should
 wire select_high_immediate;                     // Whether to select the high immediate  
 wire select_call_immediate;                     // Whether to select the call immediate 
 
+wire op_add;
+wire op_and;
+wire op_andhi;
+wire op_b;
+wire op_bi;
+wire op_be;
+wire op_bg;
+wire op_bge;
+wire op_bgeu;
+wire op_bgu;
+wire op_bne;
+wire op_call;
+wire op_calli;
+wire op_cmpe;
+wire op_cmpg;
+wire op_cmpge;
+wire op_cmpgeu;
+wire op_cmpgu;
+wire op_cmpne;
+`ifdef CFG_MC_DIVIDE_ENABLED
+wire op_divu;
+`endif
+wire op_lb;
+wire op_lbu;
+wire op_lh;
+wire op_lhu;
+wire op_lw;
+`ifdef CFG_MC_DIVIDE_ENABLED
+wire op_modu;
+`endif
+`ifdef LM32_MULTIPLY_ENABLED
+wire op_mul;
+`endif
+wire op_nor;
+wire op_or;
+wire op_orhi;
+wire op_raise;
+wire op_rcsr;
+wire op_sb;
+`ifdef CFG_SIGN_EXTEND_ENABLED
+wire op_sextb;
+wire op_sexth;
+`endif
+wire op_sh;
+`ifdef LM32_BARREL_SHIFT_ENABLED
+wire op_sl;
+`endif
+wire op_sr;
+wire op_sru;
+wire op_sub;
+wire op_sw;
+wire op_user;
+wire op_wcsr;
+wire op_xnor;
+wire op_xor;
+
+wire arith;
+wire logical;
+wire cmp;
+wire bra;
+wire call;
+`ifdef LM32_BARREL_SHIFT_ENABLED
+wire shift;
+`endif
+`ifdef LM32_NO_BARREL_SHIFT
+wire shift;
+`endif
+`ifdef CFG_SIGN_EXTEND_ENABLED
+wire sext;
+`endif
+
 /////////////////////////////////////////////////////
 // Functions
 /////////////////////////////////////////////////////
@@ -396,7 +467,7 @@ assign shift_right = op_sr | op_sru;
 `ifdef CFG_SIGN_EXTEND_ENABLED
 assign sext = op_sextb | op_sexth;
 `endif
-`ifdef LM32_MULTIPLY_ENABLED
+`ifdef CFG_MC_MULTIPLY_ENABLED
 assign multiply = op_mul;
 `endif
 `ifdef CFG_MC_DIVIDE_ENABLED
diff --git a/modules/wishbone/wb_lm32/src/lm32_include.v b/modules/wishbone/wb_lm32/src/lm32_include.v
index c5f92526..40723d2c 100644
--- a/modules/wishbone/wb_lm32/src/lm32_include.v
+++ b/modules/wishbone/wb_lm32/src/lm32_include.v
@@ -183,7 +183,7 @@
 `define LM32_CSR_WIDTH                  4
 `define LM32_CSR_RNG                    (`LM32_CSR_WIDTH-1):0
 `else
-`define LM32_CSR_WIDTH                  3
+`define LM32_CSR_WIDTH                  4 // CFG2 is "a"
 `define LM32_CSR_RNG                    (`LM32_CSR_WIDTH-1):0
 `endif
 `endif
diff --git a/modules/wishbone/wb_lm32/src/lm32_interrupt.v b/modules/wishbone/wb_lm32/src/lm32_interrupt.v
index c1b904bf..63352f3e 100644
--- a/modules/wishbone/wb_lm32/src/lm32_interrupt.v
+++ b/modules/wishbone/wb_lm32/src/lm32_interrupt.v
@@ -108,6 +108,9 @@ reg    [`LM32_WORD_RNG] csr_read_data;
 wire [interrupts-1:0] asserted;                 // Which interrupts are currently being asserted
 //p_ragma attribute asserted preserve_signal true
 wire [interrupts-1:0] interrupt_n_exception;
+wire [interrupts-1:0] ie_csr_read_data;
+wire [interrupts-1:0] ip_csr_read_data;
+wire [interrupts-1:0] im_csr_read_data;
 
 // Interrupt CSRs
 
-- 
GitLab