mirror of
https://github.com/nmap/nmap.git
synced 2025-12-25 00:49:01 +00:00
Upgrade libpcap to 1.8.1 (Nmap-specific patches not yet applied)
This commit is contained in:
@@ -20,7 +20,7 @@
|
||||
*/
|
||||
|
||||
#ifndef lint
|
||||
static const char copyright[] =
|
||||
static const char copyright[] _U_ =
|
||||
"@(#) Copyright (c) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 2000\n\
|
||||
The Regents of the University of California. All rights reserved.\n";
|
||||
#endif
|
||||
@@ -30,21 +30,70 @@ The Regents of the University of California. All rights reserved.\n";
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <stdarg.h>
|
||||
#ifdef _WIN32
|
||||
#include "getopt.h"
|
||||
#else
|
||||
#include <unistd.h>
|
||||
#endif
|
||||
#include <errno.h>
|
||||
|
||||
#define MAXIMUM_SNAPLEN 65535
|
||||
|
||||
static char *program_name;
|
||||
|
||||
/* Forwards */
|
||||
static void usage(void) __attribute__((noreturn));
|
||||
static void error(const char *, ...);
|
||||
static void warning(const char *, ...);
|
||||
/*
|
||||
* This was introduced by Clang:
|
||||
*
|
||||
* http://clang.llvm.org/docs/LanguageExtensions.html#has-attribute
|
||||
*
|
||||
* in some version (which version?); it has been picked up by GCC 5.0.
|
||||
*/
|
||||
#ifndef __has_attribute
|
||||
/*
|
||||
* It's a macro, so you can check whether it's defined to check
|
||||
* whether it's supported.
|
||||
*
|
||||
* If it's not, define it to always return 0, so that we move on to
|
||||
* the fallback checks.
|
||||
*/
|
||||
#define __has_attribute(x) 0
|
||||
#endif
|
||||
|
||||
extern int optind;
|
||||
extern int opterr;
|
||||
extern char *optarg;
|
||||
#if __has_attribute(noreturn) \
|
||||
|| (defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 205)) \
|
||||
|| (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590)) \
|
||||
|| (defined(__xlC__) && __xlC__ >= 0x0A01) \
|
||||
|| (defined(__HP_aCC) && __HP_aCC >= 61000)
|
||||
/*
|
||||
* Compiler with support for it, or GCC 2.5 and later, or Solaris Studio 12
|
||||
* (Sun C 5.9) and later, or IBM XL C 10.1 and later (do any earlier
|
||||
* versions of XL C support this?), or HP aCC A.06.10 and later.
|
||||
*/
|
||||
#define PCAP_NORETURN __attribute((noreturn))
|
||||
#elif defined( _MSC_VER )
|
||||
#define PCAP_NORETURN __declspec(noreturn)
|
||||
#else
|
||||
#define PCAP_NORETURN
|
||||
#endif
|
||||
|
||||
#if __has_attribute(__format__) \
|
||||
|| (defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 203)) \
|
||||
|| (defined(__xlC__) && __xlC__ >= 0x0A01) \
|
||||
|| (defined(__HP_aCC) && __HP_aCC >= 61000)
|
||||
/*
|
||||
* Compiler with support for it, or GCC 2.3 and later, or IBM XL C 10.1
|
||||
* and later (do any earlier versions of XL C support this?),
|
||||
* or HP aCC A.06.10 and later.
|
||||
*/
|
||||
#define PCAP_PRINTFLIKE(x,y) __attribute__((__format__(__printf__,x,y)))
|
||||
#else
|
||||
#define PCAP_PRINTFLIKE(x,y)
|
||||
#endif
|
||||
|
||||
/* Forwards */
|
||||
static void PCAP_NORETURN usage(void);
|
||||
static void PCAP_NORETURN error(const char *, ...) PCAP_PRINTFLIKE(1, 2);
|
||||
static void warning(const char *, ...) PCAP_PRINTFLIKE(1, 2);
|
||||
|
||||
int
|
||||
main(int argc, char **argv)
|
||||
@@ -113,10 +162,15 @@ main(int argc, char **argv)
|
||||
}
|
||||
}
|
||||
|
||||
if (device == NULL) {
|
||||
device = pcap_lookupdev(ebuf);
|
||||
if (device == NULL)
|
||||
error("pcap_lookupdev failed: %s", ebuf);
|
||||
}
|
||||
if (useactivate) {
|
||||
pd = pcap_create(device, ebuf);
|
||||
if (pd == NULL)
|
||||
error("%s", ebuf);
|
||||
error("%s: pcap_create failed: %s", device, ebuf);
|
||||
status = pcap_set_snaplen(pd, snaplen);
|
||||
if (status != 0)
|
||||
error("%s: pcap_set_snaplen failed: %s",
|
||||
@@ -157,7 +211,8 @@ main(int argc, char **argv)
|
||||
*/
|
||||
warning("%s: %s\n(%s)", device,
|
||||
pcap_statustostr(status), pcap_geterr(pd));
|
||||
}
|
||||
} else
|
||||
printf("%s opened successfully\n", device);
|
||||
} else {
|
||||
*ebuf = '\0';
|
||||
pd = pcap_open_live(device, 65535, 0, 1000, ebuf);
|
||||
@@ -165,6 +220,8 @@ main(int argc, char **argv)
|
||||
error("%s", ebuf);
|
||||
else if (*ebuf)
|
||||
warning("%s", ebuf);
|
||||
else
|
||||
printf("%s opened successfully\n", device);
|
||||
}
|
||||
pcap_close(pd);
|
||||
exit(status < 0 ? 1 : 0);
|
||||
|
||||
Reference in New Issue
Block a user