]> git.proxmox.com Git - mirror_edk2.git/blame - NetworkPkg/Application/IpsecConfig/IpSecConfig.h
NetworkPkg/IpsecConfig: guard the definition of ARRAY_SIZE
[mirror_edk2.git] / NetworkPkg / Application / IpsecConfig / IpSecConfig.h
CommitLineData
a3bcde70
HT
1/** @file\r
2 The internal structure and function declaration in IpSecConfig application.\r
3\r
96c1d788 4 Copyright (c) 2009 - 2016, Intel Corporation. All rights reserved.<BR>\r
a3bcde70
HT
5\r
6 This program and the accompanying materials\r
7 are licensed and made available under the terms and conditions of the BSD License\r
8 which accompanies this distribution. The full text of the license may be found at\r
9 http://opensource.org/licenses/bsd-license.php.\r
10\r
11 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
13\r
14**/\r
15\r
16#ifndef _IPSEC_CONFIG_H_\r
17#define _IPSEC_CONFIG_H_\r
18\r
19#include <Library/BaseMemoryLib.h>\r
20#include <Library/UefiLib.h>\r
21#include <Library/ShellLib.h>\r
22#include <Library/DebugLib.h>\r
23#include <Library/MemoryAllocationLib.h>\r
24#include <Library/UefiBootServicesTableLib.h>\r
be6cd654 25#include <Library/UefiHiiServicesLib.h>\r
a3bcde70
HT
26#include <Library/NetLib.h>\r
27\r
28#include <Protocol/IpSecConfig.h>\r
29\r
2f2a78f9 30#ifndef ARRAY_SIZE\r
a3bcde70 31#define ARRAY_SIZE(x) (sizeof(x) / sizeof(x[0]))\r
2f2a78f9 32#endif\r
a3bcde70
HT
33\r
34#define IPSECCONFIG_STATUS_NAME L"IpSecStatus"\r
35\r
36#define BIT(x) (UINT32) (1 << (x))\r
37\r
38#define IPSEC_STATUS_DISABLED 0x0\r
39#define IPSEC_STATUS_ENABLED 0x1\r
40\r
41#define EFI_IP4_PROTO_ICMP 0x1\r
42#define EFI_IP4_PROTO_TCP 0x6\r
43#define EFI_IP4_PROTO_UDP 0x11\r
44\r
45#define EFI_IPSEC_ANY_PROTOCOL 0xFFFF\r
46#define EFI_IPSEC_ANY_PORT 0\r
47\r
780847d1 48///\r
49/// IPsec Authentication Algorithm Definition\r
50/// The number value definition is aligned to IANA assignment\r
51///\r
52#define IPSEC_AALG_NONE 0x00\r
53#define IPSEC_AALG_MD5HMAC 0x01\r
54#define IPSEC_AALG_SHA1HMAC 0x02\r
55#define IPSEC_AALG_SHA2_256HMAC 0x05\r
56#define IPSEC_AALG_SHA2_384HMAC 0x06\r
57#define IPSEC_AALG_SHA2_512HMAC 0x07\r
58#define IPSEC_AALG_AES_XCBC_MAC 0x09\r
59#define IPSEC_AALG_NULL 0xFB\r
60\r
61///\r
62/// IPsec Encryption Algorithm Definition\r
63/// The number value definition is aligned to IANA assignment\r
64///\r
65#define IPSEC_EALG_NONE 0x00\r
66#define IPSEC_EALG_DESCBC 0x02\r
67#define IPSEC_EALG_3DESCBC 0x03\r
68#define IPSEC_EALG_CASTCBC 0x06\r
69#define IPSEC_EALG_BLOWFISHCBC 0x07\r
70#define IPSEC_EALG_NULL 0x0B\r
71#define IPSEC_EALG_AESCBC 0x0C\r
72#define IPSEC_EALG_AESCTR 0x0D\r
73#define IPSEC_EALG_AES_CCM_ICV8 0x0E\r
74#define IPSEC_EALG_AES_CCM_ICV12 0x0F\r
75#define IPSEC_EALG_AES_CCM_ICV16 0x10\r
76#define IPSEC_EALG_AES_GCM_ICV8 0x12\r
77#define IPSEC_EALG_AES_GCM_ICV12 0x13\r
78#define IPSEC_EALG_AES_GCM_ICV16 0x14\r
79\r
80typedef struct {\r
a3bcde70
HT
81 CHAR16 *VarName;\r
82 UINT32 Attribute1;\r
83 UINT32 Attribute2;\r
84 UINT32 Attribute3;\r
85 UINT32 Attribute4;\r
86} VAR_CHECK_ITEM;\r
87\r
780847d1 88typedef struct {\r
89 LIST_ENTRY Link;\r
90 CHAR16 *Name;\r
91 SHELL_PARAM_TYPE Type;\r
92 CHAR16 *Value;\r
93 UINTN OriginalPosition;\r
a3bcde70
HT
94} SHELL_PARAM_PACKAGE;\r
95\r
780847d1 96typedef struct {\r
a3bcde70
HT
97 CHAR16 *String;\r
98 UINT32 Integer;\r
99} STR2INT;\r
100\r
101extern EFI_IPSEC_CONFIG_PROTOCOL *mIpSecConfig;\r
102extern EFI_HII_HANDLE mHiiHandle;\r
103extern CHAR16 mAppName[];\r
104\r
105//\r
106// -P\r
107//\r
108extern STR2INT mMapPolicy[];\r
109\r
110//\r
111// --proto\r
112//\r
113extern STR2INT mMapIpProtocol[];\r
114\r
115//\r
116// --action\r
117//\r
118extern STR2INT mMapIpSecAction[];\r
119\r
120//\r
121// --mode\r
122//\r
123extern STR2INT mMapIpSecMode[];\r
124\r
125//\r
126// --dont-fragment\r
127//\r
128extern STR2INT mMapDfOption[];\r
129\r
130//\r
131// --ipsec-proto\r
132//\r
133extern STR2INT mMapIpSecProtocol[];\r
134//\r
135// --auth-algo\r
136//\r
137extern STR2INT mMapAuthAlgo[];\r
138\r
139//\r
140// --encrypt-algo\r
141//\r
142extern STR2INT mMapEncAlgo[];\r
143//\r
144// --auth-proto\r
145//\r
146extern STR2INT mMapAuthProto[];\r
147\r
148//\r
149// --auth-method\r
150//\r
151extern STR2INT mMapAuthMethod[];\r
152\r
153#endif\r