Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/external/bsd/libpcap/dist make the patch compile on NetBSD



details:   https://anonhg.NetBSD.org/src/rev/dc00d0565c24
branches:  trunk
changeset: 970608:dc00d0565c24
user:      christos <christos%NetBSD.org@localhost>
date:      Sun Mar 29 19:50:23 2020 +0000

description:
make the patch compile on NetBSD

diffstat:

 external/bsd/libpcap/dist/pcap-rpcap-unix.c |  64 +++++++++++++---------------
 1 files changed, 30 insertions(+), 34 deletions(-)

diffs (236 lines):

diff -r 1df9013732d0 -r dc00d0565c24 external/bsd/libpcap/dist/pcap-rpcap-unix.c
--- a/external/bsd/libpcap/dist/pcap-rpcap-unix.c       Sun Mar 29 19:49:26 2020 +0000
+++ b/external/bsd/libpcap/dist/pcap-rpcap-unix.c       Sun Mar 29 19:50:23 2020 +0000
@@ -51,7 +51,7 @@
 #include <time.h>
 #include <sys/time.h>
 #include <netinet/in.h>
-#include <linux/types.h>
+#include <sys/types.h>
 
 #include "pcap-rpcap-unix.h"
 
@@ -113,17 +113,17 @@
 }
 
 static int
-rpcap_recv_pkt(pcap_t *p, int fd, char *recv_buf, unsigned int buflen)
+rpcap_recv_pkt(pcap_t *p, int fd, unsigned char *recv_buf, unsigned int buflen)
 {
-       static char discard[1024];
+       static unsigned char discard[1024];
 
        size_t mlen;
        int ret;
-       char *buf;
+       unsigned char *buf;
        unsigned int len;
        unsigned int pkt_len;
 
-       char hdr[8];
+       unsigned char hdr[8];
        int pkt_type;
 
 /* read header loop */
@@ -162,7 +162,7 @@
        pkt_len  = get32(&hdr[4]);
 
        if (pkt_type == RPCAP_MSG_ERROR) {
-               recv_buf = p->errbuf;
+               recv_buf = (unsigned char *)p->errbuf;
                buflen = PCAP_ERRBUF_SIZE-1;
        }
 
@@ -216,10 +216,8 @@
 }
 
 static int
-rpcap_send_pkt(pcap_t *p, const char *send_buf, unsigned int len)
+rpcap_send_pkt(pcap_t *p, const unsigned char *send_buf, unsigned int len)
 {
-       char *buf;
-
        size_t mlen;
        int ret;
 
@@ -252,7 +250,7 @@
 }
 
 static int
-rpcap_send_request(pcap_t *p, char type, char *buf, unsigned int payload_len)
+rpcap_send_request(pcap_t *p, char type, unsigned char *buf, unsigned int payload_len)
 {
        buf[0] = RPCAP_VERSION_EXPERIMENTAL;
        buf[1] = type;
@@ -265,14 +263,13 @@
 static int
 rpcap_send_request_auth(pcap_t *p, const char *username, const char *password)
 {
-       int res;
 
        if (username || password) {
                snprintf(p->errbuf, PCAP_ERRBUF_SIZE, "rpcap: auth not supported (yet!)");
                return -1;
 
        } else {
-               static const char login_null_pkt[16] = { 
+               static const unsigned char login_null_pkt[16] = { 
                        RPCAP_VERSION_EXPERIMENTAL,
                        RPCAP_MSG_AUTH_REQ, 
                        0, 0, 
@@ -293,14 +290,14 @@
 {
        const size_t interface_len = strlen(interface);
 
-       char buf_open[8+255] = { 
+       unsigned char buf_open[8+255] = { 
                RPCAP_VERSION_EXPERIMENTAL, 
                RPCAP_MSG_OPEN_REQ, 
                0, 0, 
                0, 0, 0, interface_len
        };
 
-       char reply_buf[8];
+       unsigned char reply_buf[8];
        int reply_len;
 
        if (interface_len > 255) {
@@ -328,7 +325,7 @@
 static int
 rpcap_send_request_start(pcap_t *p, struct in_addr *server_ip)
 {
-       char buf_start[8+12+8+8] = { 
+       unsigned char buf_start[8+12+8+8] = { 
                RPCAP_VERSION_EXPERIMENTAL, 
                RPCAP_MSG_STARTCAP_REQ, 
                0, 0, 
@@ -350,15 +347,14 @@
        };
 
        struct sockaddr_in sin;
-       char reply_buf[8];
+       unsigned char reply_buf[8];
        int reply_len;
        int fd;
 
-       unsigned int buf_size;
        unsigned short portdata;
 
        put32(&buf_start[8], p->snapshot);      /* snaplen */
-       put32(&buf_start[12], p->md.timeout/2); /* read_timeout */
+       put32(&buf_start[12], p->opt.timeout/2); /* read_timeout */
 
        if (rpcap_send_pkt(p, buf_start, sizeof(buf_start)))
                return -1;
@@ -370,7 +366,7 @@
                return -1;
        }
 
-       buf_size = get32(&reply_buf[0]);
+       get32(&reply_buf[0]);
        portdata = get16(&reply_buf[4]);
 
        fd = socket(AF_INET, SOCK_STREAM, 0);
@@ -405,14 +401,14 @@
 static int
 rpcap_stats_common(pcap_t *handle, struct pcap_stat *stats)
 {
-       static const char buf_stats[8] = {
+       static const unsigned char buf_stats[8] = {
                RPCAP_VERSION_EXPERIMENTAL, 
                RPCAP_MSG_STATS_REQ, 
                0, 0, 
                0, 0, 0, 0
        };
 
-       char reply_buf[16];
+       unsigned char reply_buf[16];
        int reply_len;
 
 /* local */
@@ -442,7 +438,7 @@
 static int 
 rpcap_setfilter_common(pcap_t *handle, struct bpf_program *prog)
 {
-       char *buf_setfilter;
+       unsigned char *buf_setfilter;
 
        /* update local filter */
        if (install_bpf_program(handle, prog) == -1)
@@ -451,9 +447,9 @@
        /* update remote filter */
        if (prog->bf_len < 0xfffff) {
                unsigned int data_size = 8 + 8 * prog->bf_len;
-               char *buf_filter;
-               char *buf_insn;
-               int i;
+               unsigned char *buf_filter;
+               unsigned char *buf_insn;
+               size_t i;
 
                buf_setfilter = malloc(8 + data_size);
                if (!buf_setfilter) {
@@ -469,7 +465,7 @@
                put32(&buf_filter[4], prog->bf_len);
 
                for (i = 0; i < prog->bf_len; i++) {
-                       char *data = &buf_insn[i * 8];
+                       unsigned char *data = &buf_insn[i * 8];
 
                        put16(&data[0], prog->bf_insns[i].code);
                        data[2] = prog->bf_insns[i].jt;
@@ -493,14 +489,14 @@
 rpcap_read_unix(pcap_t *handle, int max_packets, pcap_handler callback, u_char *user)
 {
        struct pcap_pkthdr pkth;
-       const char *pkt;
-       const char *buf;
-       int pkt_len;
+       const unsigned char *pkt;
+       const unsigned char *buf;
+       unsigned int pkt_len;
        int count = 0;
 
        pkt_len = rpcap_recv_pkt(handle, handle->selectable_fd, handle->buffer, handle->bufsize);
        if (pkt_len < 20) {
-               if (pkt_len >= 0) {
+               if (pkt_len == 0) {
                        snprintf(handle->errbuf, PCAP_ERRBUF_SIZE, "pkt_len check failed (%u < 20)", pkt_len);
                        return -1;
                }
@@ -531,7 +527,7 @@
        if (handle->fcode.bf_insns == NULL ||
                        bpf_filter(handle->fcode.bf_insns, pkt, pkth.len, pkth.caplen)) 
        {
-               handle->md.packets_read++;
+//             handle->md.packets_read++;
                callback(user, &pkth, pkt);
                count++;
        }
@@ -555,7 +551,7 @@
 static int
 rpcap_activate(pcap_t *handle)
 {
-       const char *dev = handle->opt.source;
+       const char *dev = handle->opt.device;
        const char *tmp;
 
        char *host;
@@ -652,7 +648,7 @@
        sin.sin_family = AF_INET;
        sin.sin_addr.s_addr = inet_addr(host);
        sin.sin_port = htons(port);
-       if (sin.sin_addr.s_addr == -1) {
+       if (sin.sin_addr.s_addr == INADDR_NONE) {
                snprintf(handle->errbuf, PCAP_ERRBUF_SIZE, "rpcap: not ipv4 address");
                goto free_fail;
        }
@@ -756,7 +752,7 @@
 
        *is_ours = 1;
 
-       p = pcap_create_common(device, err_str);
+       p = pcap_create_common(__UNCONST(device), 16384);
        if (p == NULL)
                return NULL;
 



Home | Main Index | Thread Index | Old Index