Annotation of researchv9/jerq/src/sysmon/ntdkmgr.c, revision 1.1.1.1

1.1       root        1: /*
                      2:  *     setup a datakit manager process     
                      3:  *     and receive requests for its service.
                      4:  */
                      5: 
                      6: #include <dk.h>
                      7: #include <dkmgr.h>
                      8: #include <sys/ioctl.h>
                      9: #include <stdio.h>
                     10: #include <errno.h>
                     11: 
                     12: char   dkmgribuf[128] ;
                     13: int    dkmgropen = 0 ;
                     14: int    dkmgrreply = 0 ;
                     15: int    ntries = 0;
                     16: struct         mgrmsg  dkmgrmsg ;
                     17: extern int     dkp_ld ;
                     18: extern int     rdk_ld ;
                     19: 
                     20: #define MAXRETRIES 2
                     21: 
                     22: struct mgrmsg *
                     23: dkmgr(mgrname, traffic)
                     24: char * mgrname ;
                     25: {
                     26:        extern char *dkerror;
                     27:        register fd ;
                     28:        extern int errno ;
                     29:        register char *cp ;
                     30:        char *savcp ;
                     31: 
                     32:        ntries = 0;
                     33: again:
                     34:        if (dkmgrreply <= 0) {
                     35:                dkmgrreply = dkctlchan(0);
                     36:                if (dkmgrreply < 0) {
                     37:                        fprintf(stderr, "MGR %s: cannot open channel 1\r\n",
                     38:                            mgrname) ;
                     39:                        if (ntries==0)
                     40:                                exit(1);
                     41:                        nwait(ntries);
                     42:                        ntries++;
                     43:                        goto again;
                     44:                }
                     45:        }
                     46:        if ((fd = dkmgropen) == 0) {
                     47:                fd = tdkserv(mgrname, traffic) ;
                     48:                if (fd < 0) {
                     49:                        fprintf(stderr, "dkmgr: can't create server %s (%s)\r\n",
                     50:                             mgrname, dkerror) ;
                     51:                        nwait(ntries);
                     52:                        if (ntries++ > MAXRETRIES)
                     53:                                exit (2);
                     54:                        goto again ;
                     55:                }
                     56:                dkmgropen = fd ;
                     57:                fprintf(stderr, "MGR %s:  successful initialization\r\n",
                     58:                     mgrname) ;
                     59:                dkproto(fd, dkp_ld);
                     60:                ntries = 0;
                     61:                return ((struct mgrmsg *)0);
                     62:        }
                     63:        errno = 0 ;
                     64:        if (read(fd, dkmgribuf, 128) <= 0) {
                     65:                if (errno == EINTR)
                     66:                        return NULL ;
                     67:                close(fd) ;             /* a host restart */
                     68:                dkmgropen = 0 ;
                     69:                close(dkmgrreply);
                     70:                dkmgrreply = 0;
                     71:                fprintf(stderr, "MGR %s:  dk-eof,  restarting\r\n",
                     72:                     mgrname) ;
                     73:                return ((struct mgrmsg *)0);
                     74:        }
                     75:        cp = dkmgribuf ;
                     76:        dkmgrmsg.m_chan = 0 ;
                     77:        while (*cp >= '0' && *cp <= '7')
                     78:                dkmgrmsg.m_chan = (dkmgrmsg.m_chan << 3) + (*cp++ & 07) ;
                     79:        dkmgrmsg.m_tstamp = 0 ;
                     80:        if (*cp == '.') {
                     81:                cp++ ;
                     82:                while (*cp >= '0' && *cp <= '7')
                     83:                        dkmgrmsg.m_tstamp =
                     84:                               (dkmgrmsg.m_tstamp << 3) + (*cp++ & 07) ;
                     85:        }
                     86:        dkmgrmsg.m_traffic = 0 ;
                     87:        if (*cp == '.') {
                     88:                cp++ ;
                     89:                while (*cp >= '0' && *cp <= '7')
                     90:                        dkmgrmsg.m_traffic =
                     91:                               (dkmgrmsg.m_traffic << 3) + (*cp++ & 07) ;
                     92:        }
                     93:        if (*cp++ != '\n') {
                     94:                fprintf(stderr, "mgr %s: bad incall message = %s\r\n", mgrname,
                     95:                    dkmgribuf) ;
                     96:                goto again ;
                     97:        }
                     98:        dkmgrmsg.m_dial = cp ;
                     99:        dkmgrmsg.m_service = NULL ;
                    100:        while (*cp != '\n' && *cp != '\0' && *cp != '.')
                    101:                cp++ ;
                    102:        if (*cp == '.') {
                    103:                *cp++ = '\0' ;
                    104:                dkmgrmsg.m_service = cp ;
                    105:                while (*cp != '\n' && *cp != '\0') cp++ ;
                    106:        }
                    107:        if (*cp == '\n')
                    108:                *cp++ = '\0' ;
                    109:        dkmgrmsg.m_traffic = 0 ;
                    110:        dkmgrmsg.m_param1 = NULL ;
                    111:        dkmgrmsg.m_param2 = NULL ;
                    112:        dkmgrmsg.m_uid = NULL ;
                    113:        dkmgrmsg.m_source = NULL ;
                    114:        if (*cp == '\0')
                    115:                return (&dkmgrmsg) ;
                    116:        dkmgrmsg.m_source = cp ;
                    117:        while (*cp != '.' && *cp != '\0' && *cp != '\n') cp++ ;
                    118:        if (*cp == '.') {
                    119:                *cp++ = '\0' ;
                    120:                dkmgrmsg.m_uid = cp ;
                    121:        }
                    122:        while (*cp != '.' && *cp != '\0' && *cp != '\n')  cp++ ;
                    123:        if (*cp == '.') {
                    124:                *cp++ = '\0' ;
                    125:                dkmgrmsg.m_param1 = cp ;
                    126:        }
                    127:        while (*cp != '.' && *cp != '\0' && *cp != '\n')  cp++ ;
                    128:        if (*cp == '.') {
                    129:                *cp++ = '\0' ;
                    130:                dkmgrmsg.m_param2 = cp ;
                    131:        }
                    132:        while (*cp != '.' && *cp != '\0' && *cp != '\n')  cp++ ;
                    133:        *cp++ = '\0' ;
                    134:        return (&dkmgrmsg) ;
                    135: }
                    136: 
                    137: dkmgrack(chan)
                    138: {
                    139: struct listenin d ;
                    140: 
                    141:        d.l_lchan = 1 ;
                    142:        d.l_type = T_REPLY ;
                    143:        d.l_srv = D_OPEN ;
                    144:        d.l_param0 = chan ;
                    145:        d.l_param1 = 0 ;
                    146:        d.l_param2 = chan ;
                    147:        d.l_param3 = dkmgrmsg.m_tstamp ;
                    148:        d.l_param4 = 0 ;
                    149:        d.l_param5 = 0 ;
                    150:        write(dkmgrreply, &d, sizeof(d)) ;
                    151: }
                    152: 
                    153: 
                    154: dkmgrnak(chan, error)
                    155: {
                    156: struct listenin d ;
                    157: 
                    158:        d.l_lchan = 1 ;
                    159:        d.l_type = T_REPLY ;
                    160:        d.l_srv = D_FAIL ;
                    161:        d.l_param0 = chan ;
                    162:        d.l_param1 = error ;
                    163:        d.l_param2 = chan ;
                    164:        d.l_param3 = dkmgrmsg.m_tstamp ;
                    165:        d.l_param4 = 0 ;
                    166:        d.l_param5 = 0 ;
                    167:        write(dkmgrreply, &d, sizeof(d)) ;
                    168: }
                    169: 
                    170: nwait(ntries)
                    171: {
                    172:        sleep(ntries<10?5:(ntries<20?30:600)) ;
                    173: }

unix.superglobalmegacorp.com

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