ARC: [plat-eznps] Update the init sequence of aux regs per cpu.
authorLiav Rehana <liavr@mellanox.com>
Thu, 15 Jun 2017 08:43:58 +0000 (11:43 +0300)
committerVineet Gupta <vgupta@synopsys.com>
Mon, 28 Aug 2017 22:17:36 +0000 (15:17 -0700)
This commit add new configuration that enables us to distinguish
between building the kernel for platforms that have a different set
of auxiliary registers for each cpu and platforms that have a shared
set of auxiliary registers across every thread in each core.
On platforms that implement a different set of auxiliary registers
disabling this configuration insures that we initialize registers on
every cpu and not just for the first thread of the core.
Example for non shared registers is working with EZsim (non silicon)

Signed-off-by: Liav Rehana <liavr@mellanox.com>
Signed-off-by: Noam Camus <noamca@mellanox.com>
Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
arch/arc/plat-eznps/Kconfig
arch/arc/plat-eznps/entry.S

index b36afb1feabae86e9234f050fdceb050789bb3ae..e151e2067886ea52ec75d151210c9e71a4ec0a81 100644 (file)
@@ -43,3 +43,14 @@ config EZNPS_MEM_ERROR_ALIGN
          simulator platform for NPS, is handled as a Level 2 interrupt
          (just a stock ARC700) which is recoverable. This option makes
          simulator behave like hardware.
+
+config EZNPS_SHARED_AUX_REGS
+       bool "ARC-EZchip Shared Auxiliary Registers Per Core"
+       depends on ARC_PLAT_EZNPS
+       default y
+       help
+         On the real chip of the NPS, auxiliary registers are shared between
+         all the cpus of the core, whereas on simulator platform for NPS,
+         each cpu has a different set of auxiliary registers. Configuration
+         should be unset if auxiliary registers are not shared between the cpus
+         of the core, so there will be a need to initialize them per cpu.
index 328261c27cdac008543898c8f115da9c24f95e09..091c92c32ab65c24d8a8f79ca444e4b9d1408c19 100644 (file)
@@ -27,7 +27,7 @@
        .align 1024     ; HW requierment for restart first PC
 
 ENTRY(res_service)
-#ifdef CONFIG_EZNPS_MTM_EXT
+#if defined(CONFIG_EZNPS_MTM_EXT) && defined(CONFIG_EZNPS_SHARED_AUX_REGS)
        ; There is no work for HW thread id != 0
        lr      r3, [CTOP_AUX_THREAD_ID]
        cmp     r3, 0