mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-12 08:09:56 +00:00
NET: am79c961: ensure asm() statements are marked volatile
Without this the compiler can (and does) optimize register reads away from within loops, and other such optimizations. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
b4c8cc88c1
commit
d814dee0e1
@ -50,7 +50,7 @@ static const char version[] =
|
|||||||
#ifdef __arm__
|
#ifdef __arm__
|
||||||
static void write_rreg(u_long base, u_int reg, u_int val)
|
static void write_rreg(u_long base, u_int reg, u_int val)
|
||||||
{
|
{
|
||||||
__asm__(
|
asm volatile(
|
||||||
"str%?h %1, [%2] @ NET_RAP\n\t"
|
"str%?h %1, [%2] @ NET_RAP\n\t"
|
||||||
"str%?h %0, [%2, #-4] @ NET_RDP"
|
"str%?h %0, [%2, #-4] @ NET_RDP"
|
||||||
:
|
:
|
||||||
@ -60,7 +60,7 @@ static void write_rreg(u_long base, u_int reg, u_int val)
|
|||||||
static inline unsigned short read_rreg(u_long base_addr, u_int reg)
|
static inline unsigned short read_rreg(u_long base_addr, u_int reg)
|
||||||
{
|
{
|
||||||
unsigned short v;
|
unsigned short v;
|
||||||
__asm__(
|
asm volatile(
|
||||||
"str%?h %1, [%2] @ NET_RAP\n\t"
|
"str%?h %1, [%2] @ NET_RAP\n\t"
|
||||||
"ldr%?h %0, [%2, #-4] @ NET_RDP"
|
"ldr%?h %0, [%2, #-4] @ NET_RDP"
|
||||||
: "=r" (v)
|
: "=r" (v)
|
||||||
@ -70,7 +70,7 @@ static inline unsigned short read_rreg(u_long base_addr, u_int reg)
|
|||||||
|
|
||||||
static inline void write_ireg(u_long base, u_int reg, u_int val)
|
static inline void write_ireg(u_long base, u_int reg, u_int val)
|
||||||
{
|
{
|
||||||
__asm__(
|
asm volatile(
|
||||||
"str%?h %1, [%2] @ NET_RAP\n\t"
|
"str%?h %1, [%2] @ NET_RAP\n\t"
|
||||||
"str%?h %0, [%2, #8] @ NET_IDP"
|
"str%?h %0, [%2, #8] @ NET_IDP"
|
||||||
:
|
:
|
||||||
@ -80,7 +80,7 @@ static inline void write_ireg(u_long base, u_int reg, u_int val)
|
|||||||
static inline unsigned short read_ireg(u_long base_addr, u_int reg)
|
static inline unsigned short read_ireg(u_long base_addr, u_int reg)
|
||||||
{
|
{
|
||||||
u_short v;
|
u_short v;
|
||||||
__asm__(
|
asm volatile(
|
||||||
"str%?h %1, [%2] @ NAT_RAP\n\t"
|
"str%?h %1, [%2] @ NAT_RAP\n\t"
|
||||||
"ldr%?h %0, [%2, #8] @ NET_IDP\n\t"
|
"ldr%?h %0, [%2, #8] @ NET_IDP\n\t"
|
||||||
: "=r" (v)
|
: "=r" (v)
|
||||||
@ -131,7 +131,7 @@ am_readbuffer(struct net_device *dev, u_int offset, unsigned char *buf, unsigned
|
|||||||
length = (length + 1) & ~1;
|
length = (length + 1) & ~1;
|
||||||
if ((int)buf & 2) {
|
if ((int)buf & 2) {
|
||||||
unsigned int tmp;
|
unsigned int tmp;
|
||||||
__asm__ __volatile__(
|
asm volatile(
|
||||||
"ldr%?h %2, [%0], #4\n\t"
|
"ldr%?h %2, [%0], #4\n\t"
|
||||||
"str%?b %2, [%1], #1\n\t"
|
"str%?b %2, [%1], #1\n\t"
|
||||||
"mov%? %2, %2, lsr #8\n\t"
|
"mov%? %2, %2, lsr #8\n\t"
|
||||||
@ -141,7 +141,7 @@ am_readbuffer(struct net_device *dev, u_int offset, unsigned char *buf, unsigned
|
|||||||
}
|
}
|
||||||
while (length > 8) {
|
while (length > 8) {
|
||||||
unsigned int tmp, tmp2, tmp3;
|
unsigned int tmp, tmp2, tmp3;
|
||||||
__asm__ __volatile__(
|
asm volatile(
|
||||||
"ldr%?h %2, [%0], #4\n\t"
|
"ldr%?h %2, [%0], #4\n\t"
|
||||||
"ldr%?h %3, [%0], #4\n\t"
|
"ldr%?h %3, [%0], #4\n\t"
|
||||||
"orr%? %2, %2, %3, lsl #16\n\t"
|
"orr%? %2, %2, %3, lsl #16\n\t"
|
||||||
@ -155,7 +155,7 @@ am_readbuffer(struct net_device *dev, u_int offset, unsigned char *buf, unsigned
|
|||||||
}
|
}
|
||||||
while (length > 0) {
|
while (length > 0) {
|
||||||
unsigned int tmp;
|
unsigned int tmp;
|
||||||
__asm__ __volatile__(
|
asm volatile(
|
||||||
"ldr%?h %2, [%0], #4\n\t"
|
"ldr%?h %2, [%0], #4\n\t"
|
||||||
"str%?b %2, [%1], #1\n\t"
|
"str%?b %2, [%1], #1\n\t"
|
||||||
"mov%? %2, %2, lsr #8\n\t"
|
"mov%? %2, %2, lsr #8\n\t"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user