mirror of
https://github.com/zeek/zeek.git
synced 2025-10-03 15:18:20 +00:00
Guarding against reading beyond packet data when accessing L2 address
in Radiotap header. This is temporary until we clean up the preceding length check.
This commit is contained in:
parent
f662989c09
commit
cfe9ba28dd
1 changed files with 10 additions and 4 deletions
|
@ -310,18 +310,24 @@ void Packet::ProcessLayer2()
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x01:
|
case 0x01:
|
||||||
l2_dst = pdata + 16;
|
|
||||||
l2_src = pdata + 10;
|
l2_src = pdata + 10;
|
||||||
|
l2_dst = pdata + 16;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x02:
|
case 0x02:
|
||||||
l2_dst = pdata + 4;
|
|
||||||
l2_src = pdata + 16;
|
l2_src = pdata + 16;
|
||||||
|
l2_dst = pdata + 4;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x03:
|
case 0x03:
|
||||||
l2_dst = pdata + 16;
|
// TODO: We should integrate this
|
||||||
l2_src = pdata + 24;
|
// test into the length check above.
|
||||||
|
if ( pdata + 24 + l2_addr_len >= end_of_data )
|
||||||
|
{
|
||||||
|
l2_dst = pdata + 16;
|
||||||
|
l2_src = pdata + 24;
|
||||||
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue