From: Tomer Tayar <tta...@habana.ai>

The F/W dynamically allocates one of the PSOC scratchpad registers for
the engine cores, so they can raise events towards the F/W.
To allow the engine cores to access this register, this register must be
non-secured.

Signed-off-by: Tomer Tayar <tta...@habana.ai>
Reviewed-by: Oded Gabbay <ogab...@kernel.org>
Signed-off-by: Oded Gabbay <ogab...@kernel.org>
---
 .../accel/habanalabs/gaudi2/gaudi2_security.c | 20 ++++++++++++++++---
 1 file changed, 17 insertions(+), 3 deletions(-)

diff --git a/drivers/accel/habanalabs/gaudi2/gaudi2_security.c 
b/drivers/accel/habanalabs/gaudi2/gaudi2_security.c
index 2742b1f801eb..d08267e59303 100644
--- a/drivers/accel/habanalabs/gaudi2/gaudi2_security.c
+++ b/drivers/accel/habanalabs/gaudi2/gaudi2_security.c
@@ -2907,7 +2907,7 @@ static void gaudi2_init_lbw_range_registers_secure(struct 
hl_device *hdev)
         * - range 11: NIC11_CFG + *_DBG (not including TPC_DBG)
         *
         * If F/W security is not enabled:
-        * - ranges 12,13: PSOC_CFG (excluding PSOC_TIMESTAMP)
+        * - ranges 12,13: PSOC_CFG (excluding PSOC_TIMESTAMP, PSOC_EFUSE and 
PSOC_GLOBAL_CONF)
         */
        u64 lbw_range_min_short[] = {
                mmNIC0_TX_AXUSER_BASE,
@@ -2923,7 +2923,7 @@ static void gaudi2_init_lbw_range_registers_secure(struct 
hl_device *hdev)
                mmNIC10_TX_AXUSER_BASE,
                mmNIC11_TX_AXUSER_BASE,
                mmPSOC_I2C_M0_BASE,
-               mmPSOC_EFUSE_BASE
+               mmPSOC_GPIO0_BASE
        };
        u64 lbw_range_max_short[] = {
                mmNIC0_MAC_CH3_MAC_PCS_BASE + HL_BLOCK_SIZE,
@@ -3219,6 +3219,7 @@ static void gaudi2_init_range_registers(struct hl_device 
*hdev)
  */
 static int gaudi2_init_protection_bits(struct hl_device *hdev)
 {
+       u32 *user_regs_array = NULL, user_regs_array_size = 0, 
engine_core_intr_reg;
        struct asic_fixed_properties *prop = &hdev->asic_prop;
        u32 instance_offset;
        int rc = 0;
@@ -3389,11 +3390,24 @@ static int gaudi2_init_protection_bits(struct hl_device 
*hdev)
        /* PSOC.
         * Except for PSOC_GLOBAL_CONF, skip when security is enabled in F/W, 
because the blocks are
         * protected by privileged RR.
+        * For PSOC_GLOBAL_CONF, need to un-secure the scratchpad register 
which is used for engine
+        * cores to raise events towards F/W.
         */
+       engine_core_intr_reg = (u32) 
(hdev->asic_prop.engine_core_interrupt_reg_addr - CFG_BASE);
+       if (engine_core_intr_reg >= mmPSOC_GLOBAL_CONF_SCRATCHPAD_0 &&
+                       engine_core_intr_reg <= 
mmPSOC_GLOBAL_CONF_SCRATCHPAD_31) {
+               user_regs_array = &engine_core_intr_reg;
+               user_regs_array_size = 1;
+       } else {
+               dev_err(hdev->dev,
+                       "Engine cores register for interrupts (%#x) is not a 
PSOC scratchpad register\n",
+                       engine_core_intr_reg);
+       }
+
        rc |= hl_init_pb(hdev, HL_PB_SHARED, HL_PB_NA,
                        HL_PB_SINGLE_INSTANCE, HL_PB_NA,
                        gaudi2_pb_psoc_global_conf, 
ARRAY_SIZE(gaudi2_pb_psoc_global_conf),
-                       NULL, HL_PB_NA);
+                       user_regs_array, user_regs_array_size);
 
        if (!hdev->asic_prop.fw_security_enabled)
                rc |= hl_init_pb(hdev, HL_PB_SHARED, HL_PB_NA,
-- 
2.34.1

Reply via email to