2021-07-21 03:42:56 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
|
|
|
|
/*
|
|
|
|
* IPv6 IOAM implementation
|
|
|
|
*
|
|
|
|
* Author:
|
|
|
|
* Justin Iurman <justin.iurman@uliege.be>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _UAPI_LINUX_IOAM6_H
|
|
|
|
#define _UAPI_LINUX_IOAM6_H
|
|
|
|
|
|
|
|
#include <asm/byteorder.h>
|
|
|
|
#include <linux/types.h>
|
|
|
|
|
ipv6: ioam: Data plane support for Pre-allocated Trace
Implement support for processing the IOAM Pre-allocated Trace with IPv6,
see [1] and [2]. Introduce a new IPv6 Hop-by-Hop TLV option, see IANA [3].
A new per-interface sysctl is introduced. The value is a boolean to accept (=1)
or ignore (=0, by default) IPv6 IOAM options on ingress for an interface:
- net.ipv6.conf.XXX.ioam6_enabled
Two other sysctls are introduced to define IOAM IDs, represented by an integer.
They are respectively per-namespace and per-interface:
- net.ipv6.ioam6_id
- net.ipv6.conf.XXX.ioam6_id
The value of the first one represents the IOAM ID of the node itself (u32; max
and default value = U32_MAX>>8, due to hop limit concatenation) while the other
represents the IOAM ID of an interface (u16; max and default value = U16_MAX).
Each "ioam6_id" sysctl has a "_wide" equivalent:
- net.ipv6.ioam6_id_wide
- net.ipv6.conf.XXX.ioam6_id_wide
The value of the first one represents the wide IOAM ID of the node itself (u64;
max and default value = U64_MAX>>8, due to hop limit concatenation) while the
other represents the wide IOAM ID of an interface (u32; max and default value
= U32_MAX).
The use of short and wide equivalents is not exclusive, a deployment could
choose to leverage both. For example, net.ipv6.conf.XXX.ioam6_id (short format)
could be an identifier for a physical interface, whereas
net.ipv6.conf.XXX.ioam6_id_wide (wide format) could be an identifier for a
logical sub-interface. Documentation about new sysctls is provided at the end
of this patchset.
Two relativistic hash tables are used: one for IOAM namespaces, the other for
IOAM schemas. A namespace can only have a single active schema and a schema
can only be attached to a single namespace (1:1 relationship).
[1] https://tools.ietf.org/html/draft-ietf-ippm-ioam-ipv6-options
[2] https://tools.ietf.org/html/draft-ietf-ippm-ioam-data
[3] https://www.iana.org/assignments/ipv6-parameters/ipv6-parameters.xhtml#ipv6-parameters-2
Signed-off-by: Justin Iurman <justin.iurman@uliege.be>
Signed-off-by: David S. Miller <davem@davemloft.net>
2021-07-21 03:42:57 +08:00
|
|
|
#define IOAM6_U16_UNAVAILABLE U16_MAX
|
|
|
|
#define IOAM6_U32_UNAVAILABLE U32_MAX
|
|
|
|
#define IOAM6_U64_UNAVAILABLE U64_MAX
|
|
|
|
|
|
|
|
#define IOAM6_DEFAULT_ID (IOAM6_U32_UNAVAILABLE >> 8)
|
|
|
|
#define IOAM6_DEFAULT_ID_WIDE (IOAM6_U64_UNAVAILABLE >> 8)
|
|
|
|
#define IOAM6_DEFAULT_IF_ID IOAM6_U16_UNAVAILABLE
|
|
|
|
#define IOAM6_DEFAULT_IF_ID_WIDE IOAM6_U32_UNAVAILABLE
|
|
|
|
|
2021-07-21 03:42:56 +08:00
|
|
|
/*
|
|
|
|
* IPv6 IOAM Option Header
|
|
|
|
*/
|
|
|
|
struct ioam6_hdr {
|
|
|
|
__u8 opt_type;
|
|
|
|
__u8 opt_len;
|
|
|
|
__u8 :8; /* reserved */
|
|
|
|
#define IOAM6_TYPE_PREALLOC 0
|
|
|
|
__u8 type;
|
|
|
|
} __attribute__((packed));
|
|
|
|
|
|
|
|
/*
|
|
|
|
* IOAM Trace Header
|
|
|
|
*/
|
|
|
|
struct ioam6_trace_hdr {
|
|
|
|
__be16 namespace_id;
|
|
|
|
|
|
|
|
#if defined(__LITTLE_ENDIAN_BITFIELD)
|
|
|
|
|
|
|
|
__u8 :1, /* unused */
|
|
|
|
:1, /* unused */
|
|
|
|
overflow:1,
|
|
|
|
nodelen:5;
|
|
|
|
|
|
|
|
__u8 remlen:7,
|
|
|
|
:1; /* unused */
|
|
|
|
|
|
|
|
union {
|
|
|
|
__be32 type_be32;
|
|
|
|
|
|
|
|
struct {
|
|
|
|
__u32 bit7:1,
|
|
|
|
bit6:1,
|
|
|
|
bit5:1,
|
|
|
|
bit4:1,
|
|
|
|
bit3:1,
|
|
|
|
bit2:1,
|
|
|
|
bit1:1,
|
|
|
|
bit0:1,
|
|
|
|
bit15:1, /* unused */
|
|
|
|
bit14:1, /* unused */
|
|
|
|
bit13:1, /* unused */
|
|
|
|
bit12:1, /* unused */
|
|
|
|
bit11:1,
|
|
|
|
bit10:1,
|
|
|
|
bit9:1,
|
|
|
|
bit8:1,
|
|
|
|
bit23:1, /* reserved */
|
|
|
|
bit22:1,
|
|
|
|
bit21:1, /* unused */
|
|
|
|
bit20:1, /* unused */
|
|
|
|
bit19:1, /* unused */
|
|
|
|
bit18:1, /* unused */
|
|
|
|
bit17:1, /* unused */
|
|
|
|
bit16:1, /* unused */
|
|
|
|
:8; /* reserved */
|
|
|
|
} type;
|
|
|
|
};
|
|
|
|
|
|
|
|
#elif defined(__BIG_ENDIAN_BITFIELD)
|
|
|
|
|
|
|
|
__u8 nodelen:5,
|
|
|
|
overflow:1,
|
|
|
|
:1, /* unused */
|
|
|
|
:1; /* unused */
|
|
|
|
|
|
|
|
__u8 :1, /* unused */
|
|
|
|
remlen:7;
|
|
|
|
|
|
|
|
union {
|
|
|
|
__be32 type_be32;
|
|
|
|
|
|
|
|
struct {
|
|
|
|
__u32 bit0:1,
|
|
|
|
bit1:1,
|
|
|
|
bit2:1,
|
|
|
|
bit3:1,
|
|
|
|
bit4:1,
|
|
|
|
bit5:1,
|
|
|
|
bit6:1,
|
|
|
|
bit7:1,
|
|
|
|
bit8:1,
|
|
|
|
bit9:1,
|
|
|
|
bit10:1,
|
|
|
|
bit11:1,
|
|
|
|
bit12:1, /* unused */
|
|
|
|
bit13:1, /* unused */
|
|
|
|
bit14:1, /* unused */
|
|
|
|
bit15:1, /* unused */
|
|
|
|
bit16:1, /* unused */
|
|
|
|
bit17:1, /* unused */
|
|
|
|
bit18:1, /* unused */
|
|
|
|
bit19:1, /* unused */
|
|
|
|
bit20:1, /* unused */
|
|
|
|
bit21:1, /* unused */
|
|
|
|
bit22:1,
|
|
|
|
bit23:1, /* reserved */
|
|
|
|
:8; /* reserved */
|
|
|
|
} type;
|
|
|
|
};
|
|
|
|
|
|
|
|
#else
|
|
|
|
#error "Please fix <asm/byteorder.h>"
|
|
|
|
#endif
|
|
|
|
|
2021-07-21 03:42:59 +08:00
|
|
|
#define IOAM6_TRACE_DATA_SIZE_MAX 244
|
2021-07-21 03:42:56 +08:00
|
|
|
__u8 data[0];
|
|
|
|
} __attribute__((packed));
|
|
|
|
|
|
|
|
#endif /* _UAPI_LINUX_IOAM6_H */
|