mirror of
				https://github.com/acidanthera/audk.git
				synced 2025-10-26 16:53:49 +01:00 
			
		
		
		
	* V2 * Remove Arch dependency in Inf file * Add a global guid for WiFi formset and set other guids to module levels * Open supplicant and EapConfig by BY_DRIVER * Remove token free function to avoid potential NULL reference * Update WifiMgrUpdateConnectMessage() to only display message for Current Nic * Fix the potential NULL reference in AIP call * REF: https://bugzilla.tianocore.org/show_bug.cgi?id=1492 Add WiFi Connection Manager in NetworkPkg to provide UI for users to scan networks, connect or disconnect to networks. This connection manager won't include the UNDI driver, supplicant driver, or other device specific drivers and is therefor not a complete solution stack for UEFI Wi-Fi, users can seek help for Wireless card vendors. Cc: Ye Ting <ting.ye@intel.com> Cc: Fu Siyuan <siyuan.fu@intel.com> Cc: Wu Jiaxin <jiaxin.wu@intel.com> Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Wang Fan <fan.wang@intel.com> Reviewed-by: Wu Jiaxin <jiaxin.wu@intel.com> Reviewed-by: Siyuan Fu <siyuan.fu@intel.com>
		
			
				
	
	
		
			106 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|   The Mac Connection2 Protocol adapter functions for WiFi Connection Manager.
 | |
| 
 | |
|   Copyright (c) 2019, Intel Corporation. All rights reserved.<BR>
 | |
| 
 | |
|   This program and the accompanying materials
 | |
|   are licensed and made available under the terms and conditions of the BSD License
 | |
|   which accompanies this distribution.  The full text of the license may be found at
 | |
|   http://opensource.org/licenses/bsd-license.php.
 | |
| 
 | |
|   THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
 | |
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
 | |
| 
 | |
| **/
 | |
| 
 | |
| #ifndef __EFI_WIFI_IMPL__
 | |
| #define __EFI_WIFI_IMPL__
 | |
| 
 | |
| /**
 | |
|   Start scan operation, and send out a token to collect available networks.
 | |
| 
 | |
|   @param[in]  Nic                 Pointer to the device data of the selected NIC.
 | |
| 
 | |
|   @retval EFI_SUCCESS             The operation is completed.
 | |
|   @retval EFI_ALREADY_STARTED     A former scan operation is already ongoing.
 | |
|   @retval EFI_INVALID_PARAMETER   One or more parameters are invalid.
 | |
|   @retval EFI_OUT_OF_RESOURCES    Failed to allocate memory.
 | |
|   @retval Other Errors            Return errors when getting networks from low layer.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| WifiMgrStartScan (
 | |
|   IN      WIFI_MGR_DEVICE_DATA        *Nic
 | |
|   );
 | |
| 
 | |
| /**
 | |
|   Get current link state from low layer.
 | |
| 
 | |
|   @param[in]   Nic                Pointer to the device data of the selected NIC.
 | |
|   @param[out]  LinkState          The pointer to buffer to retrieve link state.
 | |
| 
 | |
|   @retval EFI_SUCCESS             The operation is completed.
 | |
|   @retval EFI_INVALID_PARAMETER   One or more parameters are invalid.
 | |
|   @retval EFI_UNSUPPORTED         Adapter information protocol is not supported.
 | |
|   @retval Other Errors            Returned errors when retrieving link state from low layer.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| WifiMgrGetLinkState (
 | |
|   IN    WIFI_MGR_DEVICE_DATA          *Nic,
 | |
|   OUT   EFI_ADAPTER_INFO_MEDIA_STATE  *LinkState
 | |
|   );
 | |
| 
 | |
| /**
 | |
|   Start connect operation, and send out a token to connect to a target network.
 | |
| 
 | |
|   @param[in]  Nic                 Pointer to the device data of the selected NIC.
 | |
|   @param[in]  Profile             The target network to be connected.
 | |
| 
 | |
|   @retval EFI_SUCCESS             The operation is completed.
 | |
|   @retval EFI_ALREADY_STARTED     Already in "connected" state, need to perform a disconnect
 | |
|                                   operation first.
 | |
|   @retval EFI_INVALID_PARAMETER   One or more parameters are invalid.
 | |
|   @retval EFI_OUT_OF_RESOURCES    Failed to allocate memory.
 | |
|   @retval Other Errors            Return errors when connecting network on low layer.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| WifiMgrConnectToNetwork (
 | |
|   IN    WIFI_MGR_DEVICE_DATA              *Nic,
 | |
|   IN    WIFI_MGR_NETWORK_PROFILE          *Profile
 | |
|   );
 | |
| 
 | |
| /**
 | |
|   Start disconnect operation, and send out a token to disconnect from current connected
 | |
|   network.
 | |
| 
 | |
|   @param[in]  Nic                 Pointer to the device data of the selected NIC.
 | |
| 
 | |
|   @retval EFI_SUCCESS             The operation is completed.
 | |
|   @retval EFI_OUT_OF_RESOURCES    Failed to allocate memory.
 | |
|   @retval Other Errors            Return errors when disconnecting a network on low layer.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| WifiMgrDisconnectToNetwork (
 | |
|   IN    WIFI_MGR_DEVICE_DATA              *Nic
 | |
|   );
 | |
| 
 | |
| /**
 | |
|   The state machine of the connection manager, periodically check the state and
 | |
|   perform a corresponding operation.
 | |
| 
 | |
|   @param[in]  Event                   The timer event to be triggered.
 | |
|   @param[in]  Context                 The context of the Nic device data.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| EFIAPI
 | |
| WifiMgrOnTimerTick (
 | |
|   IN EFI_EVENT              Event,
 | |
|   IN VOID                   *Context
 | |
|   );
 | |
| 
 | |
| #endif
 |