]> git.proxmox.com Git - mirror_edk2.git/blame - NetworkPkg/WifiConnectionManagerDxe/WifiConnectionMgrHiiConfigAccess.c
BaseTools: Add python3-distutils Ubuntu package checking
[mirror_edk2.git] / NetworkPkg / WifiConnectionManagerDxe / WifiConnectionMgrHiiConfigAccess.c
CommitLineData
90b24889
WF
1/** @file\r
2 The Hii functions for WiFi Connection Manager.\r
3\r
4 Copyright (c) 2019, Intel Corporation. All rights reserved.<BR>\r
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#include "WifiConnectionMgrDxe.h"\r
17\r
18CHAR16 mVendorStorageName[] = L"WIFI_MANAGER_IFR_NVDATA";\r
19\r
20HII_VENDOR_DEVICE_PATH mWifiMgrDxeHiiVendorDevicePath = {\r
21 {\r
22 {\r
23 HARDWARE_DEVICE_PATH,\r
24 HW_VENDOR_DP,\r
25 {\r
26 (UINT8) (sizeof (VENDOR_DEVICE_PATH)),\r
27 (UINT8) ((sizeof (VENDOR_DEVICE_PATH)) >> 8)\r
28 }\r
29 },\r
30 WIFI_CONNECTION_MANAGER_CONFIG_GUID\r
31 },\r
32 {\r
33 END_DEVICE_PATH_TYPE,\r
34 END_ENTIRE_DEVICE_PATH_SUBTYPE,\r
35 {\r
36 (UINT8) (END_DEVICE_PATH_LENGTH),\r
37 (UINT8) ((END_DEVICE_PATH_LENGTH) >> 8)\r
38 }\r
39 }\r
40};\r
41\r
42//\r
43// HII Config Access Protocol instance\r
44//\r
45GLOBAL_REMOVE_IF_UNREFERENCED\r
46EFI_HII_CONFIG_ACCESS_PROTOCOL gWifiMgrDxeHiiConfigAccess = {\r
47 WifiMgrDxeHiiConfigAccessExtractConfig,\r
48 WifiMgrDxeHiiConfigAccessRouteConfig,\r
49 WifiMgrDxeHiiConfigAccessCallback\r
50};\r
51\r
52CHAR16* mSecurityType[] = {\r
53 L"OPEN ",\r
54 L"WPA-Enterprise ",\r
55 L"WPA2-Enterprise",\r
56 L"WPA-Personal ",\r
57 L"WPA2-Personal ",\r
58 L"WEP ",\r
59 L"UnKnown "\r
60};\r
61\r
62CHAR16* mSignalStrengthBar[] = {\r
63 L"[-----]",\r
64 L"[*----]",\r
65 L"[**---]",\r
66 L"[***--]",\r
67 L"[****-]",\r
68 L"[*****]"\r
69};\r
70\r
71#define RSSI_TO_SIGNAL_STRENGTH_BAR(Rssi) mSignalStrengthBar[((Rssi + 19)/20)]\r
72\r
73#define NET_LIST_FOR_EACH_FROM_NODE(Entry, Node, ListHead) \\r
74 for(Entry = Node->ForwardLink; Entry != (ListHead); Entry = Entry->ForwardLink)\r
75\r
76extern EFI_GUID gWifiConfigFormSetGuid;\r
77\r
78/**\r
79 Create Hii Extend Label OpCode as the start opcode and end opcode.\r
80 The caller is responsible for freeing the OpCode with HiiFreeOpCodeHandle().\r
81\r
82 @param[in] StartLabelNumber The number of start label.\r
83 @param[out] StartOpCodeHandle Points to the start opcode handle.\r
84 @param[out] EndOpCodeHandle Points to the end opcode handle.\r
85\r
86 @retval EFI_OUT_OF_RESOURCES Do not have sufficient resource to finish this\r
87 operation.\r
88 @retval EFI_INVALID_PARAMETER Any input parameter is invalid.\r
89 @retval EFI_SUCCESS The operation is completed successfully.\r
90 @retval Other Errors Returned errors when updating the HII form.\r
91\r
92**/\r
93EFI_STATUS\r
94WifiMgrCreateOpCode (\r
95 IN UINT16 StartLabelNumber,\r
96 OUT VOID **StartOpCodeHandle,\r
97 OUT VOID **EndOpCodeHandle\r
98 )\r
99{\r
100 EFI_STATUS Status;\r
101 EFI_IFR_GUID_LABEL *InternalStartLabel;\r
102 EFI_IFR_GUID_LABEL *InternalEndLabel;\r
103\r
104 if (StartOpCodeHandle == NULL || EndOpCodeHandle == NULL) {\r
105 return EFI_INVALID_PARAMETER;\r
106 }\r
107\r
108 Status = EFI_OUT_OF_RESOURCES;\r
109 *StartOpCodeHandle = NULL;\r
110 *EndOpCodeHandle = NULL;\r
111\r
112 //\r
113 // Initialize the container for dynamic opcodes.\r
114 //\r
115 *StartOpCodeHandle = HiiAllocateOpCodeHandle ();\r
116 if (*StartOpCodeHandle == NULL) {\r
117 goto Exit;\r
118 }\r
119 *EndOpCodeHandle = HiiAllocateOpCodeHandle ();\r
120 if (*EndOpCodeHandle == NULL) {\r
121 goto Exit;\r
122 }\r
123\r
124 //\r
125 // Create Hii Extend Label OpCode as the start opcode.\r
126 //\r
127 InternalStartLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (\r
128 *StartOpCodeHandle,\r
129 &gEfiIfrTianoGuid,\r
130 NULL,\r
131 sizeof (EFI_IFR_GUID_LABEL)\r
132 );\r
133 if (InternalStartLabel == NULL) {\r
134 goto Exit;\r
135 }\r
136 InternalStartLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
137 InternalStartLabel->Number = StartLabelNumber;\r
138\r
139 //\r
140 // Create Hii Extend Label OpCode as the end opcode.\r
141 //\r
142 InternalEndLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (\r
143 *EndOpCodeHandle,\r
144 &gEfiIfrTianoGuid,\r
145 NULL,\r
146 sizeof (EFI_IFR_GUID_LABEL)\r
147 );\r
148 if (InternalEndLabel == NULL) {\r
149 goto Exit;\r
150 }\r
151 InternalEndLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
152 InternalEndLabel->Number = LABEL_END;\r
153\r
154 return EFI_SUCCESS;\r
155\r
156Exit:\r
157\r
158 if (*StartOpCodeHandle != NULL) {\r
159 HiiFreeOpCodeHandle (*StartOpCodeHandle);\r
160 }\r
161 if (*EndOpCodeHandle != NULL) {\r
162 HiiFreeOpCodeHandle (*EndOpCodeHandle);\r
163 }\r
164 return Status;\r
165}\r
166\r
167/**\r
168 Display the Nic list contains all available Nics.\r
169\r
170 @param[in] Private The pointer to the global private data structure.\r
171\r
172 @retval EFI_INVALID_PARAMETER Any input parameter is invalid.\r
173 @retval EFI_SUCCESS The operation is completed successfully.\r
174\r
175**/\r
176EFI_STATUS\r
177WifiMgrShowNicList (\r
178 IN WIFI_MGR_PRIVATE_DATA *Private\r
179)\r
180{\r
181 EFI_STATUS Status;\r
182 CHAR16 MacString[WIFI_MGR_MAX_MAC_STRING_LEN];\r
183 CHAR16 PortString[WIFI_STR_MAX_SIZE];\r
184 EFI_STRING_ID PortTitleToken;\r
185 EFI_STRING_ID PortTitleHelpToken;\r
186 WIFI_MGR_DEVICE_DATA *Nic;\r
187 LIST_ENTRY *Entry;\r
188 VOID *StartOpCodeHandle;\r
189 VOID *EndOpCodeHandle;\r
190\r
191 if (Private == NULL) {\r
192 return EFI_INVALID_PARAMETER;\r
193 }\r
194\r
195 Status = WifiMgrCreateOpCode (\r
196 LABEL_MAC_ENTRY,\r
197 &StartOpCodeHandle,\r
198 &EndOpCodeHandle\r
199 );\r
200 if (EFI_ERROR (Status)) {\r
201 return Status;\r
202 }\r
203\r
204 NET_LIST_FOR_EACH (Entry, &Private->NicList) {\r
205 Nic = NET_LIST_USER_STRUCT_S (Entry, WIFI_MGR_DEVICE_DATA, Link, WIFI_MGR_DEVICE_DATA_SIGNATURE);\r
206 WifiMgrMacAddrToStr (&Nic->MacAddress, sizeof (MacString), MacString);\r
207 UnicodeSPrint (PortString, sizeof (PortString), L"MAC %s", MacString);\r
208 PortTitleToken = HiiSetString (\r
209 Private->RegisteredHandle,\r
210 0,\r
211 PortString,\r
212 NULL\r
213 );\r
214 if (PortTitleToken == 0) {\r
215 Status = EFI_INVALID_PARAMETER;\r
216 goto Exit;\r
217 }\r
218\r
219 UnicodeSPrint (PortString, sizeof (PortString), L"MAC Address");\r
220 PortTitleHelpToken = HiiSetString (\r
221 Private->RegisteredHandle,\r
222 0,\r
223 PortString,\r
224 NULL\r
225 );\r
226 if (PortTitleHelpToken == 0) {\r
227 Status = EFI_INVALID_PARAMETER;\r
228 goto Exit;\r
229 }\r
230\r
231 HiiCreateGotoOpCode (\r
232 StartOpCodeHandle,\r
233 FORMID_WIFI_MAINPAGE,\r
234 PortTitleToken,\r
235 PortTitleHelpToken,\r
236 EFI_IFR_FLAG_CALLBACK,\r
237 (UINT16) (KEY_MAC_ENTRY_BASE + Nic->NicIndex)\r
238 );\r
239 }\r
240\r
241 Status = HiiUpdateForm (\r
242 Private->RegisteredHandle, // HII handle\r
243 &gWifiConfigFormSetGuid, // Formset GUID\r
244 FORMID_MAC_SELECTION, // Form ID\r
245 StartOpCodeHandle, // Label for where to insert opcodes\r
246 EndOpCodeHandle // Replace data\r
247 );\r
248\r
249Exit:\r
250\r
251 HiiFreeOpCodeHandle (StartOpCodeHandle);\r
252 HiiFreeOpCodeHandle (EndOpCodeHandle);\r
253 return Status;\r
254}\r
255\r
256/**\r
257 Retreive the unicode string of the AKM Suite list of a profile.\r
258 The caller is responsible for freeing the string with FreePool().\r
259\r
260 @param[in] Profile The network profile contains a AKM suite list.\r
261\r
262 @return the unicode string of AKM suite list or "None".\r
263\r
264**/\r
265CHAR16*\r
266WifiMgrGetStrAKMList (\r
267 IN WIFI_MGR_NETWORK_PROFILE *Profile\r
268)\r
269{\r
270 UINT8 Index;\r
271 UINT16 AKMSuiteCount;\r
272 CHAR16 *AKMListDisplay;\r
273\r
274 AKMListDisplay = NULL;\r
275 if (Profile == NULL || Profile->Network.AKMSuite == NULL) {\r
276 goto Exit;\r
277 }\r
278\r
279 AKMSuiteCount = Profile->Network.AKMSuite->AKMSuiteCount;\r
280 if (AKMSuiteCount != 0) {\r
281\r
282 //\r
283 // Current AKM Suite is between 1-9\r
284 //\r
285 AKMListDisplay = (CHAR16 *) AllocateZeroPool(sizeof (CHAR16) * AKMSuiteCount * 2);\r
286 if (AKMListDisplay != NULL) {\r
287 for (Index = 0; Index < AKMSuiteCount; Index ++) {\r
288 UnicodeSPrint (\r
289 AKMListDisplay + (Index * 2),\r
290 sizeof (CHAR16) * 2,\r
291 L"%d ",\r
292 Profile->Network.AKMSuite->AKMSuiteList[Index].SuiteType\r
293 );\r
294 if (Index == AKMSuiteCount - 1) {\r
295 *(AKMListDisplay + (Index * 2 + 1)) = L'\0';\r
296 }\r
297 }\r
298 }\r
299 }\r
300\r
301Exit:\r
302\r
303 if (AKMListDisplay == NULL) {\r
304 AKMListDisplay = AllocateCopyPool (sizeof (L"None"), L"None");\r
305 }\r
306 return AKMListDisplay;\r
307}\r
308\r
309/**\r
310 Retreive the unicode string of the Cipher Suite list of a profile.\r
311 The caller is responsible for freeing the string with FreePool().\r
312\r
313 @param[in] Profile The network profile contains a Cipher suite list.\r
314\r
315 @return the unicode string of Cipher suite list or "None".\r
316\r
317**/\r
318CHAR16*\r
319WifiMgrGetStrCipherList (\r
320 IN WIFI_MGR_NETWORK_PROFILE *Profile\r
321)\r
322{\r
323 UINT8 Index;\r
324 UINT16 CipherSuiteCount;\r
325 CHAR16 *CipherListDisplay;\r
326\r
327 CipherListDisplay = NULL;\r
328 if (Profile == NULL || Profile->Network.CipherSuite == NULL) {\r
329 goto Exit;\r
330 }\r
331\r
332 CipherSuiteCount = Profile->Network.CipherSuite->CipherSuiteCount;\r
333 if (CipherSuiteCount != 0) {\r
334\r
335 //\r
336 // Current Cipher Suite is between 1-9\r
337 //\r
338 CipherListDisplay = (CHAR16 *) AllocateZeroPool(sizeof (CHAR16) * CipherSuiteCount * 2);\r
339 if (CipherListDisplay != NULL) {\r
340 for (Index = 0; Index < CipherSuiteCount; Index ++) {\r
341 UnicodeSPrint (\r
342 CipherListDisplay + (Index * 2),\r
343 sizeof (CHAR16) * 2,\r
344 L"%d ",\r
345 Profile->Network.CipherSuite->CipherSuiteList[Index].SuiteType\r
346 );\r
347 if (Index == CipherSuiteCount - 1) {\r
348 *(CipherListDisplay + (Index * 2 + 1)) = L'\0';\r
349 }\r
350 }\r
351 }\r
352 }\r
353\r
354Exit:\r
355\r
356 if (CipherListDisplay == NULL) {\r
357 CipherListDisplay = AllocateCopyPool (sizeof (L"None"), L"None");\r
358 }\r
359 return CipherListDisplay;\r
360}\r
361\r
362/**\r
363 Refresh the network list display of the current Nic.\r
364\r
365 @param[in] Private The pointer to the global private data structure.\r
366 @param[out] IfrNvData The IFR NV data.\r
367\r
368 @retval EFI_SUCCESS The operation is completed successfully.\r
369 @retval EFI_OUT_OF_RESOURCES Failed to allocate memory.\r
370 @retval Other Errors Returned errors when creating Opcodes or updating the\r
371 Hii form.\r
372\r
373**/\r
374EFI_STATUS\r
375WifiMgrRefreshNetworkList (\r
376 IN WIFI_MGR_PRIVATE_DATA *Private,\r
377 OUT WIFI_MANAGER_IFR_NVDATA *IfrNvData\r
378 )\r
379{\r
380 EFI_STATUS Status;\r
381 EFI_TPL OldTpl;\r
382 UINT32 AvailableCount;\r
383 EFI_STRING_ID PortPromptToken;\r
384 EFI_STRING_ID PortTextToken;\r
385 EFI_STRING_ID PortHelpToken;\r
386 WIFI_MGR_NETWORK_PROFILE *Profile;\r
387 LIST_ENTRY *Entry;\r
388 VOID *StartOpCodeHandle;\r
389 VOID *EndOpCodeHandle;\r
390 CHAR16 *AKMListDisplay;\r
391 CHAR16 *CipherListDisplay;\r
392 CHAR16 PortString[WIFI_STR_MAX_SIZE];\r
393 UINTN PortStringSize;\r
394 WIFI_MGR_NETWORK_PROFILE *ConnectedProfile;\r
395\r
396 if (Private->CurrentNic == NULL) {\r
397 return EFI_SUCCESS;\r
398 }\r
399\r
400 Status = WifiMgrCreateOpCode (\r
401 LABEL_NETWORK_LIST_ENTRY,\r
402 &StartOpCodeHandle,\r
403 &EndOpCodeHandle\r
404 );\r
405 if (EFI_ERROR (Status)) {\r
406 return Status;\r
407 }\r
408\r
409 OldTpl = gBS->RaiseTPL (TPL_CALLBACK);\r
410 AvailableCount = 0;\r
411 PortStringSize = sizeof (PortString);\r
412 ConnectedProfile = NULL;\r
413 AKMListDisplay = NULL;\r
414 CipherListDisplay = NULL;\r
415\r
416 if (Private->CurrentNic->ConnectState == WifiMgrConnectedToAp) {\r
417\r
418 //\r
419 // Display the current connected network.\r
420 // Find the current operate network under connected status.\r
421 //\r
422 if (Private->CurrentNic->CurrentOperateNetwork != NULL &&\r
423 Private->CurrentNic->CurrentOperateNetwork->IsAvailable) {\r
424\r
425 Profile = Private->CurrentNic->CurrentOperateNetwork;\r
426 AvailableCount ++;\r
427\r
428 AKMListDisplay = WifiMgrGetStrAKMList (Profile);\r
429 if (AKMListDisplay == NULL) {\r
430 Status = EFI_OUT_OF_RESOURCES;\r
431 goto Exit;\r
432 }\r
433 CipherListDisplay = WifiMgrGetStrCipherList(Profile);\r
434 if (CipherListDisplay == NULL) {\r
435 Status = EFI_OUT_OF_RESOURCES;\r
436 goto Exit;\r
437 }\r
438\r
439 UnicodeSPrint (PortString, PortStringSize, L"%s (Connected)", Profile->SSId);\r
440 PortPromptToken = HiiSetString (Private->RegisteredHandle, 0, PortString, NULL);\r
441\r
442 if (Profile->SecurityType == SECURITY_TYPE_NONE) {\r
443 PortHelpToken = 0;\r
444 } else {\r
445 UnicodeSPrint (PortString, PortStringSize, L"AKMSuite: %s CipherSuite: %s", AKMListDisplay, CipherListDisplay);\r
446 PortHelpToken = HiiSetString (Private->RegisteredHandle, 0, PortString, NULL);\r
447 }\r
448 FreePool (AKMListDisplay);\r
449 FreePool (CipherListDisplay);\r
450\r
451 HiiCreateGotoOpCode (\r
452 StartOpCodeHandle,\r
453 FORMID_CONNECT_NETWORK,\r
454 PortPromptToken,\r
455 PortHelpToken,\r
456 EFI_IFR_FLAG_CALLBACK,\r
457 (UINT16) (KEY_AVAILABLE_NETWORK_ENTRY_BASE + Profile->ProfileIndex)\r
458 );\r
459\r
460 UnicodeSPrint (\r
461 PortString,\r
462 PortStringSize,\r
463 L"%s %s %s",\r
464 (Profile->SecurityType != SECURITY_TYPE_NONE ? L"Secured" : L"Open "),\r
465 mSecurityType[Profile->SecurityType],\r
466 RSSI_TO_SIGNAL_STRENGTH_BAR(Profile->NetworkQuality)\r
467 );\r
468 PortTextToken = HiiSetString (Private->RegisteredHandle, 0, PortString, NULL);\r
469\r
470 HiiCreateTextOpCode (\r
471 StartOpCodeHandle,\r
472 PortTextToken,\r
473 0,\r
474 0\r
475 );\r
476\r
477 ConnectedProfile = Profile;\r
478 } else {\r
479 Private->CurrentNic->HasDisconnectPendingNetwork = TRUE;\r
480 }\r
481 }\r
482\r
483 //\r
484 // Display all supported available networks.\r
485 //\r
486 NET_LIST_FOR_EACH (Entry, &Private->CurrentNic->ProfileList) {\r
487\r
488 Profile = NET_LIST_USER_STRUCT_S (\r
489 Entry,\r
490 WIFI_MGR_NETWORK_PROFILE,\r
491 Link,\r
492 WIFI_MGR_PROFILE_SIGNATURE\r
493 );\r
494 if (ConnectedProfile == Profile) {\r
495 continue;\r
496 }\r
497 if (Profile->IsAvailable && Profile->CipherSuiteSupported) {\r
498\r
499 AvailableCount ++;\r
500\r
501 AKMListDisplay = WifiMgrGetStrAKMList (Profile);\r
502 if (AKMListDisplay == NULL) {\r
503 Status = EFI_OUT_OF_RESOURCES;\r
504 goto Exit;\r
505 }\r
506 CipherListDisplay = WifiMgrGetStrCipherList(Profile);\r
507 if (CipherListDisplay == NULL) {\r
508 Status = EFI_OUT_OF_RESOURCES;\r
509 goto Exit;\r
510 }\r
511\r
512 PortPromptToken = HiiSetString (Private->RegisteredHandle, 0, Profile->SSId, NULL);\r
513 if (PortPromptToken == 0) {\r
514 Status = EFI_OUT_OF_RESOURCES;\r
515 goto Exit;\r
516 }\r
517\r
518 if (Profile->SecurityType == SECURITY_TYPE_NONE) {\r
519 PortHelpToken = 0;\r
520 } else {\r
521 UnicodeSPrint (\r
522 PortString,\r
523 PortStringSize,\r
524 L"AKMSuite: %s CipherSuite: %s",\r
525 AKMListDisplay, CipherListDisplay\r
526 );\r
527 PortHelpToken = HiiSetString (Private->RegisteredHandle, 0, PortString, NULL);\r
528 if (PortHelpToken == 0) {\r
529 Status = EFI_OUT_OF_RESOURCES;\r
530 goto Exit;\r
531 }\r
532 }\r
533 FreePool (AKMListDisplay);\r
534 FreePool (CipherListDisplay);\r
535\r
536 HiiCreateGotoOpCode (\r
537 StartOpCodeHandle,\r
538 FORMID_CONNECT_NETWORK,\r
539 PortPromptToken,\r
540 PortHelpToken,\r
541 EFI_IFR_FLAG_CALLBACK,\r
542 (UINT16) (KEY_AVAILABLE_NETWORK_ENTRY_BASE + Profile->ProfileIndex)\r
543 );\r
544\r
545 UnicodeSPrint (\r
546 PortString,\r
547 PortStringSize,\r
548 L"%s %s %s",\r
549 (Profile->SecurityType != SECURITY_TYPE_NONE ? L"Secured" : L"Open "),\r
550 mSecurityType[Profile->SecurityType],\r
551 RSSI_TO_SIGNAL_STRENGTH_BAR(Profile->NetworkQuality)\r
552 );\r
553 PortTextToken = HiiSetString (Private->RegisteredHandle, 0, PortString, NULL);\r
554 if (PortTextToken == 0) {\r
555 Status = EFI_OUT_OF_RESOURCES;\r
556 goto Exit;\r
557 }\r
558 HiiCreateTextOpCode (\r
559 StartOpCodeHandle,\r
560 PortTextToken,\r
561 0,\r
562 0\r
563 );\r
564 }\r
565 }\r
566\r
567 //\r
568 // Display all Unsupported available networks.\r
569 //\r
570 NET_LIST_FOR_EACH (Entry, &Private->CurrentNic->ProfileList) {\r
571\r
572 Profile = NET_LIST_USER_STRUCT_S (\r
573 Entry,\r
574 WIFI_MGR_NETWORK_PROFILE,\r
575 Link,\r
576 WIFI_MGR_PROFILE_SIGNATURE\r
577 );\r
578 if (ConnectedProfile == Profile) {\r
579 continue;\r
580 }\r
581 if (Profile->IsAvailable && !Profile->CipherSuiteSupported) {\r
582\r
583 AvailableCount ++;\r
584\r
585 AKMListDisplay = WifiMgrGetStrAKMList (Profile);\r
586 if (AKMListDisplay == NULL) {\r
587 Status = EFI_OUT_OF_RESOURCES;\r
588 goto Exit;\r
589 }\r
590 CipherListDisplay = WifiMgrGetStrCipherList(Profile);\r
591 if (CipherListDisplay == NULL) {\r
592 Status = EFI_OUT_OF_RESOURCES;\r
593 goto Exit;\r
594 }\r
595\r
596 PortPromptToken = HiiSetString (Private->RegisteredHandle, 0, Profile->SSId, NULL);\r
597\r
598 if (Profile->AKMSuiteSupported) {\r
599 UnicodeSPrint (\r
600 PortString,\r
601 PortStringSize,\r
602 L"AKMSuite: %s CipherSuite(UnSupported): %s",\r
603 AKMListDisplay, CipherListDisplay\r
604 );\r
605 } else {\r
606 UnicodeSPrint (\r
607 PortString,\r
608 PortStringSize,\r
609 L"AKMSuite(UnSupported): %s CipherSuite(UnSupported): %s",\r
610 AKMListDisplay, CipherListDisplay\r
611 );\r
612 }\r
613 FreePool (AKMListDisplay);\r
614 FreePool (CipherListDisplay);\r
615\r
616 PortHelpToken = HiiSetString (Private->RegisteredHandle, 0, PortString, NULL);\r
617\r
618 HiiCreateGotoOpCode (\r
619 StartOpCodeHandle,\r
620 FORMID_CONNECT_NETWORK,\r
621 PortPromptToken,\r
622 PortHelpToken,\r
623 EFI_IFR_FLAG_CALLBACK,\r
624 (UINT16) (KEY_AVAILABLE_NETWORK_ENTRY_BASE + Profile->ProfileIndex)\r
625 );\r
626\r
627 UnicodeSPrint (\r
628 PortString,\r
629 PortStringSize,\r
630 L"%s %s %s",\r
631 L"UnSupported",\r
632 mSecurityType[Profile->SecurityType],\r
633 RSSI_TO_SIGNAL_STRENGTH_BAR(Profile->NetworkQuality)\r
634 );\r
635 PortTextToken = HiiSetString (Private->RegisteredHandle, 0, PortString, NULL);\r
636\r
637 HiiCreateTextOpCode (\r
638 StartOpCodeHandle,\r
639 PortTextToken,\r
640 0,\r
641 0\r
642 );\r
643 }\r
644 }\r
645\r
646 Status = HiiUpdateForm (\r
647 Private->RegisteredHandle, // HII handle\r
648 &gWifiConfigFormSetGuid, // Formset GUID\r
649 FORMID_NETWORK_LIST, // Form ID\r
650 StartOpCodeHandle, // Label for where to insert opcodes\r
651 EndOpCodeHandle // Replace data\r
652 );\r
653\r
654Exit:\r
655\r
656 gBS->RestoreTPL (OldTpl);\r
657\r
658 if (AKMListDisplay != NULL) {\r
659 FreePool (AKMListDisplay);\r
660 }\r
661 if (CipherListDisplay != NULL) {\r
662 FreePool (CipherListDisplay);\r
663 }\r
664\r
665 HiiFreeOpCodeHandle (StartOpCodeHandle);\r
666 HiiFreeOpCodeHandle (EndOpCodeHandle);\r
667\r
668 DEBUG ((DEBUG_INFO, "[WiFi Connection Manager] Network List is Refreshed!\n"));\r
669 return Status;\r
670}\r
671\r
672/**\r
673 Refresh the hidden network list configured by user.\r
674\r
675 @param[in] Private The pointer to the global private data structure.\r
676\r
677 @retval EFI_SUCCESS The operation is completed successfully.\r
678 @retval Other Errors Returned errors when creating Opcodes or updating the\r
679 Hii form.\r
680**/\r
681EFI_STATUS\r
682WifiMgrRefreshHiddenList (\r
683 IN WIFI_MGR_PRIVATE_DATA *Private\r
684 )\r
685{\r
686 EFI_STATUS Status;\r
687 EFI_TPL OldTpl;\r
688 UINTN Index;\r
689 EFI_STRING_ID StringId;\r
690 VOID *StartOpCodeHandle;\r
691 VOID *EndOpCodeHandle;\r
692 WIFI_HIDDEN_NETWORK_DATA *HiddenNetwork;\r
693 LIST_ENTRY *Entry;\r
694\r
695 if (Private == NULL) {\r
696 return EFI_SUCCESS;\r
697 }\r
698\r
699 Status = WifiMgrCreateOpCode (\r
700 LABEL_HIDDEN_NETWORK_ENTRY,\r
701 &StartOpCodeHandle,\r
702 &EndOpCodeHandle\r
703 );\r
704 if (EFI_ERROR (Status)) {\r
705 return Status;\r
706 }\r
707\r
708 OldTpl = gBS->RaiseTPL (TPL_CALLBACK);\r
709 Index = 0;\r
710\r
711 NET_LIST_FOR_EACH (Entry, &Private->HiddenNetworkList) {\r
712\r
713 HiddenNetwork = NET_LIST_USER_STRUCT_S (\r
714 Entry,\r
715 WIFI_HIDDEN_NETWORK_DATA,\r
716 Link,\r
717 WIFI_MGR_HIDDEN_NETWORK_SIGNATURE\r
718 );\r
719 StringId = HiiSetString (Private->RegisteredHandle, 0, HiddenNetwork->SSId, NULL);\r
720\r
721 HiiCreateCheckBoxOpCode (\r
722 StartOpCodeHandle,\r
723 (EFI_QUESTION_ID) (KEY_HIDDEN_NETWORK_ENTRY_BASE + Index),\r
724 MANAGER_VARSTORE_ID,\r
725 (UINT16) (HIDDEN_NETWORK_LIST_VAR_OFFSET + Index),\r
726 StringId,\r
727 0,\r
728 0,\r
729 0,\r
730 NULL\r
731 );\r
732 Index ++;\r
733 }\r
734\r
735 Status = HiiUpdateForm (\r
736 Private->RegisteredHandle, // HII handle\r
737 &gWifiConfigFormSetGuid, // Formset GUID\r
738 FORMID_HIDDEN_NETWORK_LIST, // Form ID\r
739 StartOpCodeHandle, // Label for where to insert opcodes\r
740 EndOpCodeHandle // Replace data\r
741 );\r
742\r
743 gBS->RestoreTPL (OldTpl);\r
744 HiiFreeOpCodeHandle (StartOpCodeHandle);\r
745 HiiFreeOpCodeHandle (EndOpCodeHandle);\r
746 return Status;\r
747}\r
748\r
749\r
750/**\r
751 Callback function for user to select a Nic.\r
752\r
753 @param[in] Private The pointer to the global private data structure.\r
754 @param[in] KeyValue The key value received from HII input.\r
755\r
756 @retval EFI_NOT_FOUND The corresponding Nic is not found.\r
757 @retval EFI_SUCCESS The operation is completed successfully.\r
758\r
759**/\r
760EFI_STATUS\r
761WifiMgrSelectNic (\r
762 IN WIFI_MGR_PRIVATE_DATA *Private,\r
763 IN EFI_QUESTION_ID KeyValue\r
764 )\r
765{\r
766 WIFI_MGR_DEVICE_DATA *Nic;\r
767 UINT32 NicIndex;\r
768 CHAR16 MacString[WIFI_MGR_MAX_MAC_STRING_LEN];\r
769\r
770 NicIndex = KeyValue - KEY_MAC_ENTRY_BASE;\r
771 Nic = WifiMgrGetNicByIndex (Private, NicIndex);\r
772 if (Nic == NULL) {\r
773 return EFI_NOT_FOUND;\r
774 }\r
775 Private->CurrentNic = Nic;\r
776\r
777 WifiMgrMacAddrToStr (&Nic->MacAddress, sizeof (MacString), MacString);\r
778 HiiSetString (Private->RegisteredHandle, STRING_TOKEN(STR_MAC_ADDRESS), MacString, NULL);\r
779 return EFI_SUCCESS;\r
780}\r
781\r
782/**\r
783 Restore the NV data to be default.\r
784\r
785 @param[in] Private The pointer to the global private data structure.\r
786 @param[out] IfrNvData The IFR NV data.\r
787\r
788**/\r
789VOID\r
790WifiMgrCleanUserInput (\r
791 IN WIFI_MGR_PRIVATE_DATA *Private\r
792 )\r
793{\r
794 Private->SecurityType = SECURITY_TYPE_NONE;\r
795 Private->EapAuthMethod = EAP_AUTH_METHOD_TTLS;\r
796 Private->EapSecondAuthMethod = EAP_SEAUTH_METHOD_MSCHAPV2;\r
797 Private->FileType = FileTypeMax;\r
798}\r
799\r
800/**\r
801 UI handle function when user select a network to connect.\r
802\r
803 @param[in] Private The pointer to the global private data structure.\r
804 @param[in] ProfileIndex The profile index user selected to connect.\r
805\r
806 @retval EFI_INVALID_PARAMETER Nic is null.\r
807 @retval EFI_NOT_FOUND Profile could not be found.\r
808 @retval EFI_SUCCESS The operation is completed successfully.\r
809\r
810**/\r
811EFI_STATUS\r
812WifiMgrUserSelectProfileToConnect(\r
813 IN WIFI_MGR_PRIVATE_DATA *Private,\r
814 IN UINT32 ProfileIndex\r
815 )\r
816{\r
817 WIFI_MGR_NETWORK_PROFILE *Profile;\r
818 WIFI_MGR_DEVICE_DATA *Nic;\r
819\r
820 Nic = Private->CurrentNic;\r
821 if (Nic == NULL) {\r
822 return EFI_INVALID_PARAMETER;\r
823 }\r
824\r
825 //\r
826 //Initialize the connection page\r
827 //\r
828 WifiMgrCleanUserInput(Private);\r
829\r
830 Profile = WifiMgrGetProfileByProfileIndex (ProfileIndex, &Nic->ProfileList);\r
831 if (Profile == NULL) {\r
832 return EFI_NOT_FOUND;\r
833 }\r
834 Private->CurrentNic->UserSelectedProfile = Profile;\r
835\r
836 return EFI_SUCCESS;\r
837}\r
838\r
839/**\r
840 Record password from a HII input string.\r
841\r
842 @param[in] Private The pointer to the global private data structure.\r
843 @param[in] StringId The QuestionId received from HII input.\r
844 @param[in] StringBuffer The unicode string buffer to store password.\r
845 @param[in] StringBufferLen The len of unicode string buffer.\r
846\r
847 @retval EFI_INVALID_PARAMETER Any input parameter is invalid.\r
848 @retval EFI_NOT_FOUND The password string is not found or invalid.\r
849 @retval EFI_SUCCESS The operation is completed successfully.\r
850\r
851**/\r
852EFI_STATUS\r
853WifiMgrRecordPassword (\r
854 IN WIFI_MGR_PRIVATE_DATA *Private,\r
855 IN EFI_STRING_ID StringId,\r
856 IN CHAR16 *StringBuffer,\r
857 IN UINTN StringBufferLen\r
858 )\r
859{\r
860 CHAR16 *Password;\r
861\r
862 if (StringId == 0 || StringBuffer == NULL || StringBufferLen <= 0) {\r
863 return EFI_INVALID_PARAMETER;\r
864 }\r
865\r
866 Password = HiiGetString (Private->RegisteredHandle, StringId, NULL);\r
867 if (Password == NULL) {\r
868 return EFI_NOT_FOUND;\r
869 }\r
870 if (StrLen (Password) > StringBufferLen) {\r
871 FreePool (Password);\r
872 return EFI_NOT_FOUND;\r
873 }\r
874 StrnCpyS (StringBuffer, StringBufferLen, Password, StrLen (Password));\r
875 ZeroMem (Password, (StrLen (Password) + 1) * sizeof (CHAR16));\r
876 FreePool (Password);\r
877\r
878 //\r
879 // Clean password in string package\r
880 //\r
881 HiiSetString (Private->RegisteredHandle, StringId, L"", NULL);\r
882 return EFI_SUCCESS;\r
883}\r
884\r
885/**\r
886 Update connection message on connect configuration page, and trigger related form refresh.\r
887\r
888 @param[in] Nic The related Nic for updating message.\r
889 @param[in] ConnectStateChanged The tag to tell if the connection state has been changed, only\r
890 when the connection changes from "Connected" or "Disconnecting"\r
891 to "Disconnected", or from "Disconnected" or "Connecting" to\r
892 "Connected", this tag can be set as TRUE.\r
893 @param[in] ConnectStatusMessage The message to show on connected status bar, if NULL, will\r
894 use default message.\r
895\r
896**/\r
897VOID\r
898WifiMgrUpdateConnectMessage (\r
899 IN WIFI_MGR_DEVICE_DATA *Nic,\r
900 IN BOOLEAN ConnectStateChanged,\r
901 IN EFI_STRING ConnectStatusMessage\r
902 )\r
903{\r
904 CHAR16 ConnectStatusStr[WIFI_STR_MAX_SIZE];\r
905 WIFI_MGR_PRIVATE_DATA *Private;\r
906\r
907 Private = Nic->Private;\r
908 if (Private == NULL || Private->CurrentNic != Nic) {\r
909 return;\r
910 }\r
911\r
912 //\r
913 // Update Connection Status Bar\r
914 //\r
915 if (ConnectStatusMessage != NULL) {\r
916 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_CONNECT_STATUS), ConnectStatusMessage, NULL);\r
917 } else {\r
918 if (Nic->ConnectState == WifiMgrConnectedToAp) {\r
919\r
920 UnicodeSPrint (ConnectStatusStr, sizeof (ConnectStatusStr), L"Connected to %s",\r
921 Nic->CurrentOperateNetwork->SSId);\r
922 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_CONNECT_STATUS), ConnectStatusStr, NULL);\r
923 } else if (Nic->ConnectState == WifiMgrDisconnected) {\r
924\r
925 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_CONNECT_STATUS), L"Disconnected", NULL);\r
926 } else if (Nic->ConnectState == WifiMgrConnectingToAp) {\r
927\r
928 UnicodeSPrint (ConnectStatusStr, sizeof (ConnectStatusStr), L"Connecting to %s ...",\r
929 Nic->CurrentOperateNetwork->SSId);\r
930 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_CONNECT_STATUS), ConnectStatusStr, NULL);\r
931 } else if (Nic->ConnectState == WifiMgrDisconnectingToAp) {\r
932\r
933 UnicodeSPrint (ConnectStatusStr, sizeof (ConnectStatusStr), L"Disconnecting from %s ...",\r
934 Nic->CurrentOperateNetwork->SSId);\r
935 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_CONNECT_STATUS), ConnectStatusStr, NULL);\r
936 } else {\r
937 return;\r
938 }\r
939 }\r
940\r
941 //\r
942 // Update Connect Button\r
943 //\r
944 if (Nic->ConnectState == WifiMgrConnectedToAp && Nic->UserSelectedProfile == Nic->CurrentOperateNetwork) {\r
945\r
946 HiiSetString (Private->RegisteredHandle,\r
947 STRING_TOKEN (STR_CONNECT_NOW), L"Disconnect from this Network", NULL);\r
948 } else {\r
949 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_CONNECT_NOW), L"Connect to this Network", NULL);\r
950 }\r
951 gBS->SignalEvent (Private->ConnectFormRefreshEvent);\r
952\r
953 //\r
954 // Update Main Page and Network List\r
955 //\r
956 if (ConnectStateChanged) {\r
957\r
958 if (Nic->ConnectState == WifiMgrConnectedToAp) {\r
959\r
960 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_CONNECTION_INFO), L"Connected to", NULL);\r
961 HiiSetString (Private->RegisteredHandle,\r
962 STRING_TOKEN (STR_CONNECTED_SSID), Nic->CurrentOperateNetwork->SSId, NULL);\r
963 } else {\r
964 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_CONNECTION_INFO), L"Disconnected", NULL);\r
965 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_CONNECTED_SSID), L"", NULL);\r
966 }\r
967\r
968 gBS->SignalEvent (Private->NetworkListRefreshEvent);\r
969 gBS->SignalEvent (Private->MainPageRefreshEvent);\r
970 }\r
971}\r
972\r
973/**\r
974 Convert the driver configuration data into the IFR data.\r
975\r
976 @param[in] Private The pointer to the global private data structure.\r
977 @param[out] IfrNvData The IFR NV data.\r
978\r
979 @retval EFI_SUCCESS The operation is completed successfully.\r
980\r
981**/\r
982EFI_STATUS\r
983WifiMgrConvertConfigDataToIfrNvData (\r
984 IN WIFI_MGR_PRIVATE_DATA *Private,\r
985 OUT WIFI_MANAGER_IFR_NVDATA *IfrNvData\r
986 )\r
987{\r
988 //\r
989 // Private shouldn't be NULL here, assert if Private is NULL.\r
990 //\r
991 ASSERT (Private != NULL);\r
992\r
993 if (Private->CurrentNic != NULL) {\r
994 IfrNvData->ProfileCount = Private->CurrentNic->AvailableCount;\r
995 } else {\r
996 IfrNvData->ProfileCount = 0;\r
997 }\r
998\r
999 return EFI_SUCCESS;\r
1000}\r
1001\r
1002/**\r
1003 Convert the IFR data into the driver configuration data.\r
1004\r
1005 @param[in] Private The pointer to the global private data structure.\r
1006 @param[in, out] IfrNvData The IFR NV data.\r
1007\r
1008 @retval EFI_SUCCESS The operation is completed successfully.\r
1009\r
1010**/\r
1011EFI_STATUS\r
1012WifiMgrConvertIfrNvDataToConfigData (\r
1013 IN WIFI_MGR_PRIVATE_DATA *Private,\r
1014 IN OUT WIFI_MANAGER_IFR_NVDATA *IfrNvData\r
1015 )\r
1016{\r
1017 return EFI_SUCCESS;\r
1018}\r
1019\r
1020/**\r
1021 This function allows the caller to request the current\r
1022 configuration for one or more named elements. The resulting\r
1023 string is in <ConfigAltResp> format. Any and all alternative\r
1024 configuration strings shall also be appended to the end of the\r
1025 current configuration string. If they are, they must appear\r
1026 after the current configuration. They must contain the same\r
1027 routing (GUID, NAME, PATH) as the current configuration string.\r
1028 They must have an additional description indicating the type of\r
1029 alternative configuration the string represents,\r
1030 "ALTCFG=<StringToken>". That <StringToken> (when\r
1031 converted from Hex UNICODE to binary) is a reference to a\r
1032 string in the associated string pack.\r
1033\r
1034 @param This Points to the EFI_HII_CONFIG_ACCESS_PROTOCOL.\r
1035\r
1036 @param Request A null-terminated Unicode string in\r
1037 <ConfigRequest> format. Note that this\r
1038 includes the routing information as well as\r
1039 the configurable name / value pairs. It is\r
1040 invalid for this string to be in\r
1041 <MultiConfigRequest> format.\r
1042 If a NULL is passed in for the Request field,\r
1043 all of the settings being abstracted by this function\r
1044 will be returned in the Results field. In addition,\r
1045 if a ConfigHdr is passed in with no request elements,\r
1046 all of the settings being abstracted for that particular\r
1047 ConfigHdr reference will be returned in the Results Field.\r
1048\r
1049 @param Progress On return, points to a character in the\r
1050 Request string. Points to the string's null\r
1051 terminator if request was successful. Points\r
1052 to the most recent "&" before the first\r
1053 failing name / value pair (or the beginning\r
1054 of the string if the failure is in the first\r
1055 name / value pair) if the request was not\r
1056 successful.\r
1057\r
1058 @param Results A null-terminated Unicode string in\r
1059 <MultiConfigAltResp> format which has all values\r
1060 filled in for the names in the Request string.\r
1061 String to be allocated by the called function.\r
1062\r
1063 @retval EFI_SUCCESS The Results string is filled with the\r
1064 values corresponding to all requested\r
1065 names.\r
1066\r
1067 @retval EFI_OUT_OF_RESOURCES Not enough memory to store the\r
1068 parts of the results that must be\r
1069 stored awaiting possible future\r
1070 protocols.\r
1071\r
1072 @retval EFI_NOT_FOUND Routing data doesn't match any\r
1073 known driver. Progress set to the\r
1074 first character in the routing header.\r
1075 Note: There is no requirement that the\r
1076 driver validate the routing data. It\r
1077 must skip the <ConfigHdr> in order to\r
1078 process the names.\r
1079\r
1080 @retval EFI_INVALID_PARAMETER Illegal syntax. Progress set\r
1081 to most recent "&" before the\r
1082 error or the beginning of the\r
1083 string.\r
1084\r
1085 @retval EFI_INVALID_PARAMETER Unknown name. Progress points\r
1086 to the & before the name in\r
1087 question.\r
1088\r
1089**/\r
1090EFI_STATUS\r
1091EFIAPI\r
1092WifiMgrDxeHiiConfigAccessExtractConfig (\r
1093 IN CONST EFI_HII_CONFIG_ACCESS_PROTOCOL *This,\r
1094 IN CONST EFI_STRING Request,\r
1095 OUT EFI_STRING *Progress,\r
1096 OUT EFI_STRING *Results\r
1097 )\r
1098{\r
1099 WIFI_MGR_PRIVATE_DATA *Private;\r
1100 WIFI_MANAGER_IFR_NVDATA *IfrNvData;\r
1101 EFI_STRING ConfigRequestHdr;\r
1102 EFI_STRING ConfigRequest;\r
1103 UINTN Size;\r
1104 BOOLEAN AllocatedRequest;\r
1105 UINTN BufferSize;\r
1106 EFI_STATUS Status;\r
1107\r
1108 if (This == NULL || Progress == NULL || Results == NULL) {\r
1109 return EFI_INVALID_PARAMETER;\r
1110 }\r
1111\r
1112 *Progress = Request;\r
1113 if ((Request != NULL) &&\r
1114 !HiiIsConfigHdrMatch (Request, &gWifiConfigFormSetGuid, mVendorStorageName)) {\r
1115 return EFI_NOT_FOUND;\r
1116 }\r
1117\r
1118 ConfigRequestHdr = NULL;\r
1119 ConfigRequest = NULL;\r
1120 AllocatedRequest = FALSE;\r
1121 Size = 0;\r
1122\r
1123 Private = WIFI_MGR_PRIVATE_DATA_FROM_CONFIG_ACCESS (This);\r
1124\r
1125 BufferSize = sizeof (WIFI_MANAGER_IFR_NVDATA);\r
1126 IfrNvData = AllocateZeroPool (BufferSize);\r
1127 if (IfrNvData == NULL) {\r
1128 return EFI_OUT_OF_RESOURCES;\r
1129 }\r
1130\r
1131 WifiMgrConvertConfigDataToIfrNvData (Private, IfrNvData);\r
1132\r
1133 ConfigRequest = Request;\r
1134 if ((Request == NULL) || (StrStr (Request, L"OFFSET") == NULL)) {\r
1135 //\r
1136 // Request has no request element, construct full request string.\r
1137 // Allocate and fill a buffer large enough to hold the <ConfigHdr> template\r
1138 // followed by "&OFFSET=0&WIDTH=WWWWWWWWWWWWWWWW" followed by a Null-terminator.\r
1139 //\r
1140 ConfigRequestHdr = HiiConstructConfigHdr (\r
1141 &gWifiConfigFormSetGuid,\r
1142 mVendorStorageName,\r
1143 Private->DriverHandle);\r
1144 if (ConfigRequestHdr == NULL) {\r
1145 FreePool (IfrNvData);\r
1146 return EFI_OUT_OF_RESOURCES;\r
1147 }\r
1148\r
1149 Size = (StrLen (ConfigRequestHdr) + 32 + 1) * sizeof (CHAR16);\r
1150 ConfigRequest = AllocateZeroPool (Size);\r
1151 if (ConfigRequest == NULL) {\r
1152\r
1153 FreePool (IfrNvData);\r
1154 FreePool (ConfigRequestHdr);\r
1155 return EFI_OUT_OF_RESOURCES;\r
1156 }\r
1157\r
1158 AllocatedRequest = TRUE;\r
1159 UnicodeSPrint (\r
1160 ConfigRequest,\r
1161 Size,\r
1162 L"%s&OFFSET=0&WIDTH=%016LX",\r
1163 ConfigRequestHdr,\r
1164 (UINT64) BufferSize\r
1165 );\r
1166 FreePool (ConfigRequestHdr);\r
1167 }\r
1168\r
1169 //\r
1170 // Convert buffer data to <ConfigResp> by helper function BlockToConfig()\r
1171 //\r
1172 Status = gHiiConfigRouting->BlockToConfig (\r
1173 gHiiConfigRouting,\r
1174 ConfigRequest,\r
1175 (UINT8 *) IfrNvData,\r
1176 BufferSize,\r
1177 Results,\r
1178 Progress\r
1179 );\r
1180\r
1181 FreePool (IfrNvData);\r
1182 //\r
1183 // Free the allocated config request string.\r
1184 //\r
1185 if (AllocatedRequest) {\r
1186 FreePool (ConfigRequest);\r
1187 ConfigRequest = NULL;\r
1188 }\r
1189 //\r
1190 // Set Progress string to the original request string.\r
1191 //\r
1192 if (Request == NULL) {\r
1193 *Progress = NULL;\r
1194 } else if (StrStr (Request, L"OFFSET") == NULL) {\r
1195 *Progress = Request + StrLen (Request);\r
1196 }\r
1197\r
1198 return Status;\r
1199}\r
1200\r
1201/**\r
1202 This function applies changes in a driver's configuration.\r
1203 Input is a Configuration, which has the routing data for this\r
1204 driver followed by name / value configuration pairs. The driver\r
1205 must apply those pairs to its configurable storage. If the\r
1206 driver's configuration is stored in a linear block of data\r
1207 and the driver's name / value pairs are in <BlockConfig>\r
1208 format, it may use the ConfigToBlock helper function (above) to\r
1209 simplify the job.\r
1210\r
1211 @param This Points to the EFI_HII_CONFIG_ACCESS_PROTOCOL.\r
1212\r
1213 @param Configuration A null-terminated Unicode string in\r
1214 <ConfigString> format.\r
1215\r
1216 @param Progress A pointer to a string filled in with the\r
1217 offset of the most recent '&' before the\r
1218 first failing name / value pair (or the\r
1219 beginn ing of the string if the failure\r
1220 is in the first name / value pair) or\r
1221 the terminating NULL if all was\r
1222 successful.\r
1223\r
1224 @retval EFI_SUCCESS The results have been distributed or are\r
1225 awaiting distribution.\r
1226\r
1227 @retval EFI_OUT_OF_RESOURCES Not enough memory to store the\r
1228 parts of the results that must be\r
1229 stored awaiting possible future\r
1230 protocols.\r
1231\r
1232 @retval EFI_INVALID_PARAMETERS Passing in a NULL for the\r
1233 Results parameter would result\r
1234 in this type of error.\r
1235\r
1236 @retval EFI_NOT_FOUND Target for the specified routing data\r
1237 was not found\r
1238\r
1239**/\r
1240EFI_STATUS\r
1241EFIAPI\r
1242WifiMgrDxeHiiConfigAccessRouteConfig (\r
1243 IN CONST EFI_HII_CONFIG_ACCESS_PROTOCOL *This,\r
1244 IN CONST EFI_STRING Configuration,\r
1245 OUT EFI_STRING *Progress\r
1246 )\r
1247{\r
1248 EFI_STATUS Status;\r
1249 UINTN BufferSize;\r
1250 WIFI_MGR_PRIVATE_DATA *Private;\r
1251 WIFI_MANAGER_IFR_NVDATA *IfrNvData;\r
1252\r
1253 if (Configuration == NULL || Progress == NULL) {\r
1254 return EFI_INVALID_PARAMETER;\r
1255 }\r
1256\r
1257 IfrNvData = NULL;\r
1258 *Progress = Configuration;\r
1259 BufferSize = sizeof (WIFI_MANAGER_IFR_NVDATA);\r
1260 Private = WIFI_MGR_PRIVATE_DATA_FROM_CONFIG_ACCESS (This);\r
1261\r
1262 if (!HiiIsConfigHdrMatch (Configuration, &gWifiConfigFormSetGuid, mVendorStorageName)) {\r
1263 return EFI_NOT_FOUND;\r
1264 }\r
1265\r
1266 IfrNvData = AllocateZeroPool (BufferSize);\r
1267 if (IfrNvData == NULL) {\r
1268 return EFI_OUT_OF_RESOURCES;\r
1269 }\r
1270\r
1271 WifiMgrConvertConfigDataToIfrNvData (Private, IfrNvData);\r
1272\r
1273 Status = gHiiConfigRouting->ConfigToBlock (\r
1274 gHiiConfigRouting,\r
1275 Configuration,\r
1276 (UINT8*) IfrNvData,\r
1277 &BufferSize,\r
1278 Progress\r
1279 );\r
1280 if (EFI_ERROR (Status)) {\r
1281 return Status;\r
1282 }\r
1283\r
1284 Status = WifiMgrConvertIfrNvDataToConfigData (Private, IfrNvData);\r
1285 ZeroMem (IfrNvData, sizeof (WIFI_MANAGER_IFR_NVDATA));\r
1286 FreePool (IfrNvData);\r
1287\r
1288 return Status;\r
1289}\r
1290\r
1291/**\r
1292 This function is called to provide results data to the driver.\r
1293 This data consists of a unique key that is used to identify\r
1294 which data is either being passed back or being asked for.\r
1295\r
1296 @param This Points to the EFI_HII_CONFIG_ACCESS_PROTOCOL.\r
1297 @param Action Specifies the type of action taken by the browser.\r
1298 @param QuestionId A unique value which is sent to the original\r
1299 exporting driver so that it can identify the type\r
1300 of data to expect. The format of the data tends to\r
1301 vary based on the opcode that generated the callback.\r
1302 @param Type The type of value for the question.\r
1303 @param Value A pointer to the data being sent to the original\r
1304 exporting driver.\r
1305 @param ActionRequest On return, points to the action requested by the\r
1306 callback function.\r
1307\r
1308 @retval EFI_SUCCESS The callback successfully handled the action.\r
1309 @retval EFI_OUT_OF_RESOURCES Not enough storage is available to hold the\r
1310 variable and its data.\r
1311 @retval EFI_DEVICE_ERROR The variable could not be saved.\r
1312 @retval EFI_UNSUPPORTED The specified Action is not supported by the\r
1313 callback.\r
1314\r
1315**/\r
1316EFI_STATUS\r
1317EFIAPI\r
1318WifiMgrDxeHiiConfigAccessCallback (\r
1319 IN CONST EFI_HII_CONFIG_ACCESS_PROTOCOL *This,\r
1320 IN EFI_BROWSER_ACTION Action,\r
1321 IN EFI_QUESTION_ID QuestionId,\r
1322 IN UINT8 Type,\r
1323 IN OUT EFI_IFR_TYPE_VALUE *Value,\r
1324 OUT EFI_BROWSER_ACTION_REQUEST *ActionRequest\r
1325 )\r
1326{\r
1327 EFI_STATUS Status;\r
1328 EFI_INPUT_KEY Key;\r
1329 UINTN BufferSize;\r
1330 WIFI_MGR_PRIVATE_DATA *Private;\r
1331 WIFI_MANAGER_IFR_NVDATA *IfrNvData;\r
1332 EFI_DEVICE_PATH_PROTOCOL *FilePath;\r
1333 WIFI_MGR_NETWORK_PROFILE *Profile;\r
1334 WIFI_MGR_NETWORK_PROFILE *ProfileToConnect;\r
1335 WIFI_HIDDEN_NETWORK_DATA *HiddenNetwork;\r
1336 UINTN TempDataSize;\r
1337 VOID *TempData;\r
1338 LIST_ENTRY *Entry;\r
1339 UINT32 Index;\r
1340 UINT32 RemoveCount;\r
1341 CHAR16 *TempPassword;\r
1342 CHAR16 *ErrorMessage;\r
1343\r
1344 if (Action != EFI_BROWSER_ACTION_FORM_OPEN &&\r
1345 Action != EFI_BROWSER_ACTION_FORM_CLOSE &&\r
1346 Action != EFI_BROWSER_ACTION_CHANGING &&\r
1347 Action != EFI_BROWSER_ACTION_CHANGED &&\r
1348 Action != EFI_BROWSER_ACTION_RETRIEVE) {\r
1349\r
1350 return EFI_UNSUPPORTED;\r
1351 }\r
1352 if ((Value == NULL) || (ActionRequest == NULL)) {\r
1353 return EFI_INVALID_PARAMETER;\r
1354 }\r
1355\r
1356 Status = EFI_SUCCESS;\r
1357 Private = WIFI_MGR_PRIVATE_DATA_FROM_CONFIG_ACCESS (This);\r
1358 if (Private->CurrentNic == NULL) {\r
1359 return EFI_DEVICE_ERROR;\r
1360 }\r
1361\r
1362 //\r
1363 // Retrieve uncommitted data from Browser\r
1364 //\r
1365 BufferSize = sizeof (WIFI_MANAGER_IFR_NVDATA);\r
1366 IfrNvData = AllocateZeroPool (BufferSize);\r
1367 if (IfrNvData == NULL) {\r
1368 return EFI_OUT_OF_RESOURCES;\r
1369 }\r
1370 HiiGetBrowserData (&gWifiConfigFormSetGuid, mVendorStorageName, BufferSize, (UINT8 *) IfrNvData);\r
1371\r
1372 if (Action == EFI_BROWSER_ACTION_FORM_OPEN) {\r
1373 switch (QuestionId) {\r
1374\r
1375 case KEY_MAC_LIST:\r
1376\r
1377 Status = WifiMgrShowNicList (Private);\r
1378 break;\r
1379\r
1380 case KEY_REFRESH_NETWORK_LIST:\r
1381\r
1382 if (Private->CurrentNic->UserSelectedProfile != NULL) {\r
1383\r
1384 Profile = Private->CurrentNic->UserSelectedProfile;\r
1385\r
1386 //\r
1387 // Erase secrets since user has left Connection Page\r
1388 // Connection Page may direct to Network List Page or Eap Configuration Page,\r
1389 // secrets only need to be erased when head to Network List Page\r
1390 //\r
1391 WifiMgrCleanProfileSecrets (Profile);\r
1392\r
1393 Private->CurrentNic->UserSelectedProfile = NULL;\r
1394 }\r
1395\r
1396 break;\r
1397\r
1398 case KEY_CONNECT_ACTION:\r
1399\r
1400 if (Private->CurrentNic->UserSelectedProfile == NULL) {\r
1401 break;\r
1402 }\r
1403 Profile = Private->CurrentNic->UserSelectedProfile;\r
1404\r
1405 //\r
1406 //Enter the network connection configuration page\r
1407 //Recovery from restored data\r
1408 //\r
1409 if (HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_SSID), Profile->SSId, NULL) == 0) {\r
1410 return EFI_OUT_OF_RESOURCES;\r
1411 }\r
1412 IfrNvData->SecurityType = Profile->SecurityType;\r
1413 if (HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_SECURITY_TYPE),\r
1414 mSecurityType[IfrNvData->SecurityType], NULL) == 0) {\r
1415 return EFI_OUT_OF_RESOURCES;\r
1416 }\r
1417\r
1418 if (IfrNvData->SecurityType == SECURITY_TYPE_WPA2_ENTERPRISE) {\r
1419\r
1420 IfrNvData->EapAuthMethod = Profile->EapAuthMethod;\r
1421 IfrNvData->EapSecondAuthMethod = Profile->EapSecondAuthMethod;\r
1422 StrCpyS (IfrNvData->EapIdentity, EAP_IDENTITY_SIZE, Profile->EapIdentity);\r
1423 }\r
1424\r
1425 break;\r
1426\r
1427 case KEY_ENROLLED_CERT_NAME:\r
1428\r
1429 if (Private->CurrentNic->UserSelectedProfile == NULL) {\r
1430 break;\r
1431 }\r
1432 Profile = Private->CurrentNic->UserSelectedProfile;\r
1433\r
1434 //\r
1435 //Enter the key enrollment page\r
1436 //For TTLS and PEAP, only CA cert needs to be cared\r
1437 //\r
1438 if (Private->FileType == FileTypeCACert) {\r
1439\r
1440 if (Profile->CACertData != NULL) {\r
1441 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_EAP_ENROLLED_CERT_NAME), Profile->CACertName, NULL);\r
1442 } else {\r
1443 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_EAP_ENROLLED_CERT_NAME), L"", NULL);\r
1444 }\r
1445 } else if (Private->FileType == FileTypeClientCert) {\r
1446\r
1447 if (Profile->ClientCertData != NULL) {\r
1448 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_EAP_ENROLLED_CERT_NAME), Profile->ClientCertName, NULL);\r
1449 } else {\r
1450 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_EAP_ENROLLED_CERT_NAME), L"", NULL);\r
1451 }\r
1452 }\r
1453 break;\r
1454\r
1455 case KEY_ENROLLED_PRIVATE_KEY_NAME:\r
1456\r
1457 if (Private->CurrentNic->UserSelectedProfile == NULL) {\r
1458 break;\r
1459 }\r
1460 Profile = Private->CurrentNic->UserSelectedProfile;\r
1461\r
1462 if (Profile->PrivateKeyData != NULL) {\r
1463 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_EAP_ENROLLED_PRIVATE_KEY_NAME), Profile->PrivateKeyName, NULL);\r
1464 } else {\r
1465 HiiSetString (Private->RegisteredHandle, STRING_TOKEN (STR_EAP_ENROLLED_PRIVATE_KEY_NAME), L"", NULL);\r
1466 }\r
1467 break;\r
1468\r
1469 default:\r
1470 break;\r
1471 }\r
1472 } else if (Action == EFI_BROWSER_ACTION_FORM_CLOSE) {\r
1473 switch (QuestionId) {\r
1474\r
1475 case KEY_CONNECT_ACTION:\r
1476\r
1477 if (Private->CurrentNic->UserSelectedProfile == NULL) {\r
1478 break;\r
1479 }\r
1480 Profile = Private->CurrentNic->UserSelectedProfile;\r
1481\r
1482 //\r
1483 //Restore User Config Data for Page recovery\r
1484 //\r
1485 if (IfrNvData->SecurityType == SECURITY_TYPE_WPA2_ENTERPRISE) {\r
1486\r
1487 Profile->EapAuthMethod = IfrNvData->EapAuthMethod;\r
1488 Profile->EapSecondAuthMethod = IfrNvData->EapSecondAuthMethod;\r
1489 StrCpyS (Profile->EapIdentity, EAP_IDENTITY_SIZE, IfrNvData->EapIdentity);\r
1490 }\r
1491 break;\r
1492\r
1493 default:\r
1494 break;\r
1495 }\r
1496 } else if (Action == EFI_BROWSER_ACTION_CHANGING) {\r
1497 switch (QuestionId) {\r
1498\r
1499 case KEY_NETWORK_LIST:\r
1500\r
1501 //\r
1502 //User triggered a scan process.\r
1503 //\r
1504 Private->CurrentNic->OneTimeScanRequest = TRUE;\r
1505 break;\r
1506\r
1507 case KEY_PASSWORD_CONNECT_NETWORK:\r
1508 case KEY_EAP_PASSWORD_CONNECT_NETWORK:\r
1509 case KEY_PRIVATE_KEY_PASSWORD:\r
1510\r
1511 if (Private->CurrentNic->UserSelectedProfile == NULL) {\r
1512 break;\r
1513 }\r
1514 Profile = Private->CurrentNic->UserSelectedProfile;\r
1515\r
1516 if (QuestionId == KEY_PASSWORD_CONNECT_NETWORK) {\r
1517 TempPassword = Profile->Password;\r
1518 } else if (QuestionId == KEY_EAP_PASSWORD_CONNECT_NETWORK) {\r
1519 TempPassword = Profile->EapPassword;\r
1520 } else {\r
1521 TempPassword = Profile->PrivateKeyPassword;\r
1522 }\r
1523\r
1524 Status = WifiMgrRecordPassword (Private, Value->string, TempPassword, PASSWORD_STORAGE_SIZE);\r
1525 if (EFI_ERROR (Status)) {\r
1526 DEBUG ((DEBUG_ERROR, "[WiFi Connection Manager] Error: Failed to input password!"));\r
1527 break;\r
1528 }\r
1529\r
1530 //\r
1531 // This password is not a new created password, so no need to confirm.\r
1532 //\r
1533 Status = EFI_NOT_FOUND;\r
1534 break;\r
1535\r
1536 case KEY_CONNECT_ACTION:\r
1537\r
1538 ErrorMessage = NULL;\r
1539 ProfileToConnect = NULL;\r
1540\r
1541 if (Private->CurrentNic->UserSelectedProfile == NULL) {\r
1542 break;\r
1543 }\r
1544 Profile = Private->CurrentNic->UserSelectedProfile;\r
1545\r
1546 if (Private->CurrentNic->ConnectState == WifiMgrDisconnected ||\r
1547 Profile != Private->CurrentNic->CurrentOperateNetwork) {\r
1548\r
1549 //\r
1550 // When this network is not currently connected, pend it to connect.\r
1551 //\r
1552 if (Profile->AKMSuiteSupported && Profile->CipherSuiteSupported) {\r
1553\r
1554 if (Profile->SecurityType == SECURITY_TYPE_NONE || Profile->SecurityType == SECURITY_TYPE_WPA2_PERSONAL) {\r
1555\r
1556 //\r
1557 // For Open network, connect directly.\r
1558 //\r
1559 ProfileToConnect = Profile;\r
1560\r
1561 } else if (Profile->SecurityType == SECURITY_TYPE_WPA2_ENTERPRISE) {\r
1562\r
1563 //\r
1564 // For WPA/WPA2-Enterprise network, conduct eap configuration first.\r
1565 // Only EAP-TLS, TTLS and PEAP is supported now!\r
1566 //\r
1567 Profile->EapAuthMethod = IfrNvData->EapAuthMethod;\r
1568 StrCpyS (Profile->EapIdentity, EAP_IDENTITY_SIZE, IfrNvData->EapIdentity);\r
1569\r
1570 if (IfrNvData->EapAuthMethod == EAP_AUTH_METHOD_TTLS || IfrNvData->EapAuthMethod == EAP_AUTH_METHOD_PEAP) {\r
1571\r
1572 Profile->EapSecondAuthMethod = IfrNvData->EapSecondAuthMethod;\r
1573 ProfileToConnect = Profile;\r
1574 } else if (IfrNvData->EapAuthMethod == EAP_AUTH_METHOD_TLS) {\r
1575 ProfileToConnect = Profile;\r
1576 } else {\r
1577 ErrorMessage = L"ERROR: Only EAP-TLS, TTLS or PEAP is supported now!";\r
1578 }\r
1579 } else {\r
1580 ErrorMessage = L"ERROR: Can't connect to this network!";\r
1581 }\r
1582 } else {\r
1583 ErrorMessage = L"ERROR: This network is not supported!";\r
1584 }\r
1585\r
1586 if (ErrorMessage != NULL) {\r
1587 CreatePopUp (\r
1588 EFI_LIGHTGRAY | EFI_BACKGROUND_BLUE,\r
1589 &Key,\r
1590 ErrorMessage,\r
1591 NULL\r
1592 );\r
1593 }\r
1594\r
1595 if (ProfileToConnect != NULL) {\r
1596\r
1597 Private->CurrentNic->OneTimeConnectRequest = TRUE;\r
1598 Private->CurrentNic->ConnectPendingNetwork = ProfileToConnect;\r
1599 }\r
1600 } else if (Private->CurrentNic->ConnectState == WifiMgrConnectedToAp) {\r
1601\r
1602 //\r
1603 // This network is currently connected, just disconnect from it.\r
1604 //\r
1605 Private->CurrentNic->OneTimeDisconnectRequest = TRUE;\r
1606 Private->CurrentNic->HasDisconnectPendingNetwork = TRUE;\r
1607 }\r
1608 break;\r
1609\r
1610 case KEY_ENROLL_CA_CERT_CONNECT_NETWORK:\r
1611\r
1612 Private->FileType = FileTypeCACert;\r
1613 break;\r
1614\r
1615 case KEY_ENROLL_CLIENT_CERT_CONNECT_NETWORK:\r
1616\r
1617 Private->FileType = FileTypeClientCert;\r
1618 break;\r
1619\r
1620 case KEY_EAP_ENROLL_PRIVATE_KEY_FROM_FILE:\r
1621\r
1622 FilePath = NULL;\r
1623 ChooseFile (NULL, NULL, NULL, &FilePath);\r
1624\r
1625 if (FilePath != NULL) {\r
1626\r
1627 UpdatePrivateKeyFromFile(Private, FilePath);\r
1628 FreePool (FilePath);\r
1629 }\r
1630 break;\r
1631\r
1632 case KEY_EAP_ENROLL_CERT_FROM_FILE:\r
1633\r
1634 //\r
1635 //User will select a cert file from File Explore\r
1636 //\r
1637 FilePath = NULL;\r
1638 ChooseFile( NULL, NULL, NULL, &FilePath);\r
1639\r
1640 if (FilePath != NULL) {\r
1641\r
1642 UpdateCAFromFile(Private, FilePath);\r
1643 FreePool (FilePath);\r
1644 }\r
1645 break;\r
1646\r
1647 case KEY_SAVE_PRIVATE_KEY_TO_MEM:\r
1648\r
1649 if (Private->FileContext != NULL && Private->FileContext->FHandle != NULL &&\r
1650 Private->CurrentNic->UserSelectedProfile != NULL) {\r
1651\r
1652 //\r
1653 // Read Private Key file to Buffer\r
1654 //\r
1655 Profile = Private->CurrentNic->UserSelectedProfile;\r
1656 if (Profile->PrivateKeyData != NULL) {\r
1657\r
1658 ZeroMem (Profile->PrivateKeyData, Profile->PrivateKeyDataSize);\r
1659 FreePool (Profile->PrivateKeyData);\r
1660 }\r
1661\r
1662 Status = WifiMgrReadFileToBuffer (\r
1663 Private->FileContext,\r
1664 &TempData,\r
1665 &TempDataSize\r
1666 );\r
1667 if (EFI_ERROR (Status)) {\r
1668 CreatePopUp (\r
1669 EFI_LIGHTGRAY | EFI_BACKGROUND_BLUE,\r
1670 &Key,\r
1671 L"ERROR: Can't read this private key file!",\r
1672 NULL\r
1673 );\r
1674 } else {\r
1675\r
1676 ASSERT (Private->FileContext->FileName != NULL);\r
1677\r
1678 Profile->PrivateKeyData = TempData;\r
1679 Profile->PrivateKeyDataSize = TempDataSize;\r
1680 StrCpyS(Profile->PrivateKeyName, WIFI_FILENAME_STR_MAX_SIZE, Private->FileContext->FileName);\r
1681\r
1682 DEBUG ((DEBUG_INFO, "[WiFi Connection Manager] Private Key: %s has been enrolled! Size: %d\n",\r
1683 Profile->PrivateKeyName, Profile->PrivateKeyDataSize));\r
1684 }\r
1685 }\r
1686 break;\r
1687\r
1688 case KEY_SAVE_CERT_TO_MEM:\r
1689\r
1690 if (Private->FileContext != NULL && Private->FileContext->FHandle != NULL &&\r
1691 Private->CurrentNic->UserSelectedProfile != NULL) {\r
1692\r
1693 //\r
1694 // Read Cert file to Buffer\r
1695 //\r
1696 Profile = Private->CurrentNic->UserSelectedProfile;\r
1697\r
1698 if (Private->FileType == FileTypeCACert) {\r
1699 if (Profile->CACertData != NULL) {\r
1700\r
1701 ZeroMem (Profile->CACertData, Profile->CACertSize);\r
1702 FreePool (Profile->CACertData);\r
1703 }\r
1704 } else if (Private->FileType == FileTypeClientCert) {\r
1705 if (Profile->ClientCertData != NULL) {\r
1706\r
1707 ZeroMem (Profile->ClientCertData, Profile->ClientCertSize);\r
1708 FreePool (Profile->ClientCertData);\r
1709 }\r
1710 } else {\r
1711 break;\r
1712 }\r
1713\r
1714 Status = WifiMgrReadFileToBuffer (\r
1715 Private->FileContext,\r
1716 &TempData,\r
1717 &TempDataSize\r
1718 );\r
1719 if (EFI_ERROR (Status)) {\r
1720 CreatePopUp (\r
1721 EFI_LIGHTGRAY | EFI_BACKGROUND_BLUE,\r
1722 &Key,\r
1723 L"ERROR: Can't read this certificate file!",\r
1724 NULL\r
1725 );\r
1726 } else {\r
1727\r
1728 ASSERT (Private->FileContext->FileName != NULL);\r
1729 if (Private->FileType == FileTypeCACert) {\r
1730\r
1731 Profile->CACertData = TempData;\r
1732 Profile->CACertSize = TempDataSize;\r
1733 StrCpyS(Profile->CACertName, WIFI_FILENAME_STR_MAX_SIZE, Private->FileContext->FileName);\r
1734 DEBUG ((DEBUG_INFO, "[WiFi Connection Manager] CA Cert: %s has been enrolled! Size: %d\n",\r
1735 Profile->CACertName, Profile->CACertSize));\r
1736 } else {\r
1737\r
1738 Profile->ClientCertData = TempData;\r
1739 Profile->ClientCertSize = TempDataSize;\r
1740 StrCpyS(Profile->ClientCertName, WIFI_FILENAME_STR_MAX_SIZE, Private->FileContext->FileName);\r
1741 DEBUG ((DEBUG_INFO, "[WiFi Connection Manager] Client Cert: %s has been enrolled! Size: %d\n",\r
1742 Profile->ClientCertName, Profile->ClientCertSize));\r
1743 }\r
1744 }\r
1745 }\r
1746 break;\r
1747\r
1748 case KEY_ADD_HIDDEN_NETWORK:\r
1749\r
1750 //\r
1751 // Add a Hidden Network\r
1752 //\r
1753 if (StrLen (IfrNvData->SSId) < SSID_MIN_LEN ||\r
1754 Private->HiddenNetworkCount >= HIDDEN_NETWORK_LIST_COUNT_MAX) {\r
1755\r
1756 Status = EFI_ABORTED;\r
1757 break;\r
1758 } else {\r
1759\r
1760 //\r
1761 // Check if this SSId is already in Hidden Network List\r
1762 //\r
1763 NET_LIST_FOR_EACH (Entry, &Private->HiddenNetworkList) {\r
1764\r
1765 HiddenNetwork = NET_LIST_USER_STRUCT_S (Entry, WIFI_HIDDEN_NETWORK_DATA,\r
1766 Link, WIFI_MGR_HIDDEN_NETWORK_SIGNATURE);\r
1767 if (StrCmp (HiddenNetwork->SSId, IfrNvData->SSId) == 0) {\r
1768\r
1769 Status = EFI_ABORTED;\r
1770 break;\r
1771 }\r
1772 }\r
1773 }\r
1774\r
1775 HiddenNetwork = (WIFI_HIDDEN_NETWORK_DATA *) AllocateZeroPool (sizeof (WIFI_HIDDEN_NETWORK_DATA));\r
1776 if (HiddenNetwork == NULL) {\r
1777\r
1778 Status = EFI_OUT_OF_RESOURCES;\r
1779 break;\r
1780 }\r
1781 HiddenNetwork->Signature = WIFI_MGR_HIDDEN_NETWORK_SIGNATURE;\r
1782 StrCpyS (HiddenNetwork->SSId, SSID_STORAGE_SIZE, IfrNvData->SSId);\r
1783\r
1784 InsertTailList (&Private->HiddenNetworkList, &HiddenNetwork->Link);\r
1785 Private->HiddenNetworkCount ++;\r
1786\r
1787 WifiMgrRefreshHiddenList (Private);\r
1788 break;\r
1789\r
1790 case KEY_REMOVE_HIDDEN_NETWORK:\r
1791\r
1792 //\r
1793 // Remove Hidden Networks\r
1794 //\r
1795 Entry = GetFirstNode (&Private->HiddenNetworkList);\r
1796 RemoveCount = 0;\r
1797 for (Index = 0; Index < Private->HiddenNetworkCount; Index ++) {\r
1798 if (IfrNvData->HiddenNetworkList[Index] != 0) {\r
1799\r
1800 HiddenNetwork = NET_LIST_USER_STRUCT_S (Entry, WIFI_HIDDEN_NETWORK_DATA, Link, WIFI_MGR_HIDDEN_NETWORK_SIGNATURE);\r
1801 Entry = RemoveEntryList (Entry);\r
1802 RemoveCount ++;\r
1803\r
1804 FreePool (HiddenNetwork);\r
1805 } else {\r
1806 Entry = GetNextNode (&Private->HiddenNetworkList, Entry);\r
1807 }\r
1808 }\r
1809\r
1810 Private->HiddenNetworkCount -= RemoveCount;\r
1811 WifiMgrRefreshHiddenList (Private);\r
1812 break;\r
1813\r
1814 default:\r
1815\r
1816 if (QuestionId >= KEY_MAC_ENTRY_BASE && QuestionId < KEY_MAC_ENTRY_BASE + Private->NicCount) {\r
1817 //\r
1818 // User selects a wireless NIC.\r
1819 //\r
1820 Status = WifiMgrSelectNic (Private, QuestionId);\r
1821 if (EFI_ERROR (Status)) {\r
1822 CreatePopUp (\r
1823 EFI_LIGHTGRAY | EFI_BACKGROUND_BLUE,\r
1824 &Key,\r
1825 L"ERROR: Fail to operate the wireless NIC!",\r
1826 NULL\r
1827 );\r
1828 }\r
1829 } else if (Private->CurrentNic != NULL) {\r
1830 if (QuestionId >= KEY_AVAILABLE_NETWORK_ENTRY_BASE &&\r
1831 QuestionId <= KEY_AVAILABLE_NETWORK_ENTRY_BASE + Private->CurrentNic->MaxProfileIndex) {\r
1832\r
1833 Status = WifiMgrUserSelectProfileToConnect (Private, QuestionId - KEY_AVAILABLE_NETWORK_ENTRY_BASE);\r
1834 if (!EFI_ERROR (Status)) {\r
1835 WifiMgrUpdateConnectMessage(Private->CurrentNic, FALSE, NULL);\r
1836 }\r
1837 }\r
1838\r
1839 if (EFI_ERROR (Status)) {\r
1840 CreatePopUp (\r
1841 EFI_LIGHTGRAY | EFI_BACKGROUND_BLUE,\r
1842 &Key,\r
1843 L"ERROR: Fail to operate this profile!",\r
1844 NULL\r
1845 );\r
1846 }\r
1847 }\r
1848\r
1849 break;\r
1850 }\r
1851 } else if (Action == EFI_BROWSER_ACTION_CHANGED) {\r
1852 switch (QuestionId) {\r
1853\r
1854 case KEY_SAVE_CERT_TO_MEM:\r
1855 case KEY_SAVE_PRIVATE_KEY_TO_MEM:\r
1856\r
1857 *ActionRequest = EFI_BROWSER_ACTION_REQUEST_FORM_SUBMIT_EXIT;\r
1858 break;\r
1859\r
1860 case KEY_NO_SAVE_CERT_TO_MEM:\r
1861 case KEY_NO_SAVE_PRIVATE_KEY_TO_MEM:\r
1862\r
1863 *ActionRequest = EFI_BROWSER_ACTION_REQUEST_FORM_DISCARD_EXIT;\r
1864 break;\r
1865\r
1866 default:\r
1867\r
1868 *ActionRequest = EFI_BROWSER_ACTION_REQUEST_FORM_APPLY;\r
1869 break;\r
1870 }\r
1871 } else if (Action == EFI_BROWSER_ACTION_RETRIEVE) {\r
1872\r
1873 switch (QuestionId) {\r
1874\r
1875 case KEY_REFRESH_NETWORK_LIST:\r
1876\r
1877 WifiMgrRefreshNetworkList (Private, IfrNvData);\r
1878 break;\r
1879\r
1880 default:\r
1881 break;\r
1882 }\r
1883 }\r
1884\r
1885 if (!EFI_ERROR (Status)) {\r
1886 //\r
1887 // Pass changed uncommitted data back to Form Browser.\r
1888 //\r
1889 BufferSize = sizeof (WIFI_MANAGER_IFR_NVDATA);\r
1890 HiiSetBrowserData (&gWifiConfigFormSetGuid, mVendorStorageName, BufferSize, (UINT8 *) IfrNvData, NULL);\r
1891 }\r
1892\r
1893 ZeroMem (IfrNvData, sizeof (WIFI_MANAGER_IFR_NVDATA));\r
1894 FreePool (IfrNvData);\r
1895 return Status;\r
1896}\r
1897\r
1898/**\r
1899 Initialize the WiFi configuration form.\r
1900\r
1901 @param[in] Private The pointer to the global private data structure.\r
1902\r
1903 @retval EFI_SUCCESS The configuration form is initialized.\r
1904 @retval EFI_OUT_OF_RESOURCES Failed to allocate memory.\r
1905 @retval EFI_INVALID_PARAMETER Any input parameter is invalid.\r
1906 @retval Other Erros Returned Errors when installing protocols.\r
1907\r
1908**/\r
1909EFI_STATUS\r
1910WifiMgrDxeConfigFormInit (\r
1911 WIFI_MGR_PRIVATE_DATA *Private\r
1912)\r
1913{\r
1914 EFI_STATUS Status;\r
1915\r
1916 if (Private == NULL) {\r
1917 return EFI_INVALID_PARAMETER;\r
1918 }\r
1919\r
1920 Private->ConfigAccess.ExtractConfig = WifiMgrDxeHiiConfigAccessExtractConfig;\r
1921 Private->ConfigAccess.RouteConfig = WifiMgrDxeHiiConfigAccessRouteConfig;\r
1922 Private->ConfigAccess.Callback = WifiMgrDxeHiiConfigAccessCallback;\r
1923\r
1924 //\r
1925 // Install Device Path Protocol and Config Access protocol to driver handle.\r
1926 //\r
1927 Status = gBS->InstallMultipleProtocolInterfaces (\r
1928 &Private->DriverHandle,\r
1929 &gEfiDevicePathProtocolGuid,\r
1930 &mWifiMgrDxeHiiVendorDevicePath,\r
1931 &gEfiHiiConfigAccessProtocolGuid,\r
1932 &Private->ConfigAccess,\r
1933 NULL\r
1934 );\r
1935 if (EFI_ERROR (Status)) {\r
1936 return Status;\r
1937 }\r
1938\r
1939 //\r
1940 // Publish our HII data.\r
1941 //\r
1942 Private->RegisteredHandle = HiiAddPackages (\r
1943 &gWifiConfigFormSetGuid,\r
1944 Private->DriverHandle,\r
1945 WifiConnectionManagerDxeStrings,\r
1946 WifiConnectionManagerDxeBin,\r
1947 NULL\r
1948 );\r
1949 if (Private->RegisteredHandle == NULL) {\r
1950 gBS->UninstallMultipleProtocolInterfaces (\r
1951 Private->DriverHandle,\r
1952 &gEfiDevicePathProtocolGuid,\r
1953 &mWifiMgrDxeHiiVendorDevicePath,\r
1954 &gEfiHiiConfigAccessProtocolGuid,\r
1955 &Private->ConfigAccess,\r
1956 NULL\r
1957 );\r
1958 return EFI_OUT_OF_RESOURCES;\r
1959 }\r
1960\r
1961 Private->FileContext = AllocateZeroPool (sizeof (WIFI_MGR_FILE_CONTEXT));\r
1962 if (Private->FileContext == NULL) {\r
1963 return EFI_OUT_OF_RESOURCES;\r
1964 }\r
1965\r
1966 return EFI_SUCCESS;\r
1967}\r
1968\r
1969/**\r
1970 Unload the WiFi configuration form.\r
1971\r
1972 @param[in] Private The pointer to the global private data structure.\r
1973\r
1974 @retval EFI_SUCCESS The configuration form is unloaded successfully.\r
1975 @retval EFI_INVALID_PARAMETER Any input parameter is invalid.\r
1976 @retval Other Errors Returned Erros when uninstalling protocols.\r
1977\r
1978**/\r
1979EFI_STATUS\r
1980WifiMgrDxeConfigFormUnload (\r
1981 WIFI_MGR_PRIVATE_DATA *Private\r
1982)\r
1983{\r
1984 EFI_STATUS Status;\r
1985\r
1986 if (Private == NULL) {\r
1987 return EFI_INVALID_PARAMETER;\r
1988 }\r
1989\r
1990 if (Private->FileContext != NULL) {\r
1991\r
1992 if (Private->FileContext->FHandle != NULL) {\r
1993 Private->FileContext->FHandle->Close (Private->FileContext->FHandle);\r
1994 }\r
1995\r
1996 if (Private->FileContext->FileName != NULL) {\r
1997 FreePool (Private->FileContext->FileName);\r
1998 }\r
1999 FreePool (Private->FileContext);\r
2000 }\r
2001\r
2002 HiiRemovePackages(Private->RegisteredHandle);\r
2003\r
2004 Status = gBS->UninstallMultipleProtocolInterfaces (\r
2005 Private->DriverHandle,\r
2006 &gEfiDevicePathProtocolGuid,\r
2007 &mWifiMgrDxeHiiVendorDevicePath,\r
2008 &gEfiHiiConfigAccessProtocolGuid,\r
2009 &Private->ConfigAccess,\r
2010 NULL\r
2011 );\r
2012\r
2013 return Status;\r
2014}\r