From b7b33708f4a961288ea19a9fd7feb155ab975a04 Mon Sep 17 00:00:00 2001 From: hackbard Date: Sun, 15 Jun 2003 14:37:41 +0000 Subject: [PATCH] added udp_{send,rcv}.c --- Makefile | 2 +- udp_rcv.c | 76 +++++++++++++++++++++++++++++++++++++++++++++ udp_send.c | 90 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 167 insertions(+), 1 deletion(-) create mode 100644 udp_rcv.c create mode 100644 udp_send.c diff --git a/Makefile b/Makefile index 432f72a..e01e8a6 100644 --- a/Makefile +++ b/Makefile @@ -6,7 +6,7 @@ CFLAGS = -DDEBUG -O3 -Wall -I/usr/X11/include -I/usr/include/directfb -DVIDEO_DE LIBS = -L/usr/X11/lib -L/usr/lib/directfb-0.9.15 -lX11 -lXext -ldirectfb OBJS = minirgb.o webcam.o -OBJS2 = stream receive datagram dgramrcv +OBJS2 = stream receive datagram dgramrcv udp_rcv udp_send OBJS3 = dfb_api.o webcam: $(OBJS) diff --git a/udp_rcv.c b/udp_rcv.c new file mode 100644 index 0000000..1fa5fab --- /dev/null +++ b/udp_rcv.c @@ -0,0 +1,76 @@ +/* dgramrcv.c - receive from udp server + * + * author: hackbard + * + */ + +#include +#include + +/* memset */ +#include + +/* socket and bind stuff */ +#include +#include + +/* sockkaddr_in */ +#include + +/* inet_ntoa ... */ +#include + +/* errno stuff ... */ +#include + +/* read, close */ +#include + +#define MAX_BUF 1472 + +int main(int argc, char *argv[]) { + int receive_fd; + int opt; + struct sockaddr_in local_addr,target_addr; + int receive_bytes, write_bytes; + socklen_t target_addr_len; + unsigned char buf[MAX_BUF]; + + if(argc!=2) { + printf("usage: %s \n",argv[0]); + exit(1); + } + + if((receive_fd=socket(AF_INET,SOCK_DGRAM,0)) == -1) { + printf("can't open socket.\n"); + exit(1); + } + + opt=1; + setsockopt(receive_fd,SOL_SOCKET,SO_BROADCAST,&opt,sizeof(opt)); + + local_addr.sin_family=AF_INET; + local_addr.sin_port=htons(atoi(argv[1])); + local_addr.sin_addr.s_addr=htonl(INADDR_ANY); + bind(receive_fd,(const struct sockaddr *)&local_addr,sizeof(local_addr)); + + memset(&target_addr,0,sizeof(target_addr)); + /* + target_addr.sin_family=AF_INET; + target_addr.sin_port=htons(atoi(argv[1])); + target_addr.sin_addr.s_addr=inet_addr(argv[1]); + target_addr_len=sizeof(target_addr); + */ + + receive_bytes=1; + while(receive_bytes>0) { + receive_bytes=recvfrom(receive_fd,buf,sizeof(buf),0,(struct sockaddr *)&target_addr,&target_addr_len); + write_bytes=write(1,buf,receive_bytes); + } + + close(receive_fd); + printf("connection closed ...\n"); + printf("%d from %d total bytes written.\n",write_bytes,receive_bytes); + + return 0; +} diff --git a/udp_send.c b/udp_send.c new file mode 100644 index 0000000..b81eb53 --- /dev/null +++ b/udp_send.c @@ -0,0 +1,90 @@ +/* datagram.c - datagram sockets server + * + * author: hackbard + * + */ + +#include +#include + +/* memset */ +#include + +/* socket and bind stuff */ +#include +#include + +/* sockkaddr_in */ +#include + +/* inet_ntoa ... */ +#include + +/* errno stuff ... */ +#include + +/* read, close */ +#include + +/* open */ +#include +#include + +#define MAX_BUF 1472 + +int main(int argc, char *argv[]) { + int send_fd,broadcast_on; + struct sockaddr_in local_addr, remote_addr; + socklen_t remote_addr_len,optlen; + int send_bytes, read_bytes; + unsigned char buf[MAX_BUF]; + + if(argc!=3) { + printf("usage: %s \n",argv[0]); + exit(1); + } + + if((send_fd=socket(AF_INET,SOCK_DGRAM,0)) == -1) { + printf("can't open socket.\n"); + exit(1); + } + + broadcast_on=1; + optlen=sizeof(broadcast_on); + if((setsockopt(send_fd,SOL_SOCKET,SO_BROADCAST,&broadcast_on,optlen))==-1) + perror("setsockopt"); + + + memset(&local_addr,0,sizeof(local_addr)); + local_addr.sin_family=AF_INET; + local_addr.sin_port=htons(atoi(argv[2])); + local_addr.sin_addr.s_addr=htonl(INADDR_ANY); + + if(bind(send_fd,(struct sockaddr *)&local_addr,sizeof(local_addr))==-1) { + printf("unable to bind on port %d.\n",atoi(argv[2])); + perror("bind"); + exit(1); + } + + remote_addr_len=sizeof(remote_addr); + memset(&remote_addr,0,sizeof(remote_addr)); + remote_addr.sin_family=AF_INET; + remote_addr.sin_port=htons(atoi(argv[2])); + remote_addr.sin_addr.s_addr=inet_addr(argv[1]); + + /* send stuff .... */ + read_bytes=1; + while(read_bytes>0) { + read_bytes=read(0,buf,sizeof(buf)); + send_bytes=sendto(send_fd,buf,read_bytes,0,(struct sockaddr *)&remote_addr,remote_addr_len); +#ifdef DEBUG + perror("sendto"); +#endif + } + + close(send_fd); + printf("connection closed ...\n"); + printf("%d from %d total bytes sent.\n",send_bytes,read_bytes); + + return 0; +} -- 2.39.2