mirror of https://github.com/acidanthera/audk.git
NetworkPkg: better sanity check on Ipv6 prefix length
Fix a possible buffer overrun issue that could occur if PrefixLength > 128 . Changed == 128 to >= 128. Also remove check for Byte < 16, which is no longer possible because of the first change. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Samer El-Haj-Mahmoud <elhaj@hpe.com> Reviewed-by: Fu Siyuan <siyuan.fu@intel.com>
This commit is contained in:
parent
93aea44f42
commit
40696972bf
|
@ -2,7 +2,8 @@
|
|||
The ICMPv6 handle routines to process the ICMPv6 control messages.
|
||||
|
||||
Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR>
|
||||
|
||||
(C) Copyright 2016 Hewlett Packard Enterprise Development LP<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
|
||||
|
@ -479,7 +480,7 @@ Ip6GetPrefix (
|
|||
return ;
|
||||
}
|
||||
|
||||
if (PrefixLength == IP6_PREFIX_NUM - 1) {
|
||||
if (PrefixLength >= IP6_PREFIX_NUM - 1) {
|
||||
return ;
|
||||
}
|
||||
|
||||
|
@ -487,7 +488,7 @@ Ip6GetPrefix (
|
|||
Bit = (UINT8) (PrefixLength % 8);
|
||||
Value = Prefix->Addr[Byte];
|
||||
|
||||
if ((Byte > 0) && (Byte < 16)) {
|
||||
if (Byte > 0) {
|
||||
ZeroMem (Prefix->Addr + Byte, 16 - Byte);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue