mirror of
https://git.proxmox.com/git/mirror_iproute2
synced 2025-10-05 20:48:07 +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>
61 lines
1.5 KiB
C
61 lines
1.5 KiB
C
/* tcp_metrics.h - TCP Metrics Interface */
|
|
|
|
#ifndef _LINUX_TCP_METRICS_H
|
|
#define _LINUX_TCP_METRICS_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
/* NETLINK_GENERIC related info
|
|
*/
|
|
#define TCP_METRICS_GENL_NAME "tcp_metrics"
|
|
#define TCP_METRICS_GENL_VERSION 0x1
|
|
|
|
enum tcp_metric_index {
|
|
TCP_METRIC_RTT, /* in ms units */
|
|
TCP_METRIC_RTTVAR, /* in ms units */
|
|
TCP_METRIC_SSTHRESH,
|
|
TCP_METRIC_CWND,
|
|
TCP_METRIC_REORDERING,
|
|
|
|
TCP_METRIC_RTT_US, /* in usec units */
|
|
TCP_METRIC_RTTVAR_US, /* in usec units */
|
|
|
|
/* Always last. */
|
|
__TCP_METRIC_MAX,
|
|
};
|
|
|
|
#define TCP_METRIC_MAX (__TCP_METRIC_MAX - 1)
|
|
|
|
enum {
|
|
TCP_METRICS_ATTR_UNSPEC,
|
|
TCP_METRICS_ATTR_ADDR_IPV4, /* u32 */
|
|
TCP_METRICS_ATTR_ADDR_IPV6, /* binary */
|
|
TCP_METRICS_ATTR_AGE, /* msecs */
|
|
TCP_METRICS_ATTR_TW_TSVAL, /* u32, raw, rcv tsval */
|
|
TCP_METRICS_ATTR_TW_TS_STAMP, /* s32, sec age */
|
|
TCP_METRICS_ATTR_VALS, /* nested +1, u32 */
|
|
TCP_METRICS_ATTR_FOPEN_MSS, /* u16 */
|
|
TCP_METRICS_ATTR_FOPEN_SYN_DROPS, /* u16, count of drops */
|
|
TCP_METRICS_ATTR_FOPEN_SYN_DROP_TS, /* msecs age */
|
|
TCP_METRICS_ATTR_FOPEN_COOKIE, /* binary */
|
|
TCP_METRICS_ATTR_SADDR_IPV4, /* u32 */
|
|
TCP_METRICS_ATTR_SADDR_IPV6, /* binary */
|
|
TCP_METRICS_ATTR_PAD,
|
|
|
|
__TCP_METRICS_ATTR_MAX,
|
|
};
|
|
|
|
#define TCP_METRICS_ATTR_MAX (__TCP_METRICS_ATTR_MAX - 1)
|
|
|
|
enum {
|
|
TCP_METRICS_CMD_UNSPEC,
|
|
TCP_METRICS_CMD_GET,
|
|
TCP_METRICS_CMD_DEL,
|
|
|
|
__TCP_METRICS_CMD_MAX,
|
|
};
|
|
|
|
#define TCP_METRICS_CMD_MAX (__TCP_METRICS_CMD_MAX - 1)
|
|
|
|
#endif /* _LINUX_TCP_METRICS_H */
|