Fixes a heap overflow found with American Fuzzy Lop by Hanno Böck.
Fix a length value to be unsigned while we're at it.
#include "netdissect.h"
#include "addrtoname.h"
#include "netdissect.h"
#include "addrtoname.h"
-#define RFC1483LLC_LEN 8
-
static const unsigned char rfcllc[] = {
0xaa, /* DSAP: non-ISO */
0xaa, /* SSAP: non-ISO */
static const unsigned char rfcllc[] = {
0xaa, /* DSAP: non-ISO */
0xaa, /* SSAP: non-ISO */
0x00 };
static inline void
0x00 };
static inline void
-cip_print(netdissect_options *ndo, int length)
+cip_print(netdissect_options *ndo, u_int length)
{
/*
* There is no MAC-layer header, so just print the length.
*/
{
/*
* There is no MAC-layer header, so just print the length.
*/
- ND_PRINT((ndo, "%d: ", length));
+ ND_PRINT((ndo, "%u: ", length));
{
u_int caplen = h->caplen;
u_int length = h->len;
{
u_int caplen = h->caplen;
u_int length = h->len;
- if (memcmp(rfcllc, p, sizeof(rfcllc))==0 && caplen < RFC1483LLC_LEN) {
- ND_PRINT((ndo, "[|cip]"));
- return (0);
- }
+ cmplen = sizeof(rfcllc);
+ if (cmplen > caplen)
+ cmplen = caplen;
+ if (cmplen > length)
+ cmplen = length;
if (ndo->ndo_eflag)
cip_print(ndo, length);
if (ndo->ndo_eflag)
cip_print(ndo, length);
- if (memcmp(rfcllc, p, sizeof(rfcllc)) == 0) {
+ if (cmplen == 0) {
+ ND_PRINT((ndo, "[|cip]"));
+ return 0;
+ }
+ if (memcmp(rfcllc, p, cmplen) == 0) {
/*
* LLC header is present. Try to print it & higher layers.
*/
/*
* LLC header is present. Try to print it & higher layers.
*/
# bad packets from Hanno Böck
heap-overflow-1 heap-overflow-1.pcap heap-overflow-1.out -t -v -n
# bad packets from Hanno Böck
heap-overflow-1 heap-overflow-1.pcap heap-overflow-1.out -t -v -n
+heap-overflow-2 heap-overflow-2.pcap heap-overflow-2.out -t -v -n