summaryrefslogtreecommitdiff
path: root/pcap-libdlpi.c
diff options
context:
space:
mode:
authorGuy Harris <gharris@steve.local>2009-02-26 01:16:26 -0800
committerGuy Harris <gharris@steve.local>2009-02-26 01:16:26 -0800
commit8cd961c94401c080a53e0ba4c6e54d62a9b6b1da (patch)
tree1ac96c750fcce0b4fe98310f65dae9eb96b55151 /pcap-libdlpi.c
parent936df0fbc137374a0ce9ab0f838815551419711e (diff)
downloadlibpcap-8cd961c94401c080a53e0ba4c6e54d62a9b6b1da.tar.gz
From Sebastien Roy: fix compilation problems on versions of Solaris with
libdlpi.
Diffstat (limited to 'pcap-libdlpi.c')
-rw-r--r--pcap-libdlpi.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/pcap-libdlpi.c b/pcap-libdlpi.c
index 8666117f..87cd08b7 100644
--- a/pcap-libdlpi.c
+++ b/pcap-libdlpi.c
@@ -53,6 +53,7 @@ static int pcap_read_libdlpi(pcap_t *, int, pcap_handler, u_char *);
static int pcap_inject_libdlpi(pcap_t *, const void *, size_t);
static void pcap_close_libdlpi(pcap_t *);
static void pcap_libdlpi_err(const char *, const char *, int, char *);
+static void pcap_cleanup_libdlpi(pcap_t *);
/*
* list_interfaces() will list all the network links that are
@@ -113,7 +114,7 @@ pcap_activate_libdlpi(pcap_t *p)
if (retv != DLPI_SUCCESS) {
if (retv == DLPI_ELINKNAMEINVAL || retv == DLPI_ENOLINK)
err = PCAP_ERROR_NO_SUCH_DEVICE;
- else if (retv == DLPI_SYSERR && errno == EACCES)
+ else if (retv == DL_SYSERR && errno == EACCES)
err = PCAP_ERROR_PERM_DENIED;
pcap_libdlpi_err(p->opt.source, "dlpi_open", retv,
p->errbuf);
@@ -155,8 +156,9 @@ pcap_activate_libdlpi(pcap_t *p)
}
/* Try to enable SAP promiscuity. */
- if ((retv = dlpi_promiscon(p->dlpi_hd, DL_PROMISC_SAP)) != DLPI_SUCCESS) {
- if (!promisc) {
+ retv = dlpi_promiscon(p->dlpi_hd, DL_PROMISC_SAP);
+ if (retv != DLPI_SUCCESS) {
+ if (p->opt.promisc) {
pcap_libdlpi_err(p->opt.source, "dlpi_promisc(SAP)",
retv, p->errbuf);
goto bad;
@@ -179,7 +181,7 @@ pcap_activate_libdlpi(pcap_t *p)
p->fd = dlpi_fd(p->dlpi_hd);
/* Push and configure bufmod. */
- if (pcap_conf_bufmod(p, snaplen, p->md.timeout) != 0)
+ if (pcap_conf_bufmod(p, p->snapshot, p->md.timeout) != 0)
goto bad;
/*