2 The implementation for Shell command ifconfig based on IP4Config2 protocol.
4 (C) Copyright 2013-2015 Hewlett-Packard Development Company, L.P.<BR>
5 Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR>
7 This program and the accompanying materials
8 are licensed and made available under the terms and conditions of the BSD License
9 which accompanies this distribution. The full text of the license may be found at
10 http://opensource.org/licenses/bsd-license.php.
12 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
13 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
17 #include "UefiShellNetwork1CommandsLib.h"
26 VarCheckReserved
= -1,
40 } VAR_CHECK_FLAG_TYPE
;
42 #define MACADDRMAXSIZE 32
44 typedef struct _IFCONFIG_INTERFACE_CB
{
47 EFI_IP4_CONFIG2_PROTOCOL
*IfCfg
;
48 EFI_IP4_CONFIG2_INTERFACE_INFO
*IfInfo
;
49 EFI_IP4_CONFIG2_POLICY Policy
;
51 EFI_IPv4_ADDRESS DnsAddr
[1];
52 } IFCONFIG_INTERFACE_CB
;
54 typedef struct _ARG_LIST ARG_LIST
;
61 typedef struct _IFCONFIG4_PRIVATE_DATA
{
67 } IFCONFIG_PRIVATE_DATA
;
69 typedef struct _VAR_CHECK_ITEM
{
73 VAR_CHECK_FLAG_TYPE FlagType
;
76 SHELL_PARAM_ITEM mIfConfigCheckList
[] = {
103 VAR_CHECK_ITEM mSetCheckList
[] = {
130 STATIC CONST CHAR16 PermanentString
[10] = L
"PERMANENT";
133 Split a string with specified separator and save the substring to a list.
135 @param[in] String The pointer of the input string.
136 @param[in] Separator The specified separator.
138 @return The pointer of headnode of ARG_LIST.
143 IN CONST CHAR16
*String
,
152 if (*String
== L
'\0') {
157 // Copy the CONST string to a local copy.
159 Str
= AllocateCopyPool (StrSize (String
), String
);
160 ASSERT (Str
!= NULL
);
164 // init a node for the list head.
166 ArgNode
= (ARG_LIST
*) AllocateZeroPool (sizeof (ARG_LIST
));
167 ASSERT (ArgNode
!= NULL
);
171 // Split the local copy and save in the list node.
173 while (*Str
!= L
'\0') {
174 if (*Str
== Separator
) {
176 ArgNode
->Arg
= ArgStr
;
178 ArgNode
->Next
= (ARG_LIST
*) AllocateZeroPool (sizeof (ARG_LIST
));
179 ASSERT (ArgNode
->Next
!= NULL
);
180 ArgNode
= ArgNode
->Next
;
186 ArgNode
->Arg
= ArgStr
;
187 ArgNode
->Next
= NULL
;
193 Check the correctness of input Args with '-s' option.
195 @param[in] CheckList The pointer of VAR_CHECK_ITEM array.
196 @param[in] Name The pointer of input arg.
197 @param[in] Init The switch to execute the check.
199 @return VarCheckOk Valid parameter or Initialize check successfully.
200 @return VarCheckDuplicate Duplicated parameter happened.
201 @return VarCheckConflict Conflicted parameter happened
202 @return VarCheckUnknown Unknown parameter.
206 IfConfigRetriveCheckListByName(
207 IN VAR_CHECK_ITEM
*CheckList
,
212 STATIC UINT32 CheckDuplicate
;
213 STATIC UINT32 CheckConflict
;
214 VAR_CHECK_CODE RtCode
;
226 Arg
= CheckList
[Index
];
229 // Check the Duplicated/Conflicted/Unknown input Args.
231 while (Arg
.FlagStr
!= NULL
) {
232 if (StrCmp (Arg
.FlagStr
, Name
) == 0) {
234 if (CheckDuplicate
& Arg
.FlagID
) {
235 RtCode
= VarCheckDuplicate
;
239 if (CheckConflict
& Arg
.ConflictMask
) {
240 RtCode
= VarCheckConflict
;
244 CheckDuplicate
|= Arg
.FlagID
;
245 CheckConflict
|= Arg
.ConflictMask
;
249 Arg
= CheckList
[++Index
];
252 if (Arg
.FlagStr
== NULL
) {
253 RtCode
= VarCheckUnknown
;
260 The notify function of create event when performing a manual config.
262 @param[in] Event The event this notify function registered to.
263 @param[in] Context Pointer to the context data registered to the event.
268 IfConfigManualAddressNotify (
273 *((BOOLEAN
*) Context
) = TRUE
;
279 @param[in] Node The pointer of MAC address buffer.
280 @param[in] Size The size of MAC address buffer.
284 IfConfigPrintMacAddr (
291 ASSERT (Size
<= MACADDRMAXSIZE
);
293 for (Index
= 0; Index
< Size
; Index
++) {
294 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_MAC_ADDR_BODY
), gShellNetwork1HiiHandle
, Node
[Index
]);
295 if (Index
+ 1 < Size
) {
296 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_COLON
), gShellNetwork1HiiHandle
);
300 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_NEWLINE
), gShellNetwork1HiiHandle
);
305 The get current status of all handles.
307 @param[in] IfName The pointer of IfName(interface name).
308 @param[in] IfList The pointer of IfList(interface list).
310 @retval EFI_SUCCESS The get status processed successfully.
311 @retval others The get status process failed.
315 IfConfigGetInterfaceInfo (
317 IN LIST_ENTRY
*IfList
323 EFI_HANDLE
*HandleBuffer
;
324 EFI_IP4_CONFIG2_PROTOCOL
*Ip4Cfg2
;
325 EFI_IP4_CONFIG2_INTERFACE_INFO
*IfInfo
;
326 IFCONFIG_INTERFACE_CB
*IfCb
;
336 // Locate all the handles with ip4 service binding protocol.
338 Status
= gBS
->LocateHandleBuffer (
340 &gEfiIp4ServiceBindingProtocolGuid
,
345 if (EFI_ERROR (Status
) || (HandleNum
== 0)) {
350 // Enumerate all handles that installed with ip4 service binding protocol.
352 for (HandleIndex
= 0; HandleIndex
< HandleNum
; HandleIndex
++) {
358 // Ip4config protocol and ip4 service binding protocol are installed
359 // on the same handle.
361 ASSERT (HandleBuffer
!= NULL
);
362 Status
= gBS
->HandleProtocol (
363 HandleBuffer
[HandleIndex
],
364 &gEfiIp4Config2ProtocolGuid
,
368 if (EFI_ERROR (Status
)) {
373 // Get the interface information size.
375 Status
= Ip4Cfg2
->GetData (
377 Ip4Config2DataTypeInterfaceInfo
,
382 if (Status
!= EFI_BUFFER_TOO_SMALL
) {
386 IfInfo
= AllocateZeroPool (DataSize
);
388 if (IfInfo
== NULL
) {
389 Status
= EFI_OUT_OF_RESOURCES
;
394 // Get the interface info.
396 Status
= Ip4Cfg2
->GetData (
398 Ip4Config2DataTypeInterfaceInfo
,
403 if (EFI_ERROR (Status
)) {
408 // Check the interface name if required.
410 if ((IfName
!= NULL
) && (StrCmp (IfName
, IfInfo
->Name
) != 0)) {
418 // Get the size of dns server list.
420 Status
= Ip4Cfg2
->GetData (
422 Ip4Config2DataTypeDnsServer
,
427 if ((Status
!= EFI_BUFFER_TOO_SMALL
) && (Status
!= EFI_NOT_FOUND
)) {
431 IfCb
= AllocateZeroPool (sizeof (IFCONFIG_INTERFACE_CB
) + DataSize
);
434 Status
= EFI_OUT_OF_RESOURCES
;
438 IfCb
->NicHandle
= HandleBuffer
[HandleIndex
];
439 IfCb
->IfInfo
= IfInfo
;
440 IfCb
->IfCfg
= Ip4Cfg2
;
441 IfCb
->DnsCnt
= (UINT32
) (DataSize
/ sizeof (EFI_IPv4_ADDRESS
));
444 // Get the dns server list if has.
447 Status
= Ip4Cfg2
->GetData (
449 Ip4Config2DataTypeDnsServer
,
454 if (EFI_ERROR (Status
)) {
460 // Get the config policy.
462 DataSize
= sizeof (EFI_IP4_CONFIG2_POLICY
);
463 Status
= Ip4Cfg2
->GetData (
465 Ip4Config2DataTypePolicy
,
470 if (EFI_ERROR (Status
)) {
474 InsertTailList (IfList
, &IfCb
->Link
);
476 if ((IfName
!= NULL
) && (StrCmp (IfName
, IfInfo
->Name
) == 0)) {
478 // Only need the appointed interface, keep the allocated buffer.
486 if (HandleBuffer
!= NULL
) {
487 FreePool (HandleBuffer
);
494 if (IfInfo
!= NULL
) {
506 The list process of the ifconfig command.
508 @param[in] IfList The pointer of IfList(interface list).
510 @retval SHELL_SUCCESS The ifconfig command list processed successfully.
511 @retval others The ifconfig command list process failed.
515 IfConfigShowInterfaceInfo (
516 IN LIST_ENTRY
*IfList
521 IFCONFIG_INTERFACE_CB
*IfCb
;
522 BOOLEAN MediaPresent
;
523 EFI_IPv4_ADDRESS Gateway
;
528 if (IsListEmpty (IfList
)) {
529 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INVALID_INTERFACE
), gShellNetwork1HiiHandle
);
533 // Go through the interface list.
535 NET_LIST_FOR_EACH_SAFE (Entry
, Next
, IfList
) {
536 IfCb
= NET_LIST_USER_STRUCT (Entry
, IFCONFIG_INTERFACE_CB
, Link
);
538 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_BREAK
), gShellNetwork1HiiHandle
);
541 // Print interface name.
543 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_IF_NAME
), gShellNetwork1HiiHandle
, IfCb
->IfInfo
->Name
);
548 NetLibDetectMedia (IfCb
->NicHandle
, &MediaPresent
);
550 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_MEDIA_STATE
), gShellNetwork1HiiHandle
, L
"Media disconnected");
552 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_MEDIA_STATE
), gShellNetwork1HiiHandle
, L
"Media present");
556 // Print interface config policy.
558 if (IfCb
->Policy
== Ip4Config2PolicyDhcp
) {
559 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_POLICY_DHCP
), gShellNetwork1HiiHandle
);
561 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_POLICY_MAN
), gShellNetwork1HiiHandle
);
565 // Print mac address of the interface.
567 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_MAC_ADDR_HEAD
), gShellNetwork1HiiHandle
);
569 IfConfigPrintMacAddr (
570 IfCb
->IfInfo
->HwAddress
.Addr
,
571 IfCb
->IfInfo
->HwAddressSize
575 // Print IPv4 address list of the interface.
577 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_IP_ADDR_HEAD
), gShellNetwork1HiiHandle
);
583 STRING_TOKEN (STR_IFCONFIG_INFO_IP_ADDR_BODY
),
584 gShellNetwork1HiiHandle
,
585 (UINTN
)IfCb
->IfInfo
->StationAddress
.Addr
[0],
586 (UINTN
)IfCb
->IfInfo
->StationAddress
.Addr
[1],
587 (UINTN
)IfCb
->IfInfo
->StationAddress
.Addr
[2],
588 (UINTN
)IfCb
->IfInfo
->StationAddress
.Addr
[3]
592 // Print subnet mask list of the interface.
594 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_SUBNET_MASK_HEAD
), gShellNetwork1HiiHandle
);
600 STRING_TOKEN (STR_IFCONFIG_INFO_IP_ADDR_BODY
),
601 gShellNetwork1HiiHandle
,
602 (UINTN
)IfCb
->IfInfo
->SubnetMask
.Addr
[0],
603 (UINTN
)IfCb
->IfInfo
->SubnetMask
.Addr
[1],
604 (UINTN
)IfCb
->IfInfo
->SubnetMask
.Addr
[2],
605 (UINTN
)IfCb
->IfInfo
->SubnetMask
.Addr
[3]
609 // Print default gateway of the interface.
611 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_GATEWAY_HEAD
), gShellNetwork1HiiHandle
);
613 ZeroMem (&Gateway
, sizeof (EFI_IPv4_ADDRESS
));
615 for (Index
= 0; Index
< IfCb
->IfInfo
->RouteTableSize
; Index
++) {
616 if ((CompareMem (&IfCb
->IfInfo
->RouteTable
[Index
].SubnetAddress
, &mZeroIp4Addr
, sizeof (EFI_IPv4_ADDRESS
)) == 0) &&
617 (CompareMem (&IfCb
->IfInfo
->RouteTable
[Index
].SubnetMask
, &mZeroIp4Addr
, sizeof (EFI_IPv4_ADDRESS
)) == 0) ){
618 CopyMem (&Gateway
, &IfCb
->IfInfo
->RouteTable
[Index
].GatewayAddress
, sizeof (EFI_IPv4_ADDRESS
));
626 STRING_TOKEN (STR_IFCONFIG_INFO_IP_ADDR_BODY
),
627 gShellNetwork1HiiHandle
,
628 (UINTN
)Gateway
.Addr
[0],
629 (UINTN
)Gateway
.Addr
[1],
630 (UINTN
)Gateway
.Addr
[2],
631 (UINTN
)Gateway
.Addr
[3]
635 // Print route table entry.
637 ShellPrintHiiEx(-1, -1, NULL
,STRING_TOKEN (STR_IFCONFIG_ROUTES_SIZE
), gShellNetwork1HiiHandle
, IfCb
->IfInfo
->RouteTableSize
);
639 for (Index
= 0; Index
< IfCb
->IfInfo
->RouteTableSize
; Index
++) {
640 ShellPrintHiiEx(-1, -1, NULL
,STRING_TOKEN (STR_IFCONFIG_ROUTES_ENTRY_INDEX
), gShellNetwork1HiiHandle
, Index
);
646 STRING_TOKEN (STR_IFCONFIG_SHOW_IP_ADDR
),
647 gShellNetwork1HiiHandle
,
649 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].SubnetAddress
.Addr
[0],
650 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].SubnetAddress
.Addr
[1],
651 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].SubnetAddress
.Addr
[2],
652 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].SubnetAddress
.Addr
[3]
659 STRING_TOKEN (STR_IFCONFIG_SHOW_IP_ADDR
),
660 gShellNetwork1HiiHandle
,
662 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].SubnetMask
.Addr
[0],
663 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].SubnetMask
.Addr
[1],
664 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].SubnetMask
.Addr
[2],
665 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].SubnetMask
.Addr
[3]
672 STRING_TOKEN (STR_IFCONFIG_SHOW_IP_ADDR
),
673 gShellNetwork1HiiHandle
,
675 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].GatewayAddress
.Addr
[0],
676 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].GatewayAddress
.Addr
[1],
677 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].GatewayAddress
.Addr
[2],
678 (UINTN
)IfCb
->IfInfo
->RouteTable
[Index
].GatewayAddress
.Addr
[3]
683 // Print dns server addresses list of the interface if has.
685 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_DNS_ADDR_HEAD
), gShellNetwork1HiiHandle
);
687 for (Index
= 0; Index
< IfCb
->DnsCnt
; Index
++) {
692 STRING_TOKEN (STR_IFCONFIG_INFO_DNS_ADDR_BODY
),
693 gShellNetwork1HiiHandle
,
694 (UINTN
) IfCb
->DnsAddr
[Index
].Addr
[0],
695 (UINTN
) IfCb
->DnsAddr
[Index
].Addr
[1],
696 (UINTN
) IfCb
->DnsAddr
[Index
].Addr
[2],
697 (UINTN
) IfCb
->DnsAddr
[Index
].Addr
[3]
700 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_NEWLINE
), gShellNetwork1HiiHandle
);
704 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INFO_BREAK
), gShellNetwork1HiiHandle
);
706 return SHELL_SUCCESS
;
710 The clean process of the ifconfig command to clear interface info.
712 @param[in] IfList The pointer of IfList(interface list).
713 @param[in] IfName The pointer of interface name.
715 @retval SHELL_SUCCESS The ifconfig command clean processed successfully.
716 @retval others The ifconfig command clean process failed.
720 IfConfigClearInterfaceInfo (
721 IN LIST_ENTRY
*IfList
,
726 SHELL_STATUS ShellStatus
;
729 IFCONFIG_INTERFACE_CB
*IfCb
;
730 EFI_IP4_CONFIG2_POLICY Policy
;
732 Status
= EFI_SUCCESS
;
733 ShellStatus
= SHELL_SUCCESS
;
735 if (IsListEmpty (IfList
)) {
736 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INVALID_INTERFACE
), gShellNetwork1HiiHandle
);
740 // Go through the interface list.
741 // If the interface name is specified, DHCP DORA process will be
742 // triggered by the policy transition (static -> dhcp).
744 NET_LIST_FOR_EACH_SAFE (Entry
, Next
, IfList
) {
745 IfCb
= NET_LIST_USER_STRUCT (Entry
, IFCONFIG_INTERFACE_CB
, Link
);
747 if ((IfName
!= NULL
) && (StrCmp (IfName
, IfCb
->IfInfo
->Name
) == 0)) {
748 Policy
= Ip4Config2PolicyStatic
;
750 Status
= IfCb
->IfCfg
->SetData (
752 Ip4Config2DataTypePolicy
,
753 sizeof (EFI_IP4_CONFIG2_POLICY
),
756 if (EFI_ERROR (Status
)) {
757 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_GEN_ERR_AD
), gShellNetwork1HiiHandle
, L
"ifconfig");
758 ShellStatus
= SHELL_ACCESS_DENIED
;
763 Policy
= Ip4Config2PolicyDhcp
;
765 Status
= IfCb
->IfCfg
->SetData (
767 Ip4Config2DataTypePolicy
,
768 sizeof (EFI_IP4_CONFIG2_POLICY
),
771 if (EFI_ERROR (Status
)) {
772 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_GEN_ERR_AD
), gShellNetwork1HiiHandle
, L
"ifconfig");
773 ShellStatus
= SHELL_ACCESS_DENIED
;
782 The set process of the ifconfig command.
784 @param[in] IfList The pointer of IfList(interface list).
785 @param[in] VarArg The pointer of ARG_LIST(Args with "-s" option).
787 @retval SHELL_SUCCESS The ifconfig command set processed successfully.
788 @retval others The ifconfig command set process failed.
792 IfConfigSetInterfaceInfo (
793 IN LIST_ENTRY
*IfList
,
798 SHELL_STATUS ShellStatus
;
799 IFCONFIG_INTERFACE_CB
*IfCb
;
800 VAR_CHECK_CODE CheckCode
;
801 EFI_EVENT TimeOutEvt
;
805 EFI_IP4_CONFIG2_POLICY Policy
;
806 EFI_IP4_CONFIG2_MANUAL_ADDRESS ManualAddress
;
808 EFI_IPv4_ADDRESS Gateway
;
809 EFI_IPv4_ADDRESS
*Dns
;
813 CONST CHAR16
* TempString
;
817 if (IsListEmpty (IfList
)) {
818 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_INVALID_INTERFACE
), gShellNetwork1HiiHandle
);
819 return SHELL_INVALID_PARAMETER
;
823 // Make sure to set only one interface each time.
825 IfCb
= NET_LIST_USER_STRUCT (IfList
->ForwardLink
, IFCONFIG_INTERFACE_CB
, Link
);
826 Status
= EFI_SUCCESS
;
827 ShellStatus
= SHELL_SUCCESS
;
830 // Initialize check list mechanism.
832 CheckCode
= IfConfigRetriveCheckListByName(
839 // Create events & timers for asynchronous settings.
841 Status
= gBS
->CreateEvent (
848 if (EFI_ERROR (Status
)) {
849 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_GEN_ERR_AD
), gShellNetwork1HiiHandle
, L
"ifconfig");
850 ShellStatus
= SHELL_ACCESS_DENIED
;
854 Status
= gBS
->CreateEvent (
857 IfConfigManualAddressNotify
,
861 if (EFI_ERROR (Status
)) {
862 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_GEN_ERR_AD
), gShellNetwork1HiiHandle
, L
"ifconfig");
863 ShellStatus
= SHELL_ACCESS_DENIED
;
868 // Parse the setting variables.
870 while (VarArg
!= NULL
) {
872 // Check invalid parameters (duplication & unknown & conflict).
874 CheckCode
= IfConfigRetriveCheckListByName(
880 if (VarCheckOk
!= CheckCode
) {
882 case VarCheckDuplicate
:
883 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_DUPLICATE_COMMAND
), gShellNetwork1HiiHandle
, VarArg
->Arg
);
886 case VarCheckConflict
:
887 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_CONFLICT_COMMAND
), gShellNetwork1HiiHandle
, VarArg
->Arg
);
890 case VarCheckUnknown
:
892 // To handle unsupported option.
894 TempString
= PermanentString
;
895 if (StringNoCaseCompare(&VarArg
->Arg
, &TempString
) == 0) {
896 ShellPrintHiiEx(-1, -1, NULL
,STRING_TOKEN (STR_IFCONFIG_UNSUPPORTED_OPTION
), gShellNetwork1HiiHandle
, PermanentString
);
901 // To handle unknown option.
903 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_UNKNOWN_COMMAND
), gShellNetwork1HiiHandle
, VarArg
->Arg
);
910 VarArg
= VarArg
->Next
;
915 // Process valid variables.
917 if (StrCmp(VarArg
->Arg
, L
"dhcp") == 0) {
919 // Set dhcp config policy
921 Policy
= Ip4Config2PolicyDhcp
;
922 Status
= IfCb
->IfCfg
->SetData (
924 Ip4Config2DataTypePolicy
,
925 sizeof (EFI_IP4_CONFIG2_POLICY
),
928 if (EFI_ERROR(Status
)) {
929 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_GEN_ERR_AD
), gShellNetwork1HiiHandle
, L
"ifconfig");
930 ShellStatus
= SHELL_ACCESS_DENIED
;
934 VarArg
= VarArg
->Next
;
936 } else if (StrCmp (VarArg
->Arg
, L
"static") == 0) {
937 VarArg
= VarArg
->Next
;
938 if (VarArg
== NULL
) {
939 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_LACK_COMMAND
), gShellNetwork1HiiHandle
);
940 ShellStatus
= SHELL_INVALID_PARAMETER
;
944 ZeroMem (&ManualAddress
, sizeof (ManualAddress
));
947 // Get manual IP address.
949 Status
= NetLibStrToIp4 (VarArg
->Arg
, &ManualAddress
.Address
);
950 if (EFI_ERROR(Status
)) {
951 ShellPrintHiiEx(-1, -1, NULL
,STRING_TOKEN (STR_IFCONFIG_INVALID_IPADDRESS
), gShellNetwork1HiiHandle
, VarArg
->Arg
);
952 ShellStatus
= SHELL_INVALID_PARAMETER
;
959 VarArg
= VarArg
->Next
;
960 if (VarArg
== NULL
) {
961 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_LACK_COMMAND
), gShellNetwork1HiiHandle
);
962 ShellStatus
= SHELL_INVALID_PARAMETER
;
966 Status
= NetLibStrToIp4 (VarArg
->Arg
, &ManualAddress
.SubnetMask
);
967 if (EFI_ERROR(Status
)) {
968 ShellPrintHiiEx(-1, -1, NULL
,STRING_TOKEN (STR_IFCONFIG_INVALID_IPADDRESS
), gShellNetwork1HiiHandle
, VarArg
->Arg
);
969 ShellStatus
= SHELL_INVALID_PARAMETER
;
976 VarArg
= VarArg
->Next
;
977 if (VarArg
== NULL
) {
978 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_LACK_COMMAND
), gShellNetwork1HiiHandle
);
979 ShellStatus
= SHELL_INVALID_PARAMETER
;
983 Status
= NetLibStrToIp4 (VarArg
->Arg
, &Gateway
);
984 if (EFI_ERROR(Status
)) {
985 ShellPrintHiiEx(-1, -1, NULL
,STRING_TOKEN (STR_IFCONFIG_INVALID_IPADDRESS
), gShellNetwork1HiiHandle
, VarArg
->Arg
);
986 ShellStatus
= SHELL_INVALID_PARAMETER
;
991 // Set manual config policy.
993 Policy
= Ip4Config2PolicyStatic
;
994 Status
= IfCb
->IfCfg
->SetData (
996 Ip4Config2DataTypePolicy
,
997 sizeof (EFI_IP4_CONFIG2_POLICY
),
1000 if (EFI_ERROR(Status
)) {
1001 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_GEN_ERR_AD
), gShellNetwork1HiiHandle
, L
"ifconfig");
1002 ShellStatus
= SHELL_ACCESS_DENIED
;
1007 // Set Manual Address.
1009 IsAddressOk
= FALSE
;
1011 Status
= IfCb
->IfCfg
->RegisterDataNotify (
1013 Ip4Config2DataTypeManualAddress
,
1016 if (EFI_ERROR (Status
)) {
1017 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_SET_ADDR_FAILED
), gShellNetwork1HiiHandle
, Status
);
1018 ShellStatus
= SHELL_ACCESS_DENIED
;
1022 DataSize
= sizeof (EFI_IP4_CONFIG2_MANUAL_ADDRESS
);
1024 Status
= IfCb
->IfCfg
->SetData (
1026 Ip4Config2DataTypeManualAddress
,
1031 if (Status
== EFI_NOT_READY
) {
1032 gBS
->SetTimer (TimeOutEvt
, TimerRelative
, 50000000);
1034 while (EFI_ERROR (gBS
->CheckEvent (TimeOutEvt
))) {
1036 Status
= EFI_SUCCESS
;
1042 IfCb
->IfCfg
->UnregisterDataNotify (
1044 Ip4Config2DataTypeManualAddress
,
1048 if (EFI_ERROR (Status
)) {
1049 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_SET_ADDR_FAILED
), gShellNetwork1HiiHandle
, Status
);
1050 ShellStatus
= SHELL_ACCESS_DENIED
;
1057 DataSize
= sizeof (EFI_IPv4_ADDRESS
);
1059 Status
= IfCb
->IfCfg
->SetData (
1061 Ip4Config2DataTypeGateway
,
1065 if (EFI_ERROR (Status
)) {
1066 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_SET_ADDR_FAILED
), gShellNetwork1HiiHandle
, Status
);
1067 ShellStatus
= SHELL_ACCESS_DENIED
;
1071 VarArg
= VarArg
->Next
;
1073 } else if (StrCmp (VarArg
->Arg
, L
"dns") == 0) {
1075 // Get DNS addresses.
1077 VarArg
= VarArg
->Next
;
1080 while (Tmp
!= NULL
) {
1085 Dns
= AllocatePool (Index
* sizeof (EFI_IPv4_ADDRESS
));
1086 ASSERT(Dns
!= NULL
);
1089 while (Tmp
!= NULL
) {
1090 Status
= NetLibStrToIp4 (Tmp
->Arg
, Dns
+ Index
);
1091 if (EFI_ERROR(Status
)) {
1092 ShellPrintHiiEx(-1, -1, NULL
,STRING_TOKEN (STR_IFCONFIG_INVALID_IPADDRESS
), gShellNetwork1HiiHandle
, Tmp
->Arg
);
1093 ShellStatus
= SHELL_INVALID_PARAMETER
;
1103 // Set DNS addresses.
1105 DataSize
= Index
* sizeof (EFI_IPv4_ADDRESS
);
1107 Status
= IfCb
->IfCfg
->SetData (
1109 Ip4Config2DataTypeDnsServer
,
1113 if (EFI_ERROR (Status
)) {
1114 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_GEN_ERR_AD
), gShellNetwork1HiiHandle
, L
"ifconfig");
1115 ShellStatus
= SHELL_ACCESS_DENIED
;
1131 The ifconfig command main process.
1133 @param[in] Private The pointer of IFCONFIG_PRIVATE_DATA.
1135 @retval SHELL_SUCCESS ifconfig command processed successfully.
1136 @retval others The ifconfig command process failed.
1141 IN IFCONFIG_PRIVATE_DATA
*Private
1145 SHELL_STATUS ShellStatus
;
1147 ShellStatus
= SHELL_SUCCESS
;
1150 // Get configure information of all interfaces.
1152 Status
= IfConfigGetInterfaceInfo (
1156 if (EFI_ERROR (Status
)) {
1157 ShellStatus
= SHELL_NOT_FOUND
;
1161 switch (Private
->OpCode
) {
1162 case IfConfigOpList
:
1163 ShellStatus
= IfConfigShowInterfaceInfo (&Private
->IfList
);
1166 case IfConfigOpClear
:
1167 ShellStatus
= IfConfigClearInterfaceInfo (&Private
->IfList
, Private
->IfName
);
1171 ShellStatus
= IfConfigSetInterfaceInfo (&Private
->IfList
, Private
->VarArg
);
1175 ShellStatus
= SHELL_UNSUPPORTED
;
1183 The ifconfig command cleanup process, free the allocated memory.
1185 @param[in] Private The pointer of IFCONFIG_PRIVATE_DATA.
1190 IN IFCONFIG_PRIVATE_DATA
*Private
1194 LIST_ENTRY
*NextEntry
;
1195 IFCONFIG_INTERFACE_CB
*IfCb
;
1199 ASSERT (Private
!= NULL
);
1202 // Clean the list which save the set config Args.
1204 if (Private
->VarArg
!= NULL
) {
1205 ArgHead
= Private
->VarArg
;
1207 while (ArgHead
->Next
!= NULL
) {
1208 ArgNode
= ArgHead
->Next
;
1216 if (Private
->IfName
!= NULL
) {
1217 FreePool (Private
->IfName
);
1221 // Clean the IFCONFIG_INTERFACE_CB list.
1223 NET_LIST_FOR_EACH_SAFE (Entry
, NextEntry
, &Private
->IfList
) {
1224 IfCb
= NET_LIST_USER_STRUCT (Entry
, IFCONFIG_INTERFACE_CB
, Link
);
1226 RemoveEntryList (&IfCb
->Link
);
1228 if (IfCb
->IfInfo
!= NULL
) {
1230 FreePool (IfCb
->IfInfo
);
1240 Function for 'ifconfig' command.
1242 @param[in] ImageHandle Handle to the Image (NULL if Internal).
1243 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
1245 @retval EFI_SUCCESS ifconfig command processed successfully.
1246 @retval others The ifconfig command process failed.
1251 ShellCommandRunIfconfig (
1252 IN EFI_HANDLE ImageHandle
,
1253 IN EFI_SYSTEM_TABLE
*SystemTable
1257 IFCONFIG_PRIVATE_DATA
*Private
;
1258 LIST_ENTRY
*ParamPackage
;
1259 SHELL_STATUS ShellStatus
;
1260 CONST CHAR16
*ValueStr
;
1262 CHAR16
*ProblemParam
;
1265 Status
= EFI_INVALID_PARAMETER
;
1267 ShellStatus
= SHELL_SUCCESS
;
1269 Status
= ShellCommandLineParseEx (mIfConfigCheckList
, &ParamPackage
, &ProblemParam
, TRUE
, FALSE
);
1270 if (EFI_ERROR (Status
)) {
1271 if (Status
== EFI_VOLUME_CORRUPTED
&& ProblemParam
!= NULL
) {
1272 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_GEN_PARAM_INV
), gShellNetwork1HiiHandle
, L
"ifconfig", ProblemParam
);
1273 FreePool(ProblemParam
);
1274 ShellStatus
= SHELL_INVALID_PARAMETER
;
1283 // To handle unsupported option.
1285 if (ShellCommandLineGetFlag (ParamPackage
, L
"-c")) {
1286 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_UNSUPPORTED_OPTION
), gShellNetwork1HiiHandle
,L
"-c");
1287 ShellStatus
= SHELL_INVALID_PARAMETER
;
1292 // To handle no option.
1294 if (!ShellCommandLineGetFlag (ParamPackage
, L
"-r") && !ShellCommandLineGetFlag (ParamPackage
, L
"-s") &&
1295 !ShellCommandLineGetFlag (ParamPackage
, L
"-l")) {
1296 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_LACK_OPTION
), gShellNetwork1HiiHandle
);
1297 ShellStatus
= SHELL_INVALID_PARAMETER
;
1302 // To handle conflict options.
1304 if (((ShellCommandLineGetFlag (ParamPackage
, L
"-r")) && (ShellCommandLineGetFlag (ParamPackage
, L
"-s"))) ||
1305 ((ShellCommandLineGetFlag (ParamPackage
, L
"-r")) && (ShellCommandLineGetFlag (ParamPackage
, L
"-l"))) ||
1306 ((ShellCommandLineGetFlag (ParamPackage
, L
"-s")) && (ShellCommandLineGetFlag (ParamPackage
, L
"-l")))) {
1307 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_GEN_PARAM_CON
), gShellNetwork1HiiHandle
, L
"ifconfig");
1308 ShellStatus
= SHELL_INVALID_PARAMETER
;
1312 Private
= AllocateZeroPool (sizeof (IFCONFIG_PRIVATE_DATA
));
1313 if (Private
== NULL
) {
1314 ShellStatus
= SHELL_OUT_OF_RESOURCES
;
1318 InitializeListHead (&Private
->IfList
);
1321 // To get interface name for the list option.
1323 if (ShellCommandLineGetFlag (ParamPackage
, L
"-l")) {
1324 Private
->OpCode
= IfConfigOpList
;
1325 ValueStr
= ShellCommandLineGetValue (ParamPackage
, L
"-l");
1326 if (ValueStr
!= NULL
) {
1327 Str
= AllocateCopyPool (StrSize (ValueStr
), ValueStr
);
1328 ASSERT (Str
!= NULL
);
1329 Private
->IfName
= Str
;
1334 // To get interface name for the clear option.
1336 if (ShellCommandLineGetFlag (ParamPackage
, L
"-r")) {
1337 Private
->OpCode
= IfConfigOpClear
;
1338 ValueStr
= ShellCommandLineGetValue (ParamPackage
, L
"-r");
1339 if (ValueStr
!= NULL
) {
1340 Str
= AllocateCopyPool (StrSize (ValueStr
), ValueStr
);
1341 ASSERT (Str
!= NULL
);
1342 Private
->IfName
= Str
;
1347 // To get interface name and corresponding Args for the set option.
1349 if (ShellCommandLineGetFlag (ParamPackage
, L
"-s")) {
1350 ValueStr
= ShellCommandLineGetValue (ParamPackage
, L
"-s");
1351 if (ValueStr
== NULL
) {
1352 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_LACK_INTERFACE
), gShellNetwork1HiiHandle
);
1353 ShellStatus
= SHELL_INVALID_PARAMETER
;
1358 // To split the configuration into multi-section.
1360 ArgList
= SplitStrToList (ValueStr
, L
' ');
1361 ASSERT (ArgList
!= NULL
);
1363 Private
->OpCode
= IfConfigOpSet
;
1364 Private
->IfName
= ArgList
->Arg
;
1366 Private
->VarArg
= ArgList
->Next
;
1368 if (Private
->IfName
== NULL
|| Private
->VarArg
== NULL
) {
1369 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_IFCONFIG_LACK_COMMAND
), gShellNetwork1HiiHandle
);
1370 ShellStatus
= SHELL_INVALID_PARAMETER
;
1376 // Main process of ifconfig.
1378 ShellStatus
= IfConfig (Private
);
1382 ShellCommandLineFreeVarList (ParamPackage
);
1384 if (Private
!= NULL
) {
1385 IfConfigCleanup (Private
);