|
24 | 24 | #define __raw_writeb __raw_writeb |
25 | 25 | static __always_inline void __raw_writeb(u8 val, volatile void __iomem *addr) |
26 | 26 | { |
27 | | - asm volatile("strb %w0, [%1]" : : "rZ" (val), "r" (addr)); |
| 27 | + volatile u8 __iomem *ptr = addr; |
| 28 | + asm volatile("strb %w0, %1" : : "rZ" (val), "Qo" (*ptr)); |
28 | 29 | } |
29 | 30 |
|
30 | 31 | #define __raw_writew __raw_writew |
31 | 32 | static __always_inline void __raw_writew(u16 val, volatile void __iomem *addr) |
32 | 33 | { |
33 | | - asm volatile("strh %w0, [%1]" : : "rZ" (val), "r" (addr)); |
| 34 | + volatile u16 __iomem *ptr = addr; |
| 35 | + asm volatile("strh %w0, %1" : : "rZ" (val), "Qo" (*ptr)); |
34 | 36 | } |
35 | 37 |
|
36 | 38 | #define __raw_writel __raw_writel |
37 | 39 | static __always_inline void __raw_writel(u32 val, volatile void __iomem *addr) |
38 | 40 | { |
39 | | - asm volatile("str %w0, [%1]" : : "rZ" (val), "r" (addr)); |
| 41 | + volatile u32 __iomem *ptr = addr; |
| 42 | + asm volatile("str %w0, %1" : : "rZ" (val), "Qo" (*ptr)); |
40 | 43 | } |
41 | 44 |
|
42 | 45 | #define __raw_writeq __raw_writeq |
43 | 46 | static __always_inline void __raw_writeq(u64 val, volatile void __iomem *addr) |
44 | 47 | { |
45 | | - asm volatile("str %x0, [%1]" : : "rZ" (val), "r" (addr)); |
| 48 | + volatile u64 __iomem *ptr = addr; |
| 49 | + asm volatile("str %x0, %1" : : "rZ" (val), "Qo" (*ptr)); |
46 | 50 | } |
47 | 51 |
|
48 | 52 | #define __raw_readb __raw_readb |
|
0 commit comments