diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2014-06-06 19:35:10 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-06-06 19:35:10 -0400 |
commit | 57d326169e878a1a37b2bccd1cf81f6809ee67b9 (patch) | |
tree | 86ed74ae4dc2beaebce1c67b8459f1873b777d3a /arch/arm/mach-at91/sysirq_mask.c | |
parent | 7b215de3d0abbc4f6daf2efd19e8809af0564490 (diff) | |
parent | 0244756edc4b98c129e92c7061d9f383708cf786 (diff) |
Merge branch 'akpm' (patches from Andrew Morton) into next
Merge more updates from Andrew Morton:
- Most of the rest of MM.
This includes "mark remap_file_pages syscall as deprecated" but the
actual "replace remap_file_pages syscall with emulation" is held
back. I guess we'll need to work out when to pull the trigger on
that one.
- various minor cleanups to obscure filesystems
- the drivers/rtc queue
- hfsplus updates
- ufs, hpfs, fatfs, affs, reiserfs
- Documentation/
- signals
- procfs
- cpu hotplug
- lib/idr.c
- rapidio
- sysctl
- ipc updates
* emailed patches from Andrew Morton <akpm@linux-foundation.org>: (171 commits)
ufs: sb mutex merge + mutex_destroy
powerpc: update comments for generic idle conversion
cris: update comments for generic idle conversion
idle: remove cpu_idle() forward declarations
nbd: zero from and len fields in NBD_CMD_DISCONNECT.
mm: convert some level-less printks to pr_*
MAINTAINERS: adi-buildroot-devel is moderated
MAINTAINERS: add linux-api for review of API/ABI changes
mm/kmemleak-test.c: use pr_fmt for logging
fs/dlm/debug_fs.c: replace seq_printf by seq_puts
fs/dlm/lockspace.c: convert simple_str to kstr
fs/dlm/config.c: convert simple_str to kstr
mm: mark remap_file_pages() syscall as deprecated
mm: memcontrol: remove unnecessary memcg argument from soft limit functions
mm: memcontrol: clean up memcg zoneinfo lookup
mm/memblock.c: call kmemleak directly from memblock_(alloc|free)
mm/mempool.c: update the kmemleak stack trace for mempool allocations
lib/radix-tree.c: update the kmemleak stack trace for radix tree allocations
mm: introduce kmemleak_update_trace()
mm/kmemleak.c: use %u to print ->checksum
...
Diffstat (limited to 'arch/arm/mach-at91/sysirq_mask.c')
-rw-r--r-- | arch/arm/mach-at91/sysirq_mask.c | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/arch/arm/mach-at91/sysirq_mask.c b/arch/arm/mach-at91/sysirq_mask.c index 2ba694f9626b..f8bc3511a8c8 100644 --- a/arch/arm/mach-at91/sysirq_mask.c +++ b/arch/arm/mach-at91/sysirq_mask.c | |||
@@ -25,24 +25,28 @@ | |||
25 | 25 | ||
26 | #include "generic.h" | 26 | #include "generic.h" |
27 | 27 | ||
28 | #define AT91_RTC_IDR 0x24 /* Interrupt Disable Register */ | 28 | #define AT91_RTC_IDR 0x24 /* Interrupt Disable Register */ |
29 | #define AT91_RTC_IMR 0x28 /* Interrupt Mask Register */ | 29 | #define AT91_RTC_IMR 0x28 /* Interrupt Mask Register */ |
30 | #define AT91_RTC_IRQ_MASK 0x1f /* Available IRQs mask */ | ||
30 | 31 | ||
31 | void __init at91_sysirq_mask_rtc(u32 rtc_base) | 32 | void __init at91_sysirq_mask_rtc(u32 rtc_base) |
32 | { | 33 | { |
33 | void __iomem *base; | 34 | void __iomem *base; |
34 | u32 mask; | ||
35 | 35 | ||
36 | base = ioremap(rtc_base, 64); | 36 | base = ioremap(rtc_base, 64); |
37 | if (!base) | 37 | if (!base) |
38 | return; | 38 | return; |
39 | 39 | ||
40 | mask = readl_relaxed(base + AT91_RTC_IMR); | 40 | /* |
41 | if (mask) { | 41 | * sam9x5 SoCs have the following errata: |
42 | pr_info("AT91: Disabling rtc irq\n"); | 42 | * "RTC: Interrupt Mask Register cannot be used |
43 | writel_relaxed(mask, base + AT91_RTC_IDR); | 43 | * Interrupt Mask Register read always returns 0." |
44 | (void)readl_relaxed(base + AT91_RTC_IMR); /* flush */ | 44 | * |
45 | } | 45 | * Hence we're not relying on IMR values to disable |
46 | * interrupts. | ||
47 | */ | ||
48 | writel_relaxed(AT91_RTC_IRQ_MASK, base + AT91_RTC_IDR); | ||
49 | (void)readl_relaxed(base + AT91_RTC_IMR); /* flush */ | ||
46 | 50 | ||
47 | iounmap(base); | 51 | iounmap(base); |
48 | } | 52 | } |