mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-10-30 16:07:39 +00:00
07d46d93c9
Following RFC 6554 [1], the current order of fields is wrong for big
endian definition. Indeed, here is how the header looks like:
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Next Header | Hdr Ext Len | Routing Type | Segments Left |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| CmprI | CmprE | Pad | Reserved |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
This patch reorders fields so that big endian definition is now correct.
[1] https://tools.ietf.org/html/rfc6554#section-3
Fixes: cfa933d938
("include: uapi: linux: add rpl sr header definition")
Signed-off-by: Justin Iurman <justin.iurman@uliege.be>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
48 lines
824 B
C
48 lines
824 B
C
/* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
|
|
/*
|
|
* IPv6 RPL-SR implementation
|
|
*
|
|
* Author:
|
|
* (C) 2020 Alexander Aring <alex.aring@gmail.com>
|
|
*/
|
|
|
|
#ifndef _UAPI_LINUX_RPL_H
|
|
#define _UAPI_LINUX_RPL_H
|
|
|
|
#include <asm/byteorder.h>
|
|
#include <linux/types.h>
|
|
#include <linux/in6.h>
|
|
|
|
/*
|
|
* RPL SR Header
|
|
*/
|
|
struct ipv6_rpl_sr_hdr {
|
|
__u8 nexthdr;
|
|
__u8 hdrlen;
|
|
__u8 type;
|
|
__u8 segments_left;
|
|
#if defined(__LITTLE_ENDIAN_BITFIELD)
|
|
__u32 cmpre:4,
|
|
cmpri:4,
|
|
reserved:4,
|
|
pad:4,
|
|
reserved1:16;
|
|
#elif defined(__BIG_ENDIAN_BITFIELD)
|
|
__u32 cmpri:4,
|
|
cmpre:4,
|
|
pad:4,
|
|
reserved:20;
|
|
#else
|
|
#error "Please fix <asm/byteorder.h>"
|
|
#endif
|
|
|
|
union {
|
|
struct in6_addr addr[0];
|
|
__u8 data[0];
|
|
} segments;
|
|
} __attribute__((packed));
|
|
|
|
#define rpl_segaddr segments.addr
|
|
#define rpl_segdata segments.data
|
|
|
|
#endif
|