Commit 6d584c6e authored by Cong Wang's avatar Cong Wang Committed by Greg Kroah-Hartman

cgroup: Fix sock_cgroup_data on big-endian.

[ Upstream commit 14b032b8 ]

In order for no_refcnt and is_data to be the lowest order two
bits in the 'val' we have to pad out the bitfield of the u8.

Fixes: ad0f75e5 ("cgroup: fix cgroup_sk_alloc() for sk_clone_lock()")
Reported-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 0505cc4c
...@@ -757,6 +757,7 @@ struct sock_cgroup_data { ...@@ -757,6 +757,7 @@ struct sock_cgroup_data {
struct { struct {
u8 is_data : 1; u8 is_data : 1;
u8 no_refcnt : 1; u8 no_refcnt : 1;
u8 unused : 6;
u8 padding; u8 padding;
u16 prioidx; u16 prioidx;
u32 classid; u32 classid;
...@@ -766,6 +767,7 @@ struct sock_cgroup_data { ...@@ -766,6 +767,7 @@ struct sock_cgroup_data {
u32 classid; u32 classid;
u16 prioidx; u16 prioidx;
u8 padding; u8 padding;
u8 unused : 6;
u8 no_refcnt : 1; u8 no_refcnt : 1;
u8 is_data : 1; u8 is_data : 1;
} __packed; } __packed;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment