mirror of
https://git.proxmox.com/git/mirror_iproute2
synced 2025-10-05 17:15:45 +00:00

iproute2 contains a bunch of kernel headers, including uapi ones. Android's libc uses uapi headers almost directly, and uses a script to fix kernel types that don't match what userspace expects. For example: https://issuetracker.google.com/36987220 reports that our struct ip_mreq_source contains "__be32 imr_multiaddr" rather than "struct in_addr imr_multiaddr". The script addresses this by replacing the uapi struct definition with a #include <bits/ip_mreq.h> which contains the traditional userspace definition. Unfortunately, when we compile iproute2, this definition conflicts with the one in iproute2's linux/in.h. Historically we've just solved this problem by running "git rm" on all the iproute2 include/linux headers that break Android's libc. However, deleting the files in this way makes it harder to keep up with upstream, because every upstream change to an include file causes a merge conflict with the delete. This patch fixes the problem by moving the iproute2 linux headers from include/linux to include/uapi/linux. Tested: compiles on ubuntu trusty (glibc) Signed-off-by: Elliott Hughes <enh@google.com> Signed-off-by: Lorenzo Colitti <lorenzo@google.com>
33 lines
526 B
C
33 lines
526 B
C
#ifndef _LINUX_SEG6_GENL_H
|
|
#define _LINUX_SEG6_GENL_H
|
|
|
|
#define SEG6_GENL_NAME "SEG6"
|
|
#define SEG6_GENL_VERSION 0x1
|
|
|
|
enum {
|
|
SEG6_ATTR_UNSPEC,
|
|
SEG6_ATTR_DST,
|
|
SEG6_ATTR_DSTLEN,
|
|
SEG6_ATTR_HMACKEYID,
|
|
SEG6_ATTR_SECRET,
|
|
SEG6_ATTR_SECRETLEN,
|
|
SEG6_ATTR_ALGID,
|
|
SEG6_ATTR_HMACINFO,
|
|
__SEG6_ATTR_MAX,
|
|
};
|
|
|
|
#define SEG6_ATTR_MAX (__SEG6_ATTR_MAX - 1)
|
|
|
|
enum {
|
|
SEG6_CMD_UNSPEC,
|
|
SEG6_CMD_SETHMAC,
|
|
SEG6_CMD_DUMPHMAC,
|
|
SEG6_CMD_SET_TUNSRC,
|
|
SEG6_CMD_GET_TUNSRC,
|
|
__SEG6_CMD_MAX,
|
|
};
|
|
|
|
#define SEG6_CMD_MAX (__SEG6_CMD_MAX - 1)
|
|
|
|
#endif
|