Skip to content
Snippets Groups Projects
Commit 3161b5f0 authored by Daniel Czerwonk's avatar Daniel Czerwonk
Browse files

out of bounds index fix

parent 42839c12
Branches
Tags
No related merge requests found
...@@ -64,23 +64,26 @@ func deserializeMultiProtocolReachNLRI(b []byte) (MultiProtocolReachNLRI, error) ...@@ -64,23 +64,26 @@ func deserializeMultiProtocolReachNLRI(b []byte) (MultiProtocolReachNLRI, error)
return n, nil return n, nil
} }
idx := uint8(0) idx := uint16(0)
for idx < uint8(len(variable)) { for idx < uint16(len(variable)) {
l := numberOfBytesForPrefixLength(variable[idx]) pfxLen := variable[idx]
start := idx + 1 numBytes := uint16(numberOfBytesForPrefixLength(pfxLen))
end := idx + 1 + l idx++
r := uint8(len(variable)) - idx - 1
if r < l { r := uint16(len(variable)) - idx
return MultiProtocolReachNLRI{}, fmt.Errorf("expected %d bytes for NLRI, only %d remaining", l, r) if r < numBytes {
return MultiProtocolReachNLRI{}, fmt.Errorf("expected %d bytes for NLRI, only %d remaining", numBytes, r)
} }
pfx, err := deserializePrefix(variable[start:end], variable[idx], n.AFI) start := idx
end := idx + numBytes
pfx, err := deserializePrefix(variable[start:end], pfxLen, n.AFI)
if err != nil { if err != nil {
return MultiProtocolReachNLRI{}, err return MultiProtocolReachNLRI{}, err
} }
n.Prefixes = append(n.Prefixes, pfx) n.Prefixes = append(n.Prefixes, pfx)
idx = idx + l + 1 idx = idx + numBytes
} }
return n, nil return n, nil
......
...@@ -46,23 +46,26 @@ func deserializeMultiProtocolUnreachNLRI(b []byte) (MultiProtocolUnreachNLRI, er ...@@ -46,23 +46,26 @@ func deserializeMultiProtocolUnreachNLRI(b []byte) (MultiProtocolUnreachNLRI, er
return n, nil return n, nil
} }
idx := uint8(0) idx := uint16(0)
for idx < uint8(len(prefix)) { for idx < uint16(len(prefix)) {
l := numberOfBytesForPrefixLength(prefix[idx]) pfxLen := prefix[idx]
start := idx + 1 numBytes := uint16(numberOfBytesForPrefixLength(pfxLen))
end := idx + 1 + l idx++
r := uint8(len(prefix)) - idx - 1
if r < l { r := uint16(len(prefix)) - idx
return MultiProtocolUnreachNLRI{}, fmt.Errorf("expected %d bytes for NLRI, only %d remaining", l, r) if r < numBytes {
return MultiProtocolUnreachNLRI{}, fmt.Errorf("expected %d bytes for NLRI, only %d remaining", numBytes, r)
} }
pfx, err := deserializePrefix(prefix[start:end], prefix[idx], n.AFI) start := idx
end := idx + numBytes
pfx, err := deserializePrefix(prefix[start:end], pfxLen, n.AFI)
if err != nil { if err != nil {
return MultiProtocolUnreachNLRI{}, err return MultiProtocolUnreachNLRI{}, err
} }
n.Prefixes = append(n.Prefixes, pfx) n.Prefixes = append(n.Prefixes, pfx)
idx = idx + l + 1 idx = idx + numBytes
} }
return n, nil return n, nil
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment