arch/arm: Remove CONFIG_ARCH_TRUSTZONE_BOTH related stuff
represent tee by CONFIG_ARCH_TRUSTZONE_SECURE instead Signed-off-by: Xiang Xiao <xiaoxiang@xiaomi.com> Signed-off-by: hujun5 <hujun5@xiaomi.com>
This commit is contained in:
parent
e8be4d0000
commit
7bb563dfe9
6 changed files with 24 additions and 291 deletions
|
@ -532,9 +532,6 @@ config ARCH_TRUSTZONE_SECURE
|
|||
config ARCH_TRUSTZONE_NONSECURE
|
||||
bool "All CPUs operate non-secure state"
|
||||
|
||||
config ARCH_TRUSTZONE_BOTH
|
||||
bool "CPUs operate in both secure and non-secure states"
|
||||
|
||||
endchoice # TrustZone Configuration
|
||||
|
||||
config ARCH_FPU
|
||||
|
|
|
@ -177,7 +177,7 @@ void arm_gic_initialize(void)
|
|||
|
||||
iccicr = getreg32(GIC_ICCICR);
|
||||
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE) || defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Clear secure state ICCICR bits to be configured below */
|
||||
|
||||
iccicr &= ~(GIC_ICCICRS_FIQEN | GIC_ICCICRS_ACKTCTL | GIC_ICCICRS_CBPR |
|
||||
|
@ -186,7 +186,7 @@ void arm_gic_initialize(void)
|
|||
GIC_ICCICRS_FIQBYPDISGRP0 | GIC_ICCICRS_IRQBYPDISGRP0 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP1 | GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_NONSECURE)
|
||||
#else
|
||||
/* Clear non-secure state ICCICR bits to be configured below */
|
||||
|
||||
iccicr &= ~(GIC_ICCICRU_EOIMODENS | GIC_ICCICRU_ENABLEGRP1 |
|
||||
|
@ -201,122 +201,38 @@ void arm_gic_initialize(void)
|
|||
* REVISIT: Do I need to do this?
|
||||
*/
|
||||
|
||||
/* iccicr |= GIC_ICCICRS_FIQEN; */
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Set FIQn=1 if secure interrupts are to signal using nfiq_c.
|
||||
*
|
||||
* NOTE: Only for processors that operate in secure state.
|
||||
* REVISIT: Do I need to do this?
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_FIQEN;
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Program the AckCtl bit to select the required interrupt acknowledge
|
||||
* behavior.
|
||||
*
|
||||
* NOTE: Only for processors that operate in both secure and non-secure
|
||||
* state.
|
||||
* REVISIT: This is here only for superstitious reasons. I don't think
|
||||
* I need this setting in this configuration.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_ACKTCTL;
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Program the AckCtl bit to select the required interrupt acknowledge
|
||||
* behavior.
|
||||
*
|
||||
* NOTE: Only for processors that operate in both secure and non-secure
|
||||
* state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_ACKTCTL;
|
||||
|
||||
/* Program the SBPR bit to select the required binary pointer behavior.
|
||||
*
|
||||
* NOTE: Only for processors that operate in both secure and non-secure
|
||||
* state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_CBPR;
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARMV7A_GIC_EOIMODE
|
||||
# if defined(CONFIG_ARCH_TRUSTZONE_SECURE) || defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
# if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Set EnableS=1 to enable CPU interface to signal secure interrupts.
|
||||
*
|
||||
* NOTE: Only for processors that operate in secure state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_EOIMODES;
|
||||
# endif
|
||||
|
||||
# if defined(CONFIG_ARCH_TRUSTZONE_NONSECURE)
|
||||
# else
|
||||
/* Set EnableNS=1 to enable the CPU to signal non-secure interrupts.
|
||||
*
|
||||
* NOTE: Only for processors that operate in non-secure state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRU_EOIMODENS;
|
||||
|
||||
# elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Set EnableNS=1 to enable the CPU to signal non-secure interrupts.
|
||||
*
|
||||
* NOTE: Only for processors that operate in non-secure state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_EOIMODENS;
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARCH_TRUSTZONE_BOTH
|
||||
/* If the processor operates in both security states and SBPR=0, then it
|
||||
* must switch to the other security state and repeat the programming of
|
||||
* the binary point register so that the binary point will be programmed
|
||||
* for interrupts in both security states.
|
||||
*/
|
||||
|
||||
# warning Missing logic
|
||||
#endif
|
||||
|
||||
#if !defined(CONFIG_ARCH_HAVE_TRUSTZONE)
|
||||
/* Enable the distributor by setting the Enable bit in the enable
|
||||
* register (no security extensions).
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICR_ENABLE;
|
||||
icddcr = GIC_ICDDCR_ENABLE;
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Enable the Group 0 interrupts, FIQEn and disable Group 0/1
|
||||
* bypass.
|
||||
*/
|
||||
|
||||
#if 0 /* REVISIT -- I don't know why this needs to be like this */
|
||||
iccicr |= (GIC_ICCICRS_ENABLEGRP0 | GIC_ICCICRS_FIQBYPDISGRP0 |
|
||||
GIC_ICCICRS_IRQBYPDISGRP0 | GIC_ICCICRS_FIQBYPDISGRP1 |
|
||||
GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
#else
|
||||
iccicr |= (GIC_ICCICRS_ENABLEGRP0 | GIC_ICCICRS_ENABLEGRP1 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP0 | GIC_ICCICRS_IRQBYPDISGRP0 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP1 | GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
#endif
|
||||
icddcr = GIC_ICDDCR_ENABLEGRP0;
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Enable the Group 0/1 interrupts, FIQEn and disable Group 0/1
|
||||
* bypass.
|
||||
*/
|
||||
|
||||
iccicr |= (GIC_ICCICRS_ENABLEGRP0 | GIC_ICCICRS_ENABLEGRP1 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP0 | GIC_ICCICRS_IRQBYPDISGRP0 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP1 | GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
icddcr = (GIC_ICDDCR_ENABLEGRP0 | GIC_ICDDCR_ENABLEGRP1);
|
||||
|
||||
#else /* defined(CONFIG_ARCH_TRUSTZONE_NONSECURE) */
|
||||
#else
|
||||
/* Enable the Group 1 interrupts and disable Group 1 bypass. */
|
||||
|
||||
iccicr |= (GIC_ICCICRU_ENABLEGRP1 | GIC_ICCICRU_FIQBYPDISGRP1 |
|
||||
|
@ -329,16 +245,6 @@ void arm_gic_initialize(void)
|
|||
|
||||
putreg32(iccicr, GIC_ICCICR);
|
||||
|
||||
#ifdef CONFIG_ARCH_TRUSTZONE_BOTH
|
||||
/* A processor in the secure state must then switch to the non-secure
|
||||
* a repeat setting of the enable bit in the enable register. This
|
||||
* enables distributor to respond to interrupt in both security states.
|
||||
* REVISIT: Initial implementation operates only in secure state.
|
||||
*/
|
||||
|
||||
# warning Missing logic
|
||||
#endif
|
||||
|
||||
/* Write the ICDDCR value to enable the forwarding of interrupt by the
|
||||
* distributor.
|
||||
*/
|
||||
|
@ -380,7 +286,7 @@ uint32_t *arm_decodeirq(uint32_t *regs)
|
|||
* interrupt.
|
||||
*/
|
||||
|
||||
DEBUGASSERT(irq < NR_IRQS || irq == 1023);
|
||||
DEBUGASSERT(irq < NR_IRQS || irq >= 1022);
|
||||
if (irq < NR_IRQS)
|
||||
{
|
||||
/* Dispatch the interrupt */
|
||||
|
|
|
@ -278,7 +278,7 @@ struct oneshot_lowerhalf_s *arm_timer_initialize(unsigned int freq)
|
|||
ctrl |= ARM_TIMER_CTRL_ENABLE | ARM_TIMER_CTRL_INT_MASK;
|
||||
arm_timer_set_ctrl(ctrl);
|
||||
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE) || defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
irq_attach(GIC_IRQ_STM, arm_timer_interrupt, lower);
|
||||
up_enable_irq(GIC_IRQ_STM);
|
||||
#else
|
||||
|
|
|
@ -177,7 +177,7 @@ void arm_gic_initialize(void)
|
|||
|
||||
iccicr = getreg32(GIC_ICCICR);
|
||||
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE) || defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Clear secure state ICCICR bits to be configured below */
|
||||
|
||||
iccicr &= ~(GIC_ICCICRS_FIQEN | GIC_ICCICRS_ACKTCTL | GIC_ICCICRS_CBPR |
|
||||
|
@ -186,7 +186,7 @@ void arm_gic_initialize(void)
|
|||
GIC_ICCICRS_FIQBYPDISGRP0 | GIC_ICCICRS_IRQBYPDISGRP0 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP1 | GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_NONSECURE)
|
||||
#else
|
||||
/* Clear non-secure state ICCICR bits to be configured below */
|
||||
|
||||
iccicr &= ~(GIC_ICCICRU_EOIMODENS | GIC_ICCICRU_ENABLEGRP1 |
|
||||
|
@ -201,31 +201,8 @@ void arm_gic_initialize(void)
|
|||
* REVISIT: Do I need to do this?
|
||||
*/
|
||||
|
||||
/* iccicr |= GIC_ICCICRS_FIQEN; */
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Set FIQn=1 if secure interrupts are to signal using nfiq_c.
|
||||
*
|
||||
* NOTE: Only for processors that operate in secure state.
|
||||
* REVISIT: Do I need to do this?
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_FIQEN;
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Program the AckCtl bit to select the required interrupt acknowledge
|
||||
* behavior.
|
||||
*
|
||||
* NOTE: Only for processors that operate in both secure and non-secure
|
||||
* state.
|
||||
* REVISIT: This is here only for superstitious reasons. I don't think
|
||||
* I need this setting in this configuration.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_ACKTCTL;
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Program the AckCtl bit to select the required interrupt acknowledge
|
||||
* behavior.
|
||||
*
|
||||
|
@ -234,89 +211,37 @@ void arm_gic_initialize(void)
|
|||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_ACKTCTL;
|
||||
|
||||
/* Program the SBPR bit to select the required binary pointer behavior.
|
||||
*
|
||||
* NOTE: Only for processors that operate in both secure and non-secure
|
||||
* state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_CBPR;
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARMV7R_GIC_EOIMODE
|
||||
# if defined(CONFIG_ARCH_TRUSTZONE_SECURE) || defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
# if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Set EnableS=1 to enable CPU interface to signal secure interrupts.
|
||||
*
|
||||
* NOTE: Only for processors that operate in secure state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_EOIMODES;
|
||||
# endif
|
||||
|
||||
# if defined(CONFIG_ARCH_TRUSTZONE_NONSECURE)
|
||||
# else
|
||||
/* Set EnableNS=1 to enable the CPU to signal non-secure interrupts.
|
||||
*
|
||||
* NOTE: Only for processors that operate in non-secure state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRU_EOIMODENS;
|
||||
|
||||
# elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Set EnableNS=1 to enable the CPU to signal non-secure interrupts.
|
||||
*
|
||||
* NOTE: Only for processors that operate in non-secure state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_EOIMODENS;
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARCH_TRUSTZONE_BOTH
|
||||
/* If the processor operates in both security states and SBPR=0, then it
|
||||
* must switch to the other security state and repeat the programming of
|
||||
* the binary point register so that the binary point will be programmed
|
||||
* for interrupts in both security states.
|
||||
*/
|
||||
|
||||
# warning Missing logic
|
||||
#endif
|
||||
|
||||
#if !defined(CONFIG_ARCH_HAVE_TRUSTZONE)
|
||||
/* Enable the distributor by setting the Enable bit in the enable
|
||||
* register (no security extensions).
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICR_ENABLE;
|
||||
icddcr = GIC_ICDDCR_ENABLE;
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Enable the Group 0 interrupts, FIQEn and disable Group 0/1
|
||||
* bypass.
|
||||
*/
|
||||
|
||||
#if 0 /* REVISIT -- I don't know why this needs to be like this */
|
||||
iccicr |= (GIC_ICCICRS_ENABLEGRP0 | GIC_ICCICRS_FIQBYPDISGRP0 |
|
||||
GIC_ICCICRS_IRQBYPDISGRP0 | GIC_ICCICRS_FIQBYPDISGRP1 |
|
||||
GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
#else
|
||||
iccicr |= (GIC_ICCICRS_ENABLEGRP0 | GIC_ICCICRS_ENABLEGRP1 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP0 | GIC_ICCICRS_IRQBYPDISGRP0 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP1 | GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
#endif
|
||||
icddcr = GIC_ICDDCR_ENABLEGRP0;
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Enable the Group 0/1 interrupts, FIQEn and disable Group 0/1
|
||||
* bypass.
|
||||
*/
|
||||
|
||||
iccicr |= (GIC_ICCICRS_ENABLEGRP0 | GIC_ICCICRS_ENABLEGRP1 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP0 | GIC_ICCICRS_IRQBYPDISGRP0 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP1 | GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
icddcr = (GIC_ICDDCR_ENABLEGRP0 | GIC_ICDDCR_ENABLEGRP1);
|
||||
|
||||
#else /* defined(CONFIG_ARCH_TRUSTZONE_NONSECURE) */
|
||||
#else
|
||||
/* Enable the Group 1 interrupts and disable Group 1 bypass. */
|
||||
|
||||
iccicr |= (GIC_ICCICRU_ENABLEGRP1 | GIC_ICCICRU_FIQBYPDISGRP1 |
|
||||
|
@ -329,16 +254,6 @@ void arm_gic_initialize(void)
|
|||
|
||||
putreg32(iccicr, GIC_ICCICR);
|
||||
|
||||
#ifdef CONFIG_ARCH_TRUSTZONE_BOTH
|
||||
/* A processor in the secure state must then switch to the non-secure
|
||||
* a repeat setting of the enable bit in the enable register. This
|
||||
* enables distributor to respond to interrupt in both security states.
|
||||
* REVISIT: Initial implementation operates only in secure state.
|
||||
*/
|
||||
|
||||
# warning Missing logic
|
||||
#endif
|
||||
|
||||
/* Write the ICDDCR value to enable the forwarding of interrupt by the
|
||||
* distributor.
|
||||
*/
|
||||
|
@ -380,7 +295,7 @@ uint32_t *arm_decodeirq(uint32_t *regs)
|
|||
* interrupt.
|
||||
*/
|
||||
|
||||
DEBUGASSERT(irq < NR_IRQS || irq == 1023);
|
||||
DEBUGASSERT(irq < NR_IRQS || irq >= 1022);
|
||||
if (irq < NR_IRQS)
|
||||
{
|
||||
/* Dispatch the interrupt */
|
||||
|
|
|
@ -278,7 +278,7 @@ struct oneshot_lowerhalf_s *arm_timer_initialize(unsigned int freq)
|
|||
ctrl |= ARM_TIMER_CTRL_ENABLE | ARM_TIMER_CTRL_INT_MASK;
|
||||
arm_timer_set_ctrl(ctrl);
|
||||
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE) || defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
irq_attach(GIC_IRQ_STM, arm_timer_interrupt, lower);
|
||||
up_enable_irq(GIC_IRQ_STM);
|
||||
#else
|
||||
|
|
|
@ -899,7 +899,7 @@ static void arm_gic_initialize(void)
|
|||
|
||||
iccicr = getreg32(GIC_ICCICR);
|
||||
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE) || defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Clear secure state ICCICR bits to be configured below */
|
||||
|
||||
iccicr &= ~(GIC_ICCICRS_FIQEN | GIC_ICCICRS_ACKTCTL | GIC_ICCICRS_CBPR |
|
||||
|
@ -908,7 +908,7 @@ static void arm_gic_initialize(void)
|
|||
GIC_ICCICRS_FIQBYPDISGRP0 | GIC_ICCICRS_IRQBYPDISGRP0 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP1 | GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_NONSECURE)
|
||||
#else
|
||||
/* Clear non-secure state ICCICR bits to be configured below */
|
||||
|
||||
iccicr &= ~(GIC_ICCICRU_EOIMODENS | GIC_ICCICRU_ENABLEGRP1 |
|
||||
|
@ -923,31 +923,8 @@ static void arm_gic_initialize(void)
|
|||
* REVISIT: Do I need to do this?
|
||||
*/
|
||||
|
||||
/* iccicr |= GIC_ICCICRS_FIQEN; */
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Set FIQn=1 if secure interrupts are to signal using nfiq_c.
|
||||
*
|
||||
* NOTE: Only for processors that operate in secure state.
|
||||
* REVISIT: Do I need to do this?
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_FIQEN;
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Program the AckCtl bit to select the required interrupt acknowledge
|
||||
* behavior.
|
||||
*
|
||||
* NOTE: Only for processors that operate in both secure and non-secure
|
||||
* state.
|
||||
* REVISIT: This is here only for superstitious reasons. I don't think
|
||||
* I need this setting in this configuration.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_ACKTCTL;
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Program the AckCtl bit to select the required interrupt acknowledge
|
||||
* behavior.
|
||||
*
|
||||
|
@ -956,89 +933,37 @@ static void arm_gic_initialize(void)
|
|||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_ACKTCTL;
|
||||
|
||||
/* Program the SBPR bit to select the required binary pointer behavior.
|
||||
*
|
||||
* NOTE: Only for processors that operate in both secure and non-secure
|
||||
* state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_CBPR;
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARM_GIC_EOIMODE
|
||||
# if defined(CONFIG_ARCH_TRUSTZONE_SECURE) || defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
# if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Set EnableS=1 to enable CPU interface to signal secure interrupts.
|
||||
*
|
||||
* NOTE: Only for processors that operate in secure state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_EOIMODES;
|
||||
# endif
|
||||
|
||||
# if defined(CONFIG_ARCH_TRUSTZONE_NONSECURE)
|
||||
# else
|
||||
/* Set EnableNS=1 to enable the CPU to signal non-secure interrupts.
|
||||
*
|
||||
* NOTE: Only for processors that operate in non-secure state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRU_EOIMODENS;
|
||||
|
||||
# elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Set EnableNS=1 to enable the CPU to signal non-secure interrupts.
|
||||
*
|
||||
* NOTE: Only for processors that operate in non-secure state.
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICRS_EOIMODENS;
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARCH_TRUSTZONE_BOTH
|
||||
/* If the processor operates in both security states and SBPR=0, then it
|
||||
* must switch to the other security state and repeat the programming of
|
||||
* the binary point register so that the binary point will be programmed
|
||||
* for interrupts in both security states.
|
||||
*/
|
||||
|
||||
# warning Missing logic
|
||||
#endif
|
||||
|
||||
#if !defined(CONFIG_ARCH_HAVE_TRUSTZONE)
|
||||
/* Enable the distributor by setting the Enable bit in the enable
|
||||
* register (no security extensions).
|
||||
*/
|
||||
|
||||
iccicr |= GIC_ICCICR_ENABLE;
|
||||
icddcr = GIC_ICDDCR_ENABLE;
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
#if defined(CONFIG_ARCH_TRUSTZONE_SECURE)
|
||||
/* Enable the Group 0 interrupts, FIQEn and disable Group 0/1
|
||||
* bypass.
|
||||
*/
|
||||
|
||||
#if 0 /* REVISIT -- I don't know why this needs to be like this */
|
||||
iccicr |= (GIC_ICCICRS_ENABLEGRP0 | GIC_ICCICRS_FIQBYPDISGRP0 |
|
||||
GIC_ICCICRS_IRQBYPDISGRP0 | GIC_ICCICRS_FIQBYPDISGRP1 |
|
||||
GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
#else
|
||||
iccicr |= (GIC_ICCICRS_ENABLEGRP0 | GIC_ICCICRS_ENABLEGRP1 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP0 | GIC_ICCICRS_IRQBYPDISGRP0 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP1 | GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
#endif
|
||||
icddcr = GIC_ICDDCR_ENABLEGRP0;
|
||||
|
||||
#elif defined(CONFIG_ARCH_TRUSTZONE_BOTH)
|
||||
/* Enable the Group 0/1 interrupts, FIQEn and disable Group 0/1
|
||||
* bypass.
|
||||
*/
|
||||
|
||||
iccicr |= (GIC_ICCICRS_ENABLEGRP0 | GIC_ICCICRS_ENABLEGRP1 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP0 | GIC_ICCICRS_IRQBYPDISGRP0 |
|
||||
GIC_ICCICRS_FIQBYPDISGRP1 | GIC_ICCICRS_IRQBYPDISGRP1);
|
||||
icddcr = (GIC_ICDDCR_ENABLEGRP0 | GIC_ICDDCR_ENABLEGRP1);
|
||||
|
||||
#else /* defined(CONFIG_ARCH_TRUSTZONE_NONSECURE) */
|
||||
#else
|
||||
/* Enable the Group 1 interrupts and disable Group 1 bypass. */
|
||||
|
||||
iccicr |= (GIC_ICCICRU_ENABLEGRP1 | GIC_ICCICRU_FIQBYPDISGRP1 |
|
||||
|
@ -1051,16 +976,6 @@ static void arm_gic_initialize(void)
|
|||
|
||||
putreg32(iccicr, GIC_ICCICR);
|
||||
|
||||
#ifdef CONFIG_ARCH_TRUSTZONE_BOTH
|
||||
/* A processor in the secure state must then switch to the non-secure
|
||||
* a repeat setting of the enable bit in the enable register. This
|
||||
* enables distributor to respond to interrupt in both security states.
|
||||
* REVISIT: Initial implementation operates only in secure state.
|
||||
*/
|
||||
|
||||
# warning Missing logic
|
||||
#endif
|
||||
|
||||
/* Write the ICDDCR value to enable the forwarding of interrupt by the
|
||||
* distributor.
|
||||
*/
|
||||
|
@ -1105,7 +1020,7 @@ uint64_t *arm64_decodeirq(uint64_t * regs)
|
|||
* interrupt.
|
||||
*/
|
||||
|
||||
DEBUGASSERT(irq < NR_IRQS || irq == 1023);
|
||||
DEBUGASSERT(irq < NR_IRQS || irq >= 1022);
|
||||
if (irq < NR_IRQS)
|
||||
{
|
||||
/* Dispatch the interrupt */
|
||||
|
|
Loading…
Reference in a new issue