mirror of https://github.com/acidanthera/audk.git
NetworkPkg: Dhcp6Dxe: Removes duplicate check and replaces with macro
Removes duplicate check after merge > > // > // Verify the PacketCursor is within the packet > // > if ( (*PacketCursor < Packet->Dhcp6.Option) > || (*PacketCursor >= Packet->Dhcp6.Option + (Packet->Size - sizeof (EFI_DHCP6_HEADER)))) > { > return EFI_INVALID_PARAMETER; > } > Converts the check to a macro and replaces all instances of the check with the macro Cc: Saloni Kasbekar <saloni.kasbekar@intel.com> Cc: Zachary Clark-williams <zachary.clark-williams@intel.com> Signed-off-by: Doug Flick [MSFT] <doug.edk2@gmail.com> Reviewed-by: Saloni Kasbekar <saloni.kasbekar@intel.com> Reviewed-by: Leif Lindholm <quic_llindhol@quicinc.com>
This commit is contained in:
parent
1c440a5ece
commit
af3fad99d6
|
@ -10,6 +10,16 @@
|
||||||
|
|
||||||
#include "Dhcp6Impl.h"
|
#include "Dhcp6Impl.h"
|
||||||
|
|
||||||
|
//
|
||||||
|
// Verifies the packet cursor is within the packet
|
||||||
|
// otherwise it is invalid
|
||||||
|
//
|
||||||
|
#define IS_INVALID_PACKET_CURSOR(PacketCursor, Packet) \
|
||||||
|
(((*PacketCursor) < (Packet)->Dhcp6.Option) || \
|
||||||
|
((*PacketCursor) >= (Packet)->Dhcp6.Option + ((Packet)->Size - sizeof(EFI_DHCP6_HEADER))) \
|
||||||
|
) \
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Generate client Duid in the format of Duid-llt.
|
Generate client Duid in the format of Duid-llt.
|
||||||
|
|
||||||
|
@ -638,9 +648,7 @@ Dhcp6AppendOption (
|
||||||
//
|
//
|
||||||
// Verify the PacketCursor is within the packet
|
// Verify the PacketCursor is within the packet
|
||||||
//
|
//
|
||||||
if ( (*PacketCursor < Packet->Dhcp6.Option)
|
if (IS_INVALID_PACKET_CURSOR (PacketCursor, Packet)) {
|
||||||
|| (*PacketCursor >= Packet->Dhcp6.Option + (Packet->Size - sizeof (EFI_DHCP6_HEADER))))
|
|
||||||
{
|
|
||||||
return EFI_INVALID_PARAMETER;
|
return EFI_INVALID_PARAMETER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -657,15 +665,6 @@ Dhcp6AppendOption (
|
||||||
return EFI_BUFFER_TOO_SMALL;
|
return EFI_BUFFER_TOO_SMALL;
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
// Verify the PacketCursor is within the packet
|
|
||||||
//
|
|
||||||
if ( (*PacketCursor < Packet->Dhcp6.Option)
|
|
||||||
|| (*PacketCursor >= Packet->Dhcp6.Option + (Packet->Size - sizeof (EFI_DHCP6_HEADER))))
|
|
||||||
{
|
|
||||||
return EFI_INVALID_PARAMETER;
|
|
||||||
}
|
|
||||||
|
|
||||||
WriteUnaligned16 ((UINT16 *)*PacketCursor, OptType);
|
WriteUnaligned16 ((UINT16 *)*PacketCursor, OptType);
|
||||||
*PacketCursor += DHCP6_SIZE_OF_OPT_CODE;
|
*PacketCursor += DHCP6_SIZE_OF_OPT_CODE;
|
||||||
WriteUnaligned16 ((UINT16 *)*PacketCursor, OptLen);
|
WriteUnaligned16 ((UINT16 *)*PacketCursor, OptLen);
|
||||||
|
@ -744,9 +743,7 @@ Dhcp6AppendIaAddrOption (
|
||||||
//
|
//
|
||||||
// Verify the PacketCursor is within the packet
|
// Verify the PacketCursor is within the packet
|
||||||
//
|
//
|
||||||
if ( (*PacketCursor < Packet->Dhcp6.Option)
|
if (IS_INVALID_PACKET_CURSOR (PacketCursor, Packet)) {
|
||||||
|| (*PacketCursor >= Packet->Dhcp6.Option + (Packet->Size - sizeof (EFI_DHCP6_HEADER))))
|
|
||||||
{
|
|
||||||
return EFI_INVALID_PARAMETER;
|
return EFI_INVALID_PARAMETER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -877,9 +874,7 @@ Dhcp6AppendIaOption (
|
||||||
//
|
//
|
||||||
// Verify the PacketCursor is within the packet
|
// Verify the PacketCursor is within the packet
|
||||||
//
|
//
|
||||||
if ( (*PacketCursor < Packet->Dhcp6.Option)
|
if (IS_INVALID_PACKET_CURSOR (PacketCursor, Packet)) {
|
||||||
|| (*PacketCursor >= Packet->Dhcp6.Option + (Packet->Size - sizeof (EFI_DHCP6_HEADER))))
|
|
||||||
{
|
|
||||||
return EFI_INVALID_PARAMETER;
|
return EFI_INVALID_PARAMETER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -940,16 +935,16 @@ Dhcp6AppendIaOption (
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
// Fill the value of Ia option length
|
|
||||||
//
|
|
||||||
*Len = HTONS ((UINT16)(*PacketCursor - (UINT8 *)Len - 2));
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Update the packet length
|
// Update the packet length
|
||||||
//
|
//
|
||||||
Packet->Length += BytesNeeded;
|
Packet->Length += BytesNeeded;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Fill the value of Ia option length
|
||||||
|
//
|
||||||
|
*Len = HTONS ((UINT16)(*PacketCursor - (UINT8 *)Len - 2));
|
||||||
|
|
||||||
return EFI_SUCCESS;
|
return EFI_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -957,6 +952,7 @@ Dhcp6AppendIaOption (
|
||||||
Append the appointed Elapsed time option to Buf, and move Buf to the end.
|
Append the appointed Elapsed time option to Buf, and move Buf to the end.
|
||||||
|
|
||||||
@param[in, out] Packet A pointer to the packet, on success Packet->Length
|
@param[in, out] Packet A pointer to the packet, on success Packet->Length
|
||||||
|
will be updated.
|
||||||
@param[in, out] PacketCursor The pointer in the packet, on success PacketCursor
|
@param[in, out] PacketCursor The pointer in the packet, on success PacketCursor
|
||||||
will be moved to the end of the option.
|
will be moved to the end of the option.
|
||||||
@param[in] Instance The pointer to the Dhcp6 instance.
|
@param[in] Instance The pointer to the Dhcp6 instance.
|
||||||
|
@ -1012,9 +1008,7 @@ Dhcp6AppendETOption (
|
||||||
//
|
//
|
||||||
// Verify the PacketCursor is within the packet
|
// Verify the PacketCursor is within the packet
|
||||||
//
|
//
|
||||||
if ( (*PacketCursor < Packet->Dhcp6.Option)
|
if (IS_INVALID_PACKET_CURSOR (PacketCursor, Packet)) {
|
||||||
|| (*PacketCursor >= Packet->Dhcp6.Option + (Packet->Size - sizeof (EFI_DHCP6_HEADER))))
|
|
||||||
{
|
|
||||||
return EFI_INVALID_PARAMETER;
|
return EFI_INVALID_PARAMETER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue