Date: Mon, 28 Feb 2000 05:18:29 -0800 From: Rahul Dhesi <dhesi@rahul.net> To: freebsd-stable@freebsd.org Subject: divert(4) non-working code example Message-ID: <20000228131831.63A783FF09@bolero.rahul.net>
next in thread | raw e-mail | index | archive | help
The following is a relatively simple program that should read and write divert-ed packets, without modifying them. But it never returns from the recvfrom() system call. Any suggestions? An extensive web search appears to indicate that only one existing program, i.e., natd(8), uses divert(4). I found no other examples of anybody using divert(4). Rahul -- cut here -- /* TEST PROGRAM TO SEE IF divert(4) will work */ /* FreeBSD 3.4-STABLE. Kernel currently include options DUMMYNET, IPDIVERT, IPFIREWALL, and IPFIREWALL_DEFAULT_TO_ACCEPT. This code is based on information from the divert(4) man page and also after examining the natd(8) source code. To test: cc -o testdivert testdivert.c ./testdivert >& Log & ipfw add 1 divert 22222 all from 0.0.0.0/0 to xx.xx.xx.xx/32 where xx.xx.xx.xx is the IP address of some other host. Now ping xx.xx.xx.xx. Each ping packet should result in an entry being made into the file 'Log'. But in fact I see no output into 'Log' and no traffic to xx.xx.xx.xx gets through. Tracing with ktrace shows that testdivert is waiting for recvfrom() to return. */ #include <stdio.h> #include <string.h> #include <stdlib.h> #include <errno.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> /* required by netinet/ip.h */ #include <netinet/in_systm.h> /* to define IP_MAXPACKET */ #include <netinet/ip.h> /* big enough to hold a network packet */ #define SZ_PACKET IP_MAXPACKET static char *myname = "testdivert"; int main(int argc, char **argv) { unsigned port = 22222; int socket_fd = -1; char packetbuf[SZ_PACKET]; struct sockaddr_in addr; /* make the socket */ socket_fd = socket(PF_INET, SOCK_RAW, IPPROTO_DIVERT); if (socket_fd == -1) { (void) fprintf(stderr, "%s: error: can't make socket: %s\n", myname, strerror(errno)); exit(1); } addr.sin_family = AF_INET; addr.sin_addr.s_addr = htonl(INADDR_ANY); /* will be ignored by bind() */ addr.sin_port = port; if (bind(socket_fd, (struct sockaddr *) &addr, sizeof addr) == -1) { (void) fprintf(stderr, "%s: error: can't bind socket to port %u: %s\n", myname, port, strerror(errno)); exit(1); } (void) fprintf(stdout, "%s: note: socket_fd is %d, port is %d\n", myname, socket_fd, port); /* make output unbufferd so we can print status dots */ (void) setbuf(stdout, (char *) NULL); /* go into read/write loop */ for ( ; ; ) { int incount; int addrlen; addrlen = sizeof addr; incount = recvfrom(socket_fd, packetbuf, sizeof packetbuf, 0, (struct sockaddr *) &addr, &addrlen); if (incount >= 0) { int sendstatus; (void) fprintf(stdout, "<"); /* < means got a packet */ sendstatus = sendto(socket_fd, packetbuf, incount, 0, (struct sockaddr *) &addr, sizeof addr); if (sendstatus != -1) { (void) fprintf(stdout, ">"); /* > means sent a packet */ } else { (void) fprintf(stdout, "?"); /* ? = send error */ } } else { (void) fprintf(stdout, "."); /* . = receive error */ } } /*NOTREACHED*/ return 0; } -- cut here -- To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-stable" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20000228131831.63A783FF09>