Annotation of 43BSDReno/contrib/isode-beta/compat/ubcx25.c, revision 1.1

1.1     ! root        1: /* ubcx25.c - X.25 abstractions for UBC X25 */
        !             2: 
        !             3: #ifndef lint
        !             4: static char *rcsid = "$Header: /f/osi/compat/RCS/ubcx25.c,v 7.2 90/07/09 14:32:28 mrose Exp $";
        !             5: #endif
        !             6: 
        !             7: /*
        !             8:  * $Header: /f/osi/compat/RCS/ubcx25.c,v 7.2 90/07/09 14:32:28 mrose Exp $
        !             9:  *
        !            10:  * Contributed by Julian Onions, Nottingham University in the UK
        !            11:  *
        !            12:  *
        !            13:  * $Log:       ubcx25.c,v $
        !            14:  * Revision 7.2  90/07/09  14:32:28  mrose
        !            15:  * sync
        !            16:  * 
        !            17:  * Revision 7.1  89/12/07  01:08:02  mrose
        !            18:  * queued writes
        !            19:  * 
        !            20:  * Revision 7.0  89/11/23  21:23:47  mrose
        !            21:  * Release 6.0
        !            22:  * 
        !            23:  */
        !            24: 
        !            25: /*
        !            26:  *                                NOTICE
        !            27:  *
        !            28:  *    Acquisition, use, and distribution of this module and related
        !            29:  *    materials are subject to the restrictions of a license agreement.
        !            30:  *    Consult the Preface in the User's Manual for the full terms of
        !            31:  *    this agreement.
        !            32:  *
        !            33:  */
        !            34: 
        !            35: 
        !            36: /* LINTLIBRARY */
        !            37: 
        !            38: #include <errno.h>
        !            39: #include <stdio.h>
        !            40: #include "general.h"
        !            41: #include "manifest.h"
        !            42: #include "tailor.h"
        !            43: #include "tpkt.h"
        !            44: 
        !            45: /*    4.[23] UNIX: UBC X25 */
        !            46: 
        !            47: #ifdef  X25
        !            48: #ifdef  UBC_X25
        !            49: 
        !            50: #include "x25.h"
        !            51: #include <sys/uio.h>
        !            52: 
        !            53: #define         X25_MBIT        0x40
        !            54: #define         X25_QBIT        0x80
        !            55: 
        !            56: /*  */
        !            57: 
        !            58: int     start_x25_client (local)
        !            59: struct NSAPaddr *local;
        !            60: {
        !            61:     int     sd, pgrp;
        !            62: 
        !            63:     if (local != NULLNA)
        !            64:        local -> na_stack = NA_X25, local -> na_community = ts_comm_x25_default;
        !            65:     if ((sd = socket (AF_CCITT, SOCK_STREAM, 0)) == NOTOK) {
        !            66:        SLOG (compat_log, LLOG_EXCEPTIONS, "failed", ("socket"));
        !            67:        return NOTOK; /* Error can be found in errno */
        !            68:     }
        !            69: 
        !            70:     pgrp = getpid();
        !            71:     if (ioctl(sd, SIOCSPGRP, &pgrp)) {
        !            72:        SLOG (compat_log, LLOG_EXCEPTIONS, "failed", ("SIOCSPGRP"));
        !            73:        return NOTOK; /* Error can be found in errno */
        !            74:     }
        !            75: 
        !            76:     return sd;
        !            77: }
        !            78: 
        !            79: /*  */
        !            80: 
        !            81: int     start_x25_server (local, backlog, opt1, opt2)
        !            82: struct NSAPaddr *local;
        !            83: int     backlog,
        !            84:        opt1,
        !            85:        opt2;
        !            86: {
        !            87:     int     sd, pgrp;
        !            88: #ifdef notyet
        !            89: #ifdef BSD43
        !            90:     int            onoff;
        !            91: #endif
        !            92: #endif
        !            93:     CONN_DB     zsck;
        !            94:     CONN_DB     *sck = &zsck;
        !            95: 
        !            96:     if ((sd = socket (AF_CCITT, SOCK_STREAM, 0)) == NOTOK) {
        !            97:        SLOG (compat_log, LLOG_EXCEPTIONS, "failed", ("socket"));
        !            98:        return NOTOK; /* Can't get an X.25 socket */
        !            99:     }
        !           100: 
        !           101:     pgrp = getpid();
        !           102:     if (ioctl(sd, SIOCSPGRP, &pgrp)) {
        !           103:        SLOG (compat_log, LLOG_EXCEPTIONS, "failed", ("SIOCSPGRP"));
        !           104:        return NOTOK; /* Error can be found in errno */
        !           105:     }
        !           106: 
        !           107:     if (local != NULLNA) {
        !           108:        local -> na_stack = NA_X25, local -> na_community = ts_comm_x25_default;
        !           109:        if (local -> na_dtelen == 0) {
        !           110:            (void) strcpy (local -> na_dte, x25_local_dte);
        !           111:            local -> na_dtelen = strlen(x25_local_dte);
        !           112:            if (local -> na_pidlen == 0 && *x25_local_pid)
        !           113:                local -> na_pidlen =
        !           114:                    str2sel (x25_local_pid, -1, local -> na_pid, NPSIZE);
        !           115:        }
        !           116:     }
        !           117: 
        !           118:     (void) gen2if (local, sck, ADDR_LISTEN);
        !           119:     if (bind (sd, sck, sizeof(CONN_DB)) == NOTOK) {
        !           120:        SLOG (compat_log, LLOG_EXCEPTIONS, "failed", ("bind"));
        !           121:        (void) close_x25_socket (sd);
        !           122:        return NOTOK;
        !           123:     }
        !           124: 
        !           125: 
        !           126: #ifdef notyet          /* not sure if these are supported... */
        !           127: #ifndef        BSD43
        !           128:     if (opt1)
        !           129:        (void) setsockopt (sd, SOL_SOCKET, opt1, NULLCP, 0);
        !           130:     if (opt2)
        !           131:        (void) setsockopt (sd, SOL_SOCKET, opt2, NULLCP, 0);
        !           132: #else
        !           133:     onoff = 1;
        !           134:     if (opt1)
        !           135:        (void) setsockopt (sd, SOL_SOCKET, opt1, (char *)&onoff, sizeof onoff);
        !           136:     if (opt2)
        !           137:        (void) setsockopt (sd, SOL_SOCKET, opt2, (char *)&onoff, sizeof onoff);
        !           138: #endif
        !           139: #endif
        !           140: 
        !           141:     (void) listen (sd, backlog);
        !           142: 
        !           143:     return sd;
        !           144: }
        !           145: 
        !           146: /*  */
        !           147: 
        !           148: int     join_x25_client (fd, remote)
        !           149: int     fd;
        !           150: struct NSAPaddr *remote;
        !           151: {
        !           152:     CONN_DB     sck;
        !           153:     int     len = sizeof sck;
        !           154:     int         nfd;
        !           155: 
        !           156:     if((nfd = accept (fd, (struct sockaddr *) &sck, &len)) == NOTOK)
        !           157:        return NOTOK;
        !           158:     (void) if2gen (remote, &sck, ADDR_REMOTE);
        !           159:     return nfd;
        !           160: }
        !           161: 
        !           162: int     join_x25_server (fd, remote)
        !           163: int     fd;
        !           164: struct NSAPaddr *remote;
        !           165: {
        !           166:     CONN_DB zsck;
        !           167:     CONN_DB *sck = &zsck;
        !           168: 
        !           169:     if (remote == NULLNA || remote -> na_stack != NA_X25)
        !           170:     {
        !           171:        SLOG (compat_log, LLOG_EXCEPTIONS, NULLCP,
        !           172:              ("Invalid type na%d", remote->na_stack));
        !           173:        return NOTOK;
        !           174:     }
        !           175:     (void) gen2if (remote, sck, ADDR_REMOTE);
        !           176:     return connect (fd, sck, sizeof (CONN_DB));
        !           177: }
        !           178: 
        !           179: int     read_x25_socket (fd, buffer, len)
        !           180: int     fd, len;
        !           181: char    *buffer;
        !           182: {
        !           183:     static u_char mode;
        !           184:     static struct iovec iov[2] = {
        !           185:        (char *)&mode, 1,
        !           186:        "", 0
        !           187:     };
        !           188:     char        *p = buffer;
        !           189:     int         cc, count = 0, total = len;
        !           190: 
        !           191:     do {
        !           192:        iov[1].iov_base = p;
        !           193:        iov[1].iov_len = total > X25_PACKETSIZE ? X25_PACKETSIZE : total;
        !           194: 
        !           195:        switch (cc = readv (fd, iov, 2)) {
        !           196:                /*
        !           197:                 * for the -1,0 & 1 cases these returns should be ok
        !           198:                 * if it's the first time through, then they are valid anyway
        !           199:                 * later stages means the M bit is set so there must
        !           200:                 * be more data else someone is violating the
        !           201:                 * protocol badly.
        !           202:                 */
        !           203: 
        !           204:            case NOTOK:
        !           205:            case 0:
        !           206:                return cc;
        !           207: 
        !           208:            case 1:
        !           209:                SLOG (compat_log, LLOG_EXCEPTIONS, NULLCP,
        !           210:                      ("strange return from read_x25_socket"));
        !           211:                return NOTOK;
        !           212: 
        !           213:            default:
        !           214:                cc --;          /* discount the info byte */
        !           215:                count += cc;
        !           216:                p += cc;
        !           217:                total -= cc;
        !           218:        }
        !           219:     } while (len > 0 && (mode & X25_MBIT));
        !           220:     DLOG (compat_log, LLOG_DEBUG, ("X25 read, total %d/%d", count, len));
        !           221: 
        !           222:     return count;
        !           223: }
        !           224: 
        !           225: #ifdef UBC_X25_WRITEV
        !           226: /* God this all very bizarre - iovecs work on read but not write!! */
        !           227: 
        !           228: /*
        !           229:  * OK, this is due to a bug in UBC implementation. It may or may not
        !           230:  * be fixed in later versions. If writev allows you to write single
        !           231:  * bytes in the first vector then use this version. It's much more
        !           232:  * efficient.
        !           233:  */
        !           234: 
        !           235: int     write_x25_socket (fd, buffer, len)
        !           236: int     fd, len;
        !           237: char    *buffer;
        !           238: {
        !           239:     static u_char mode;
        !           240:     static struct iovec iov[2] = {
        !           241:        (char *)&mode, 1,
        !           242:        "", 0
        !           243:        };
        !           244:     int cc;
        !           245:     char        *p = buffer;
        !           246:     int         count, total = 0;
        !           247: 
        !           248:     do {
        !           249:        count = len > X25_PACKETSIZE ? X25_PACKETSIZE : len;
        !           250:        mode = len > X25_PACKETSIZE ? X25_MBIT : 0;
        !           251:        iov[1].iov_base = p;
        !           252:        iov[1].iov_len = count;
        !           253:        switch (cc = writev (fd, iov, 2))
        !           254:        {
        !           255:            case NOTOK:
        !           256:            case 0:
        !           257:                return cc;
        !           258: 
        !           259:            case 1:
        !           260:                SLOG (compat_log, LLOG_EXCEPTIONS, NULLCP,
        !           261:                      ("strange return from write_x25_socket"));
        !           262:                return NOTOK;
        !           263: 
        !           264:            default:
        !           265:                cc --;
        !           266:                len -= cc;
        !           267:                p += cc;
        !           268:                total += cc;
        !           269:        }
        !           270:     } while (len > 0);
        !           271:     DLOG (compat_log, LLOG_DEBUG, ("X25 write, total %d/%d", total, len));
        !           272:     return total;
        !           273: }
        !           274: #else
        !           275: int     write_x25_socket (fd, buffer, len)
        !           276: int     fd, len;
        !           277: char    *buffer;
        !           278: {
        !           279:     char        mybuffer[X25_PACKETSIZE+1];
        !           280:     char        *p = buffer;
        !           281:     int         count, total = 0;
        !           282:     int         cc;
        !           283: 
        !           284:     do {
        !           285:        count = len > X25_PACKETSIZE ? X25_PACKETSIZE : len;
        !           286:        mybuffer[0] = len > X25_PACKETSIZE ? X25_MBIT : 0;
        !           287:        bcopy (p, &mybuffer[1], count);
        !           288:        switch (cc = write (fd, mybuffer, count + 1))
        !           289:        {
        !           290:            case NOTOK:
        !           291:            case 0:
        !           292:                return cc;
        !           293: 
        !           294:            case 1:
        !           295:                SLOG (compat_log, LLOG_EXCEPTIONS, NULLCP,
        !           296:                      ("strange return from write_x25_socket"));
        !           297:                return NOTOK;
        !           298: 
        !           299:            default:
        !           300:                cc --;
        !           301:                len -= cc;
        !           302:                p += cc;
        !           303:                total += cc;
        !           304:        }
        !           305:     } while (len > 0);
        !           306:     DLOG (compat_log, LLOG_DEBUG, ("X25 write, total %d/%d", total, len));
        !           307:     return total;
        !           308: }
        !           309: #endif
        !           310: 
        !           311: #endif
        !           312: #endif

unix.superglobalmegacorp.com

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