mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-12 15:44:01 +08:00
e2be04c7f9
Many user space API headers have licensing information, which is either incomplete, badly formatted or just a shorthand for referring to the license under which the file is supposed to be. This makes it hard for compliance tools to determine the correct license. Update these files with an SPDX license identifier. The identifier was chosen based on the license information in the file. GPL/LGPL licensed headers get the matching GPL/LGPL SPDX license identifier with the added 'WITH Linux-syscall-note' exception, which is the officially assigned exception identifier for the kernel syscall exception: NOTE! This copyright does *not* cover user programs that use kernel services by normal system calls - this is merely considered normal use of the kernel, and does *not* fall under the heading of "derived work". This exception makes it possible to include GPL headers into non GPL code, without confusing license compliance tools. Headers which have either explicit dual licensing or are just licensed under a non GPL license are updated with the corresponding SPDX identifier and the GPLv2 with syscall exception identifier. The format is: ((GPL-2.0 WITH Linux-syscall-note) OR SPDX-ID-OF-OTHER-LICENSE) SPDX license identifiers are a legally binding shorthand, which can be used instead of the full boiler plate text. The update does not remove existing license information as this has to be done on a case by case basis and the copyright holders might have to be consulted. This will happen in a separate step. This patch is based on work done by Thomas Gleixner and Kate Stewart and Philippe Ombredanne. See the previous patch in this series for the methodology of how this patch was researched. Reviewed-by: Kate Stewart <kstewart@linuxfoundation.org> Reviewed-by: Philippe Ombredanne <pombredanne@nexb.com> Reviewed-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
100 lines
2.9 KiB
C
100 lines
2.9 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
|
|
/*
|
|
* INET An implementation of the TCP/IP protocol suite for the LINUX
|
|
* operating system. INET is implemented using the BSD Socket
|
|
* interface as the means of communication with the user level.
|
|
*
|
|
* Definitions for the ICMP protocol.
|
|
*
|
|
* Version: @(#)icmp.h 1.0.3 04/28/93
|
|
*
|
|
* Author: Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version
|
|
* 2 of the License, or (at your option) any later version.
|
|
*/
|
|
#ifndef _UAPI_LINUX_ICMP_H
|
|
#define _UAPI_LINUX_ICMP_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
#define ICMP_ECHOREPLY 0 /* Echo Reply */
|
|
#define ICMP_DEST_UNREACH 3 /* Destination Unreachable */
|
|
#define ICMP_SOURCE_QUENCH 4 /* Source Quench */
|
|
#define ICMP_REDIRECT 5 /* Redirect (change route) */
|
|
#define ICMP_ECHO 8 /* Echo Request */
|
|
#define ICMP_TIME_EXCEEDED 11 /* Time Exceeded */
|
|
#define ICMP_PARAMETERPROB 12 /* Parameter Problem */
|
|
#define ICMP_TIMESTAMP 13 /* Timestamp Request */
|
|
#define ICMP_TIMESTAMPREPLY 14 /* Timestamp Reply */
|
|
#define ICMP_INFO_REQUEST 15 /* Information Request */
|
|
#define ICMP_INFO_REPLY 16 /* Information Reply */
|
|
#define ICMP_ADDRESS 17 /* Address Mask Request */
|
|
#define ICMP_ADDRESSREPLY 18 /* Address Mask Reply */
|
|
#define NR_ICMP_TYPES 18
|
|
|
|
|
|
/* Codes for UNREACH. */
|
|
#define ICMP_NET_UNREACH 0 /* Network Unreachable */
|
|
#define ICMP_HOST_UNREACH 1 /* Host Unreachable */
|
|
#define ICMP_PROT_UNREACH 2 /* Protocol Unreachable */
|
|
#define ICMP_PORT_UNREACH 3 /* Port Unreachable */
|
|
#define ICMP_FRAG_NEEDED 4 /* Fragmentation Needed/DF set */
|
|
#define ICMP_SR_FAILED 5 /* Source Route failed */
|
|
#define ICMP_NET_UNKNOWN 6
|
|
#define ICMP_HOST_UNKNOWN 7
|
|
#define ICMP_HOST_ISOLATED 8
|
|
#define ICMP_NET_ANO 9
|
|
#define ICMP_HOST_ANO 10
|
|
#define ICMP_NET_UNR_TOS 11
|
|
#define ICMP_HOST_UNR_TOS 12
|
|
#define ICMP_PKT_FILTERED 13 /* Packet filtered */
|
|
#define ICMP_PREC_VIOLATION 14 /* Precedence violation */
|
|
#define ICMP_PREC_CUTOFF 15 /* Precedence cut off */
|
|
#define NR_ICMP_UNREACH 15 /* instead of hardcoding immediate value */
|
|
|
|
/* Codes for REDIRECT. */
|
|
#define ICMP_REDIR_NET 0 /* Redirect Net */
|
|
#define ICMP_REDIR_HOST 1 /* Redirect Host */
|
|
#define ICMP_REDIR_NETTOS 2 /* Redirect Net for TOS */
|
|
#define ICMP_REDIR_HOSTTOS 3 /* Redirect Host for TOS */
|
|
|
|
/* Codes for TIME_EXCEEDED. */
|
|
#define ICMP_EXC_TTL 0 /* TTL count exceeded */
|
|
#define ICMP_EXC_FRAGTIME 1 /* Fragment Reass time exceeded */
|
|
|
|
|
|
struct icmphdr {
|
|
__u8 type;
|
|
__u8 code;
|
|
__sum16 checksum;
|
|
union {
|
|
struct {
|
|
__be16 id;
|
|
__be16 sequence;
|
|
} echo;
|
|
__be32 gateway;
|
|
struct {
|
|
__be16 __unused;
|
|
__be16 mtu;
|
|
} frag;
|
|
__u8 reserved[4];
|
|
} un;
|
|
};
|
|
|
|
|
|
/*
|
|
* constants for (set|get)sockopt
|
|
*/
|
|
|
|
#define ICMP_FILTER 1
|
|
|
|
struct icmp_filter {
|
|
__u32 data;
|
|
};
|
|
|
|
|
|
#endif /* _UAPI_LINUX_ICMP_H */
|