diff options
| -rw-r--r-- | arch/arc/include/asm/irqflags.h | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/arch/arc/include/asm/irqflags.h b/arch/arc/include/asm/irqflags.h index ccd84806b62f..eac071668201 100644 --- a/arch/arc/include/asm/irqflags.h +++ b/arch/arc/include/asm/irqflags.h | |||
| @@ -39,7 +39,7 @@ static inline long arch_local_irq_save(void) | |||
| 39 | " flag.nz %0 \n" | 39 | " flag.nz %0 \n" |
| 40 | : "=r"(temp), "=r"(flags) | 40 | : "=r"(temp), "=r"(flags) |
| 41 | : "n"((STATUS_E1_MASK | STATUS_E2_MASK)) | 41 | : "n"((STATUS_E1_MASK | STATUS_E2_MASK)) |
| 42 | : "cc"); | 42 | : "memory", "cc"); |
| 43 | 43 | ||
| 44 | return flags; | 44 | return flags; |
| 45 | } | 45 | } |
| @@ -53,7 +53,8 @@ static inline void arch_local_irq_restore(unsigned long flags) | |||
| 53 | __asm__ __volatile__( | 53 | __asm__ __volatile__( |
| 54 | " flag %0 \n" | 54 | " flag %0 \n" |
| 55 | : | 55 | : |
| 56 | : "r"(flags)); | 56 | : "r"(flags) |
| 57 | : "memory"); | ||
| 57 | } | 58 | } |
| 58 | 59 | ||
| 59 | /* | 60 | /* |
| @@ -73,7 +74,8 @@ static inline void arch_local_irq_disable(void) | |||
| 73 | " and %0, %0, %1 \n" | 74 | " and %0, %0, %1 \n" |
| 74 | " flag %0 \n" | 75 | " flag %0 \n" |
| 75 | : "=&r"(temp) | 76 | : "=&r"(temp) |
| 76 | : "n"(~(STATUS_E1_MASK | STATUS_E2_MASK))); | 77 | : "n"(~(STATUS_E1_MASK | STATUS_E2_MASK)) |
| 78 | : "memory"); | ||
| 77 | } | 79 | } |
| 78 | 80 | ||
| 79 | /* | 81 | /* |
| @@ -85,7 +87,9 @@ static inline long arch_local_save_flags(void) | |||
| 85 | 87 | ||
| 86 | __asm__ __volatile__( | 88 | __asm__ __volatile__( |
| 87 | " lr %0, [status32] \n" | 89 | " lr %0, [status32] \n" |
| 88 | : "=&r"(temp)); | 90 | : "=&r"(temp) |
| 91 | : | ||
| 92 | : "memory"); | ||
| 89 | 93 | ||
| 90 | return temp; | 94 | return temp; |
| 91 | } | 95 | } |
