Annotation of 43BSDReno/sys/netiso/cisink.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1989, 1990 Regents of the University of California.
        !             3:  * All rights reserved.
        !             4:  *
        !             5:  * %sccs.include.redist.c%
        !             6:  */
        !             7: #ifndef lint
        !             8: static char sccsid[] = "%W% (Berkeley) %G%";
        !             9: #endif /* not lint */
        !            10: 
        !            11: /*
        !            12:  * This is a test program to be a sink for ISO packets.
        !            13:  */
        !            14: #include <sys/param.h>
        !            15: #include <sys/uio.h>
        !            16: #include <sys/socket.h>
        !            17: #include <sys/ioctl.h>
        !            18: #include <net/route.h>
        !            19: #include <net/if.h>
        !            20: #define  TCPT_NTIMERS 4
        !            21: #include <netiso/iso.h>
        !            22: #include <netiso/tp_param.h>
        !            23: #include <netiso/tp_user.h>
        !            24: 
        !            25: #include <stdio.h>
        !            26: #include <errno.h>
        !            27: #include <ctype.h>
        !            28: #include <netdb.h>
        !            29: 
        !            30: 
        !            31: #define dbprintf if(verbose)printf
        !            32: #define try(a,b,c) {x = (a b); dbprintf("%s%s returns %d\n",c,"a",x);\
        !            33:                if(x<0) {perror("a"); myexit(0);}}
        !            34: 
        !            35: 
        !            36: struct  ifreq ifr;
        !            37: short port = 3000;
        !            38: struct  sockaddr_iso faddr, laddr = { sizeof(laddr), AF_ISO };
        !            39: struct  sockaddr_iso *siso = &laddr;
        !            40: 
        !            41: long size, count = 10, forkp, confp, echop, mynamep, verbose = 1, playtag = 0;
        !            42: long records, dgramp = 1;
        !            43: 
        !            44: char buf[2048];
        !            45: char your_it[] = "You're it!";
        !            46: 
        !            47: char *Servername;
        !            48: 
        !            49: main(argc, argv)
        !            50: int argc;
        !            51: char *argv[];
        !            52: {
        !            53:        register char **av = argv;
        !            54:        register char *cp;
        !            55:        struct iso_addr iso_addr();
        !            56: 
        !            57:        while(--argc > 0) {
        !            58:                av++;
        !            59:                if(strcmp(*av,"Servername")==0) {
        !            60:                        av++;
        !            61:                        Servername = *av;
        !            62:                        argc--;
        !            63:                } else if (strcmp(*av,"host")==0) {
        !            64:                        av++;
        !            65:                        laddr.siso_addr = iso_addr(*av);
        !            66:                        argc--;
        !            67:                } else if (strcmp(*av,"count")==0) {
        !            68:                        av++;
        !            69:                        sscanf(*av,"%ld",&count);
        !            70:                        argc--;
        !            71:                } else if (strcmp(*av,"port")==0) {
        !            72:                        av++;
        !            73:                        sscanf(*av,"%hd",&port);
        !            74:                        argc--;
        !            75:                } else if (strcmp(*av,"size")==0) {
        !            76:                        av++;
        !            77:                        sscanf(*av,"%ld",&size);
        !            78:                        argc--;
        !            79:                }
        !            80:        }
        !            81:        if (Servername) {
        !            82:                int tlen = laddr.siso_tlen = strlen(Servername);
        !            83:                int len =  TSEL(siso) + tlen - (caddr_t) &siso;
        !            84:                if (len > sizeof(*siso)) {
        !            85:                        siso = (struct sockaddr_iso *)malloc(len);
        !            86:                        *siso = laddr;
        !            87:                        siso->siso_len = len;
        !            88:                }
        !            89:                bcopy(Servername, TSEL(siso), tlen);
        !            90:        } else {
        !            91:                port = htons(port);
        !            92:                laddr.siso_tlen = sizeof(port);
        !            93:                bcopy((char *)&port, TSEL(siso), sizeof(port));
        !            94:        }
        !            95:        tisink();
        !            96: }
        !            97: #define BIG 2048
        !            98: #define MIDLIN 512
        !            99: char readbuf[BIG];
        !           100: struct iovec iov[1] = {
        !           101:        readbuf,
        !           102:        sizeof readbuf,
        !           103: };
        !           104: char name[MIDLIN];
        !           105: union {
        !           106:     struct {
        !           107:            struct cmsghdr      cmhdr;
        !           108:            char                cmdata[128 - sizeof(struct cmsghdr)];
        !           109:     } cm;
        !           110:     char data[128];
        !           111: } cbuf;
        !           112: #define control cbuf.data
        !           113: struct msghdr msghdr = {
        !           114:        name, sizeof(name),
        !           115:        iov, sizeof(iov)/sizeof(iov[1]),
        !           116:        control, sizeof control,
        !           117:        0 /* flags */
        !           118: };
        !           119: 
        !           120: tisink()
        !           121: {
        !           122:        int x, s, pid, on = 1, loop = 0, n, ns;
        !           123:        extern int errno;
        !           124:        int socktype = (dgramp ? SOCK_DGRAM : SOCK_SEQPACKET);
        !           125:        int addrlen = sizeof(faddr);
        !           126: 
        !           127:        try(socket, (AF_ISO, socktype, 0),"");
        !           128: 
        !           129:        s = x;
        !           130: 
        !           131:        try(bind, (s, (struct sockaddr *) siso, siso->siso_len), "");
        !           132: 
        !           133:        /*try(setsockopt, (s, SOL_SOCKET, SO_DEBUG, &on, sizeof (on)), ""); */
        !           134:        if (dgramp) {
        !           135:                ns  =  s;
        !           136:                pid = getpid();
        !           137:                goto dgram1;
        !           138:        }
        !           139: 
        !           140:        try(listen, (s, 5), "");
        !           141:        for(;;) {
        !           142:                int child;
        !           143:                char childname[50];
        !           144: 
        !           145:                try (accept, (s, &faddr, &addrlen), "");
        !           146:                ns = x;
        !           147:                dumpit("connection from:", &faddr, sizeof faddr);
        !           148:                if (mynamep) {
        !           149:                        addrlen = sizeof(faddr);
        !           150:                        try (getsockname, (ns, &faddr, &addrlen), "");
        !           151:                        dumpit("connected as:", &faddr, addrlen);
        !           152:                }
        !           153:                loop++;
        !           154:                if(loop > 3) myexit(0);
        !           155:                if (forkp) {
        !           156:                        try(fork, (), "");
        !           157:                } else
        !           158:                        x = 0;
        !           159:                pid = getpid();
        !           160:                if (x == 0)  {
        !           161:                    long n, count = 0, cn, flags;
        !           162:                    records = 0;
        !           163:                    if (confp) {
        !           164:                        msghdr.msg_iovlen = 0;
        !           165:                        msghdr.msg_namelen = 0;
        !           166:                        msghdr.msg_controllen = 
        !           167:                            cbuf.cm.cmhdr.cmsg_len = sizeof (cbuf.cm.cmhdr);
        !           168:                        cbuf.cm.cmhdr.cmsg_level = SOL_TRANSPORT;
        !           169:                        cbuf.cm.cmhdr.cmsg_type = TPOPT_CFRM_DATA;
        !           170:                        n = sendmsg(ns, &msghdr, 0);
        !           171:                        if (n <= 0) {
        !           172:                                printf("confirm: errno is %d\n", errno);
        !           173:                                fflush(stdout);
        !           174:                                perror("Confirm error");
        !           175:                        } else {
        !           176:                                dbprintf("confim ok\n");
        !           177:                        }
        !           178:                        sleep(10);
        !           179:                    }
        !           180:                    for (;;) {
        !           181:                    dgram1:
        !           182:                        msghdr.msg_iovlen = 1;
        !           183:                        msghdr.msg_controllen = sizeof(control);
        !           184:                        msghdr.msg_namelen = (dgramp ? (sizeof name) : 0);
        !           185:                        iov->iov_len = sizeof(readbuf);
        !           186:                        n = recvmsg(ns, &msghdr, 0);
        !           187:                        flags = msghdr.msg_flags;
        !           188:                        count++;
        !           189:                        dbprintf("recvmsg from pid %d got %d ctl %d flags %x\n",
        !           190:                                pid, n, (cn = msghdr.msg_controllen), flags);
        !           191:                        fflush(stdout);
        !           192:                        if (dgramp && msghdr.msg_namelen && verbose)
        !           193:                                dumpit("from:\n", name, msghdr.msg_namelen);
        !           194:                        if (cn && verbose)
        !           195:                                dumpit("control data:\n", control, cn);
        !           196:                        if (n <= 0) {
        !           197:                                fprintf(stderr, "errno is %d\n", errno);
        !           198:                                perror("recvmsg");
        !           199:                                /*sleep (10);*/
        !           200:                                break;
        !           201:                        } else {
        !           202:                                if (verbose)
        !           203:                                        dumpit("data:\n", readbuf, n);
        !           204:                        }
        !           205:                        if (echop) {
        !           206:                                n = answerback(flags, n, ns);
        !           207:                        }
        !           208:                        if (flags & MSG_EOR)
        !           209:                                records++;
        !           210:                        if (playtag && n == sizeof(your_it) && (flags & MSG_EOR)
        !           211:                            && bcmp(readbuf, your_it, n) == 0) {
        !           212:                                printf("Answering back!!!!\n");
        !           213:                                answerback(flags, n, ns);
        !           214:                                answerback(flags, n, ns);
        !           215:                        }
        !           216:                        errno = 0;
        !           217:                    }
        !           218:                }
        !           219:                myexit(0);
        !           220:        }
        !           221: }
        !           222: answerback(flags, n, ns)
        !           223: {
        !           224:        msghdr.msg_controllen = 0;
        !           225:        msghdr.msg_iovlen = 1;
        !           226:        iov->iov_len = n;
        !           227:        n = sendmsg(ns, &msghdr, flags);
        !           228:        dbprintf("echoed %d\n", n);
        !           229:        return n;
        !           230: }
        !           231: 
        !           232: dumpit(what, where, n)
        !           233: char *what; unsigned short *where; int n;
        !           234: {
        !           235:        unsigned short *s = where;
        !           236:        unsigned short *z = where + (n+1)/2;
        !           237:        int count = 0;
        !           238:        printf(what);
        !           239:        while(s < z) {
        !           240:                count++;
        !           241:                printf("%x ",*s++);
        !           242:                if ((count & 15) == 0)
        !           243:                        putchar('\n');
        !           244:        }
        !           245:        if (count & 15)
        !           246:                putchar('\n');
        !           247:        fflush(stdout);
        !           248: }
        !           249: myexit(n)
        !           250: {
        !           251:        fflush(stderr);
        !           252:        printf("got %d records\n", records);
        !           253:        fflush(stdout);
        !           254:        exit(n);
        !           255: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.