diff options
author | Haiqing Bai <Haiqing.Bai@windriver.com> | 2018-08-27 04:32:26 +0300 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2018-08-28 01:23:31 +0300 |
commit | 30935198b7d0be12b1c45c328b66a7fdefb16256 (patch) | |
tree | 4d2e12f2daa913eb6c8a7d7908f41dd0c2a42cff /net/tipc/name_table.h | |
parent | ca2b1d2d4271209060a1c9e8e1ffb06fbecc812b (diff) | |
download | linux-30935198b7d0be12b1c45c328b66a7fdefb16256.tar.xz |
tipc: fix the big/little endian issue in tipc_dest
In function tipc_dest_push, the 32bit variables 'node' and 'port'
are stored separately in uppper and lower part of 64bit 'value'.
Then this value is assigned to dst->value which is a union like:
union
{
struct {
u32 port;
u32 node;
};
u64 value;
}
This works on little-endian machines like x86 but fails on big-endian
machines.
The fix remove the 'value' stack parameter and even the 'value'
member of the union in tipc_dest, assign the 'node' and 'port' member
directly with the input parameter to avoid the endian issue.
Fixes: a80ae5306a73 ("tipc: improve destination linked list")
Signed-off-by: Zhenbo Gao <zhenbo.gao@windriver.com>
Acked-by: Jon Maloy <jon.maloy@ericsson.com>
Signed-off-by: Haiqing Bai <Haiqing.Bai@windriver.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/tipc/name_table.h')
-rw-r--r-- | net/tipc/name_table.h | 9 |
1 files changed, 2 insertions, 7 deletions
diff --git a/net/tipc/name_table.h b/net/tipc/name_table.h index 0febba41da86..892bd750b85f 100644 --- a/net/tipc/name_table.h +++ b/net/tipc/name_table.h @@ -133,13 +133,8 @@ void tipc_nametbl_stop(struct net *net); struct tipc_dest { struct list_head list; - union { - struct { - u32 port; - u32 node; - }; - u64 value; - }; + u32 port; + u32 node; }; struct tipc_dest *tipc_dest_find(struct list_head *l, u32 node, u32 port); |