mirror of https://github.com/acidanthera/audk.git
NetworkPkg: Add old IPv4_DEVICE_PATH and IPv6_DEVICE_PATH support
GatewayIpAddress and SubnetMask do not exist in old IPv4_DEVICE_PATH, IPAddressOrigin, PrefixLength and GatewayIPAddress do not exist in old IPv6_DEVICE_PATH. This will lead new IScsiDxe to error without updating IPv4_DEVICE_PATH and IPv6_DEVICE_PATH in system. Following UEFI2.5 spec of IPv4_DEVICE_PATH do a check before accessing fields only defined in new version's IPv4_DEVICE_PATH, and revise the same issue for IPv6_DEVICE_PATH in Iscsi driver. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: fanwang2 <fan.wang@intel.com> Reviewed-by: Ye Ting <ting.ye@intel.com> [lersek@redhat.com: rewrapped commit message] Signed-off-by: Laszlo Ersek <lersek@redhat.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@18056 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
f18b2162e8
commit
42f0586d61
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Miscellaneous routines for iSCSI driver.
|
Miscellaneous routines for iSCSI driver.
|
||||||
|
|
||||||
Copyright (c) 2004 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2004 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -1352,6 +1352,7 @@ IScsiGetTcpConnDevicePath (
|
||||||
EFI_DEVICE_PATH_PROTOCOL *DevicePath;
|
EFI_DEVICE_PATH_PROTOCOL *DevicePath;
|
||||||
EFI_STATUS Status;
|
EFI_STATUS Status;
|
||||||
EFI_DEV_PATH *DPathNode;
|
EFI_DEV_PATH *DPathNode;
|
||||||
|
UINTN PathLen;
|
||||||
|
|
||||||
if (Session->State != SESSION_STATE_LOGGED_IN) {
|
if (Session->State != SESSION_STATE_LOGGED_IN) {
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -1390,21 +1391,58 @@ IScsiGetTcpConnDevicePath (
|
||||||
DPathNode->Ipv4.StaticIpAddress =
|
DPathNode->Ipv4.StaticIpAddress =
|
||||||
(BOOLEAN) (!Session->ConfigData->SessionConfigData.InitiatorInfoFromDhcp);
|
(BOOLEAN) (!Session->ConfigData->SessionConfigData.InitiatorInfoFromDhcp);
|
||||||
|
|
||||||
IP4_COPY_ADDRESS (
|
//
|
||||||
&DPathNode->Ipv4.GatewayIpAddress,
|
// Add a judgement here to support previous versions of IPv4_DEVICE_PATH.
|
||||||
&Session->ConfigData->SessionConfigData.Gateway
|
// In previous versions of IPv4_DEVICE_PATH, GatewayIpAddress and SubnetMask
|
||||||
);
|
// do not exist.
|
||||||
|
// In new version of IPv4_DEVICE_PATH, structcure length is 27.
|
||||||
|
//
|
||||||
|
|
||||||
|
PathLen = DevicePathNodeLength (&DPathNode->Ipv4);
|
||||||
|
|
||||||
|
if (PathLen == IPv4_NODE_LEN_NEW_VERSIONS) {
|
||||||
|
|
||||||
|
IP4_COPY_ADDRESS (
|
||||||
|
&DPathNode->Ipv4.GatewayIpAddress,
|
||||||
|
&Session->ConfigData->SessionConfigData.Gateway
|
||||||
|
);
|
||||||
|
|
||||||
|
IP4_COPY_ADDRESS (
|
||||||
|
&DPathNode->Ipv4.SubnetMask,
|
||||||
|
&Session->ConfigData->SessionConfigData.SubnetMask
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
IP4_COPY_ADDRESS (
|
|
||||||
&DPathNode->Ipv4.SubnetMask,
|
|
||||||
&Session->ConfigData->SessionConfigData.SubnetMask
|
|
||||||
);
|
|
||||||
break;
|
break;
|
||||||
} else if (Conn->Ipv6Flag && DevicePathSubType (&DPathNode->DevPath) == MSG_IPv6_DP) {
|
} else if (Conn->Ipv6Flag && DevicePathSubType (&DPathNode->DevPath) == MSG_IPv6_DP) {
|
||||||
DPathNode->Ipv6.LocalPort = 0;
|
DPathNode->Ipv6.LocalPort = 0;
|
||||||
DPathNode->Ipv6.IpAddressOrigin = 0;
|
|
||||||
DPathNode->Ipv6.PrefixLength = IP6_PREFIX_LENGTH;
|
//
|
||||||
ZeroMem (&DPathNode->Ipv6.GatewayIpAddress, sizeof (EFI_IPv6_ADDRESS));
|
// Add a judgement here to support previous versions of IPv6_DEVICE_PATH.
|
||||||
|
// In previous versions of IPv6_DEVICE_PATH, IpAddressOrigin, PrefixLength
|
||||||
|
// and GatewayIpAddress do not exist.
|
||||||
|
// In new version of IPv6_DEVICE_PATH, structure length is 60, while in
|
||||||
|
// old versions, the length is 43.
|
||||||
|
//
|
||||||
|
|
||||||
|
PathLen = DevicePathNodeLength (&DPathNode->Ipv6);
|
||||||
|
|
||||||
|
if (PathLen == IPv6_NODE_LEN_NEW_VERSIONS ) {
|
||||||
|
|
||||||
|
DPathNode->Ipv6.IpAddressOrigin = 0;
|
||||||
|
DPathNode->Ipv6.PrefixLength = IP6_PREFIX_LENGTH;
|
||||||
|
ZeroMem (&DPathNode->Ipv6.GatewayIpAddress, sizeof (EFI_IPv6_ADDRESS));
|
||||||
|
}
|
||||||
|
else if (PathLen == IPv6_NODE_LEN_OLD_VERSIONS) {
|
||||||
|
|
||||||
|
//
|
||||||
|
// StaticIPAddress is a field in old versions of IPv6_DEVICE_PATH, while ignored in new
|
||||||
|
// version. Set StaticIPAddress through its' offset in old IPv6_DEVICE_PATH.
|
||||||
|
//
|
||||||
|
*((UINT8 *)(&DPathNode->Ipv6) + IPv6_OLD_IPADDRESS_OFFSET) =
|
||||||
|
(BOOLEAN) (!Session->ConfigData->SessionConfigData.InitiatorInfoFromDhcp);
|
||||||
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Miscellaneous definitions for iSCSI driver.
|
Miscellaneous definitions for iSCSI driver.
|
||||||
|
|
||||||
Copyright (c) 2004 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2004 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -17,6 +17,22 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
||||||
|
|
||||||
typedef struct _ISCSI_DRIVER_DATA ISCSI_DRIVER_DATA;
|
typedef struct _ISCSI_DRIVER_DATA ISCSI_DRIVER_DATA;
|
||||||
|
|
||||||
|
///
|
||||||
|
/// IPv4 Device Path Node Length
|
||||||
|
///
|
||||||
|
#define IPv4_NODE_LEN_NEW_VERSIONS 27
|
||||||
|
|
||||||
|
///
|
||||||
|
/// IPv6 Device Path Node Length
|
||||||
|
///
|
||||||
|
#define IPv6_NODE_LEN_OLD_VERSIONS 43
|
||||||
|
#define IPv6_NODE_LEN_NEW_VERSIONS 60
|
||||||
|
|
||||||
|
///
|
||||||
|
/// The ignored field StaticIpAddress's offset in old IPv6 Device Path
|
||||||
|
///
|
||||||
|
#define IPv6_OLD_IPADDRESS_OFFSET 42;
|
||||||
|
|
||||||
#pragma pack(1)
|
#pragma pack(1)
|
||||||
typedef struct _ISCSI_SESSION_CONFIG_NVDATA {
|
typedef struct _ISCSI_SESSION_CONFIG_NVDATA {
|
||||||
UINT16 TargetPort;
|
UINT16 TargetPort;
|
||||||
|
|
Loading…
Reference in New Issue