unaligned access in sk_run_filter()
This patch fixes unaligned access warnings noticed on IA64 in sk_run_filter(). 'ptr' can be unaligned. Signed-off-By: Dmitry Mishin <dim@openvz.org> Signed-off-By: Kirill Korotaev <dev@openvz.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
b809739a1b
commit
40daafc80b
|
@ -34,6 +34,7 @@
|
||||||
#include <linux/timer.h>
|
#include <linux/timer.h>
|
||||||
#include <asm/system.h>
|
#include <asm/system.h>
|
||||||
#include <asm/uaccess.h>
|
#include <asm/uaccess.h>
|
||||||
|
#include <asm/unaligned.h>
|
||||||
#include <linux/filter.h>
|
#include <linux/filter.h>
|
||||||
|
|
||||||
/* No hurry in this branch */
|
/* No hurry in this branch */
|
||||||
|
@ -177,7 +178,7 @@ unsigned int sk_run_filter(struct sk_buff *skb, struct sock_filter *filter, int
|
||||||
load_w:
|
load_w:
|
||||||
ptr = load_pointer(skb, k, 4, &tmp);
|
ptr = load_pointer(skb, k, 4, &tmp);
|
||||||
if (ptr != NULL) {
|
if (ptr != NULL) {
|
||||||
A = ntohl(*(u32 *)ptr);
|
A = ntohl(get_unaligned((u32 *)ptr));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -186,7 +187,7 @@ unsigned int sk_run_filter(struct sk_buff *skb, struct sock_filter *filter, int
|
||||||
load_h:
|
load_h:
|
||||||
ptr = load_pointer(skb, k, 2, &tmp);
|
ptr = load_pointer(skb, k, 2, &tmp);
|
||||||
if (ptr != NULL) {
|
if (ptr != NULL) {
|
||||||
A = ntohs(*(u16 *)ptr);
|
A = ntohs(get_unaligned((u16 *)ptr));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue