Annotation of 43BSDReno/usr.sbin/named/ns_sort.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1986, 1990 Regents of the University of California.
        !             3:  * All rights reserved.
        !             4:  *
        !             5:  * Redistribution and use in source and binary forms are permitted provided
        !             6:  * that: (1) source distributions retain this entire copyright notice and
        !             7:  * comment, and (2) distributions including binaries display the following
        !             8:  * acknowledgement:  ``This product includes software developed by the
        !             9:  * University of California, Berkeley and its contributors'' in the
        !            10:  * documentation or other materials provided with the distribution and in
        !            11:  * all advertising materials mentioning features or use of this software.
        !            12:  * Neither the name of the University nor the names of its contributors may
        !            13:  * be used to endorse or promote products derived from this software without
        !            14:  * specific prior written permission.
        !            15:  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
        !            16:  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
        !            17:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
        !            18:  */
        !            19: 
        !            20: #ifndef lint
        !            21: static char sccsid[] = "@(#)ns_sort.c  4.8 (Berkeley) 6/1/90";
        !            22: #endif /* not lint */
        !            23: 
        !            24: #include <stdio.h>
        !            25: #include <sys/types.h>
        !            26: #include <sys/time.h>
        !            27: #include <sys/socket.h>
        !            28: #include <sys/file.h>
        !            29: #include <netinet/in.h>
        !            30: #include <syslog.h>
        !            31: #include <arpa/nameser.h>
        !            32: #include "ns.h"
        !            33: #include "db.h"
        !            34: 
        !            35: extern char *p_type(), *p_class();
        !            36: 
        !            37: extern int     debug;
        !            38: extern  FILE   *ddt;
        !            39: 
        !            40: struct netinfo* 
        !            41: local(from)
        !            42:        struct sockaddr_in *from;
        !            43: {
        !            44:        extern struct netinfo *nettab, netloop, **enettab;
        !            45:        struct netinfo *ntp;
        !            46: 
        !            47:        if (from->sin_addr.s_addr == netloop.my_addr.s_addr)
        !            48:                return( &netloop);
        !            49:        for (ntp = nettab; ntp != *enettab; ntp = ntp->next) {
        !            50:                if (ntp->net == (from->sin_addr.s_addr & ntp->mask))
        !            51:                        return(ntp);
        !            52:        }
        !            53:        return(NULL);
        !            54: }
        !            55: 
        !            56: 
        !            57: sort_response(cp, ancount, lp, eom)
        !            58:        register char *cp;
        !            59:        register int ancount;
        !            60:        struct netinfo *lp;
        !            61:        u_char *eom;
        !            62: {
        !            63:        register struct netinfo *ntp;
        !            64:        extern struct netinfo *nettab;
        !            65: 
        !            66: #ifdef DEBUG
        !            67:        if (debug > 2)
        !            68:            fprintf(ddt,"sort_response(%d)\n", ancount);
        !            69: #endif DEBUG
        !            70:        if (ancount > 1) {
        !            71:                if (sort_rr(cp, ancount, lp, eom))
        !            72:                        return;
        !            73:                for (ntp = nettab; ntp != NULL; ntp = ntp->next) {
        !            74:                        if ((ntp->net == lp->net) && (ntp->mask == lp->mask))
        !            75:                                continue;
        !            76:                        if (sort_rr(cp, ancount, ntp, eom))
        !            77:                                break;
        !            78:                }
        !            79:        }
        !            80: }
        !            81: 
        !            82: int
        !            83: sort_rr(cp, count, ntp, eom)
        !            84:        register u_char *cp;
        !            85:        int count;
        !            86:        register struct netinfo *ntp;
        !            87:        u_char *eom;
        !            88: {
        !            89:        int type, class, dlen, n, c;
        !            90:        struct in_addr inaddr;
        !            91:        u_char *rr1;
        !            92: 
        !            93: #ifdef DEBUG
        !            94:        if (debug > 2) {
        !            95:            inaddr.s_addr = ntp->net;
        !            96:            fprintf(ddt,"sort_rr( x%x, %d, %s)\n",cp, count,
        !            97:                inet_ntoa(inaddr));
        !            98:        }
        !            99: #endif DEBUG
        !           100:        rr1 = NULL;
        !           101:        for (c = count; c > 0; --c) {
        !           102:            n = dn_skipname(cp, eom);
        !           103:            if (n < 0)
        !           104:                return (1);             /* bogus, stop processing */
        !           105:            cp += n;
        !           106:            if (cp + QFIXEDSZ > eom)
        !           107:                return (1);
        !           108:            GETSHORT(type, cp);
        !           109:            GETSHORT(class, cp);
        !           110:            cp += sizeof(u_long);
        !           111:            GETSHORT(dlen, cp);
        !           112:            if (dlen > eom - cp)
        !           113:                return (1);             /* bogus, stop processing */
        !           114:            switch (type) {
        !           115:            case T_A:
        !           116:                switch (class) {
        !           117:                case C_IN:
        !           118:                case C_HS:
        !           119:                        bcopy(cp, (char *)&inaddr, sizeof(inaddr));
        !           120:                        if (rr1 == NULL)
        !           121:                                rr1 = cp;
        !           122:                        if ((ntp->mask & inaddr.s_addr) == ntp->net) {
        !           123: #ifdef DEBUG
        !           124:                            if (debug > 1) {
        !           125:                                fprintf(ddt,"net %s best choice\n",
        !           126:                                        inet_ntoa(inaddr));
        !           127:                            }
        !           128: #endif DEBUG
        !           129:                            if (rr1 != cp) {
        !           130:                                bcopy(rr1, cp, sizeof(inaddr));
        !           131:                                bcopy((char *)&inaddr, rr1, sizeof(inaddr));
        !           132:                            }
        !           133:                            return(1);
        !           134:                        }
        !           135:                        break;
        !           136:                }
        !           137:                break;
        !           138:            }
        !           139:            cp += dlen;
        !           140:        }
        !           141:        return(0);
        !           142: }

unix.superglobalmegacorp.com

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