From: Bo Shen Date: Mon, 15 Dec 2014 05:24:35 +0000 (+0800) Subject: ARM: atmel: sama5d4: add interrupt redirect function X-Git-Tag: v2015.04-rc2~33^2~16 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=569bbd3ceb1f3ca9d1f448178cd67f3eea4e01c4;p=oweals%2Fu-boot.git ARM: atmel: sama5d4: add interrupt redirect function Signed-off-by: Bo Shen [fix subject] Signed-off-by: Andreas Bießmann --- diff --git a/arch/arm/cpu/armv7/at91/sama5d4_devices.c b/arch/arm/cpu/armv7/at91/sama5d4_devices.c index 9c63e99899..ef39cb7e08 100644 --- a/arch/arm/cpu/armv7/at91/sama5d4_devices.c +++ b/arch/arm/cpu/armv7/at91/sama5d4_devices.c @@ -11,6 +11,7 @@ #include #include #include +#include #include char *get_cpu_name() @@ -78,4 +79,15 @@ void matrix_init(void) writel(ATMEL_MATRIX_WPMR_WPKEY | ATMEL_MATRIX_WPMR_WPEN, &h64mx->wpmr); writel(ATMEL_MATRIX_WPMR_WPKEY | ATMEL_MATRIX_WPMR_WPEN, &h32mx->wpmr); } + +void redirect_int_from_saic_to_aic(void) +{ + struct atmel_sfr *sfr = (struct atmel_sfr *)ATMEL_BASE_SFR; + u32 key32; + + if (!(readl(&sfr->aicredir) & ATMEL_SFR_AICREDIR_NSAIC)) { + key32 = readl(&sfr->sn1) ^ ATMEL_SFR_AICREDIR_KEY; + writel((key32 | ATMEL_SFR_AICREDIR_NSAIC), &sfr->aicredir); + } +} #endif