diff options
| author | Chris Metcalf <cmetcalf@tilera.com> | 2013-04-09 12:33:07 -0400 |
|---|---|---|
| committer | Chris Metcalf <cmetcalf@tilera.com> | 2013-04-09 12:33:07 -0400 |
| commit | ffae3d0e3606b2e274c9ec1b969342d630b2ecae (patch) | |
| tree | 8dbe20e674f88fa4b19a960a36ba45edef15bc86 /arch/tile | |
| parent | 39e8202bb3b83a826e5825b1a07bbbf30ae9a140 (diff) | |
tile: comment assumption about __insn_mtspr for <asm/irqflags.h>
The arch_local_irq_save(), etc., routines are required to function
as compiler barriers. They do, but it's subtle and requires knowing
that the gcc builtin __insn_mtspr() is marked as a memory clobber.
Provide a comment explaining the assumption.
Signed-off-by: Chris Metcalf <cmetcalf@tilera.com>
Diffstat (limited to 'arch/tile')
| -rw-r--r-- | arch/tile/include/asm/irqflags.h | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/arch/tile/include/asm/irqflags.h b/arch/tile/include/asm/irqflags.h index 241c0bb60b12..c96f9bbb760d 100644 --- a/arch/tile/include/asm/irqflags.h +++ b/arch/tile/include/asm/irqflags.h | |||
| @@ -40,7 +40,15 @@ | |||
| 40 | #include <asm/percpu.h> | 40 | #include <asm/percpu.h> |
| 41 | #include <arch/spr_def.h> | 41 | #include <arch/spr_def.h> |
| 42 | 42 | ||
| 43 | /* Set and clear kernel interrupt masks. */ | 43 | /* |
| 44 | * Set and clear kernel interrupt masks. | ||
| 45 | * | ||
| 46 | * NOTE: __insn_mtspr() is a compiler builtin marked as a memory | ||
| 47 | * clobber. We rely on it being equivalent to a compiler barrier in | ||
| 48 | * this code since arch_local_irq_save() and friends must act as | ||
| 49 | * compiler barriers. This compiler semantic is baked into enough | ||
| 50 | * places that the compiler will maintain it going forward. | ||
| 51 | */ | ||
| 44 | #if CHIP_HAS_SPLIT_INTR_MASK() | 52 | #if CHIP_HAS_SPLIT_INTR_MASK() |
| 45 | #if INT_PERF_COUNT < 32 || INT_AUX_PERF_COUNT < 32 || INT_MEM_ERROR >= 32 | 53 | #if INT_PERF_COUNT < 32 || INT_AUX_PERF_COUNT < 32 || INT_MEM_ERROR >= 32 |
| 46 | # error Fix assumptions about which word various interrupts are in | 54 | # error Fix assumptions about which word various interrupts are in |
