| /** @file | |
| Header file for ICMP protocol. | |
| Copyright (c) 2005 - 2018, Intel Corporation. All rights reserved.<BR> | |
| SPDX-License-Identifier: BSD-2-Clause-Patent | |
| **/ | |
| #ifndef __EFI_IP4_ICMP_H__ | |
| #define __EFI_IP4_ICMP_H__ | |
| // | |
| // ICMP type definitions | |
| // | |
| #define ICMP_ECHO_REPLY 0 | |
| #define ICMP_DEST_UNREACHABLE 3 | |
| #define ICMP_SOURCE_QUENCH 4 | |
| #define ICMP_REDIRECT 5 | |
| #define ICMP_ECHO_REQUEST 8 | |
| #define ICMP_TIME_EXCEEDED 11 | |
| #define ICMP_PARAMETER_PROBLEM 12 | |
| #define ICMP_TIMESTAMP 13 | |
| #define ICMP_INFO_REQUEST 15 | |
| #define ICMP_INFO_REPLY 16 | |
| #define ICMP_TYPE_MAX ICMP_INFO_REPLY | |
| #define ICMP_DEFAULT_CODE 0 | |
| // | |
| // ICMP code definitions for ICMP_DEST_UNREACHABLE | |
| // | |
| #define ICMP_NET_UNREACHABLE 0 | |
| #define ICMP_HOST_UNREACHABLE 1 | |
| #define ICMP_PROTO_UNREACHABLE 2 // Host may generate | |
| #define ICMP_PORT_UNREACHABLE 3 // Host may generate | |
| #define ICMP_FRAGMENT_FAILED 4 | |
| #define ICMP_SOURCEROUTE_FAILED 5 // Host may generate | |
| #define ICMP_NET_UNKNOWN 6 | |
| #define ICMP_HOST_UNKNOWN 7 | |
| #define ICMP_SOURCE_ISOLATED 8 | |
| #define ICMP_NET_PROHIBITED 9 | |
| #define ICMP_HOST_PROHIBITED 10 | |
| #define ICMP_NET_UNREACHABLE_TOS 11 | |
| #define ICMP_HOST_UNREACHABLE_TOS 12 | |
| // | |
| // ICMP code definitions for ICMP_TIME_EXCEEDED | |
| // | |
| #define ICMP_TIMEOUT_IN_TRANSIT 0 | |
| #define ICMP_TIMEOUT_REASSEMBLE 1 // Host may generate | |
| // | |
| // ICMP code definitions for ICMP_TIME_EXCEEDED | |
| // | |
| #define ICMP_NET_REDIRECT 0 | |
| #define ICMP_HOST_REDIRECT 1 | |
| #define ICMP_NET_TOS_REDIRECT 2 | |
| #define ICMP_HOST_TOS_REDIRECT 3 | |
| // | |
| // ICMP message classes, each class of ICMP message shares | |
| // a common message format. INVALID_MESSAGE is only a flag. | |
| // | |
| #define ICMP_INVALID_MESSAGE 0 | |
| #define ICMP_ERROR_MESSAGE 1 | |
| #define ICMP_QUERY_MESSAGE 2 | |
| typedef struct { | |
| UINT8 IcmpType; | |
| UINT8 IcmpClass; | |
| } IP4_ICMP_CLASS; | |
| extern IP4_ICMP_CLASS mIcmpClass[]; | |
| extern EFI_IP4_ICMP_TYPE mIp4SupportedIcmp[]; | |
| /** | |
| Handle the ICMP packet. First validate the message format, | |
| then according to the message types, process it as query or | |
| error packet. | |
| @param[in] IpSb The IP4 service that receivd the packet. | |
| @param[in] Head The IP4 head of the ICMP query packet. | |
| @param[in] Packet The content of the ICMP query with IP4 head | |
| removed. | |
| @retval EFI_INVALID_PARAMETER The packet is malformatted. | |
| @retval EFI_SUCCESS The ICMP message is successfully processed. | |
| @retval Others Failed to handle ICMP packet. | |
| **/ | |
| EFI_STATUS | |
| Ip4IcmpHandle ( | |
| IN IP4_SERVICE *IpSb, | |
| IN IP4_HEAD *Head, | |
| IN NET_BUF *Packet | |
| ); | |
| #endif |