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