v2: *1. Add IScsiDnsIsConfigured function in IScsiSupported to check attempt using DNS protocol or not.2. Fix wrongs typos in IScsiDns.c and .uni file.3. define a macro for the length of target URL.4. update the Copyright to 2017. Add DNS support for target URL directly configuration in UI. Besides, When we enable the option (Get target info via DHCP) , the dhcp server will return target info include the rootpath, like the format "iscsi:"<servername>":"<protocol>":"<port>":"<LUN>":"<targetname> According to the RFC 4173,the server name region is expressed as IPv4(192.168.10.20 )or IPv6 ([2000:bbbb::3]) or domain name, but currently we only support the IP address format. To enable this feature, we can support both. Another enhancement is that we can deal with the data received from the iSCSI login response with an target redirection status, in which contains the Target Address in the format domainname[:port][,portal-group-tag] required by RFC 3720. 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.0 Signed-off-by: Zhang Lubo <lubo.zhang@intel.com> Reviewed-by: Wu Jiaxin <jiaxin.wu@intel.com> Reviewed-by: Ye Ting <ting.ye@intel.com> Reviewed-by: Fu Siyuan <siyuan.fu@intel.com>
		
			
				
	
	
		
			59 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|  The header file of routines for IScsi driver to perform DNS
 | |
|  resolution based on UEFI DNS protocols.
 | |
| 
 | |
| Copyright (c) 2017, 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 _ISCSI_DNS_H_
 | |
| #define _ISCSI_DNS_H_
 | |
| 
 | |
| /**
 | |
|   Retrieve the host address using the EFI_DNS4_PROTOCOL.
 | |
| 
 | |
|   @param[in]  Image               The handle of the driver image.
 | |
|   @param[in]  Controller          The handle of the controller.
 | |
|   @param[in, out]  NvData         The Session config data structure.
 | |
| 
 | |
|   @retval EFI_SUCCESS             Operation succeeded.
 | |
|   @retval EFI_OUT_OF_RESOURCES    Failed to allocate needed resources.
 | |
|   @retval EFI_DEVICE_ERROR        An unexpected network error occurred.
 | |
|   @retval Others                  Other errors as indicated.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| IScsiDns4 (
 | |
|   IN     EFI_HANDLE                      Image,
 | |
|   IN     EFI_HANDLE                      Controller,
 | |
|   IN OUT ISCSI_SESSION_CONFIG_NVDATA     *NvData
 | |
|   );
 | |
| 
 | |
| /**
 | |
|   Retrieve the host address using the EFI_DNS6_PROTOCOL.
 | |
| 
 | |
|   @param[in]  Image               The handle of the driver image.
 | |
|   @param[in]  Controller          The handle of the controller.
 | |
|   @param[in, out]  NvData         The Session config data structure.
 | |
| 
 | |
|   @retval EFI_SUCCESS             Operation succeeded.
 | |
|   @retval EFI_OUT_OF_RESOURCES    Failed to allocate needed resources.
 | |
|   @retval EFI_DEVICE_ERROR        An unexpected network error occurred.
 | |
|   @retval Others                  Other errors as indicated.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| IScsiDns6 (
 | |
|   IN     EFI_HANDLE                      Image,
 | |
|   IN     EFI_HANDLE                      Controller,
 | |
|   IN OUT ISCSI_SESSION_CONFIG_NVDATA     *NvData
 | |
|   );
 | |
| 
 | |
| #endif |