[lc_ctrl] Fix for unconnected WE checker on tap side

This integrity error remained unconnected because initially the reg_top
only checked for bus integrity errors (and the TAP side does not support
that). However, since we now also have WE checkers inside the reg_top,
this signal should be connected for the TAP side also.

Signed-off-by: Michael Schaffner <msf@google.com>
diff --git a/hw/ip/lc_ctrl/rtl/lc_ctrl.sv b/hw/ip/lc_ctrl/rtl/lc_ctrl.sv
index 35fa29a..a17273a 100644
--- a/hw/ip/lc_ctrl/rtl/lc_ctrl.sv
+++ b/hw/ip/lc_ctrl/rtl/lc_ctrl.sv
@@ -129,17 +129,17 @@
   lc_ctrl_reg_pkg::lc_ctrl_hw2reg_t hw2reg;
 
   // SEC_CM: TRANSITION.CONFIG.REGWEN, STATE.CONFIG.SPARSE
-  logic fatal_bus_integ_error_q, fatal_bus_integ_error_d;
+  logic fatal_bus_integ_error_q, fatal_bus_integ_error_csr_d, fatal_bus_integ_error_tap_d;
   lc_ctrl_reg_top u_reg (
     .clk_i,
     .rst_ni,
     .tl_i,
     .tl_o,
-    .reg2hw    ( reg2hw                  ),
-    .hw2reg    ( hw2reg                  ),
+    .reg2hw    ( reg2hw                      ),
+    .hw2reg    ( hw2reg                      ),
     // SEC_CM: BUS.INTEGRITY
-    .intg_err_o( fatal_bus_integ_error_d ),
-    .devmode_i ( 1'b1                    )
+    .intg_err_o( fatal_bus_integ_error_csr_d ),
+    .devmode_i ( 1'b1                        )
   );
 
   ////////////////////
@@ -154,13 +154,15 @@
   lc_ctrl_reg_top u_reg_tap (
     .clk_i,
     .rst_ni,
-    .tl_i      ( tap_tl_h2d ),
-    .tl_o      ( tap_tl_d2h ),
-    .reg2hw    ( tap_reg2hw ),
-    .hw2reg    ( tap_hw2reg ),
-    // The JTAG TAP does not support bus integrity.
-    .intg_err_o(            ),
-    .devmode_i ( 1'b1       )
+    .tl_i      ( tap_tl_h2d                  ),
+    .tl_o      ( tap_tl_d2h                  ),
+    .reg2hw    ( tap_reg2hw                  ),
+    .hw2reg    ( tap_hw2reg                  ),
+    // SEC_CM: BUS.INTEGRITY
+    // While the TAP does not have bus integrity, it does have a WE checker
+    // that feeds into intg_err_o - hence this is is wired up to the fatal_bus_integ_error.
+    .intg_err_o( fatal_bus_integ_error_tap_d ),
+    .devmode_i ( 1'b1                        )
   );
 
 
@@ -448,7 +450,9 @@
       fatal_prog_error_q        <= otp_prog_error_d        | fatal_prog_error_q;
       fatal_state_error_q       <= state_invalid_error_d   | fatal_state_error_q;
       otp_part_error_q          <= otp_lc_data_i.error     | otp_part_error_q;
-      fatal_bus_integ_error_q   <= fatal_bus_integ_error_d | fatal_bus_integ_error_q;
+      fatal_bus_integ_error_q   <= fatal_bus_integ_error_csr_d |
+                                   fatal_bus_integ_error_tap_d |
+                                   fatal_bus_integ_error_q;
       // Other regs, gated by mutex further below.
       sw_claim_transition_if_q  <= sw_claim_transition_if_d;
       tap_claim_transition_if_q <= tap_claim_transition_if_d;