Annotation of 43BSDReno/pgrm/gprof/lookup.c, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1983 Regents of the University of California.
                      3:  * All rights reserved.
                      4:  *
                      5:  * Redistribution and use in source and binary forms are permitted
                      6:  * provided that: (1) source distributions retain this entire copyright
                      7:  * notice and comment, and (2) distributions including binaries display
                      8:  * the following acknowledgement:  ``This product includes software
                      9:  * developed by the University of California, Berkeley and its contributors''
                     10:  * in the documentation or other materials provided with the distribution
                     11:  * and in all advertising materials mentioning features or use of this
                     12:  * software. Neither the name of the University nor the names of its
                     13:  * contributors may be used to endorse or promote products derived
                     14:  * from this software without specific prior written permission.
                     15:  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
                     16:  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
                     17:  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
                     18:  */
                     19: 
                     20: #ifndef lint
                     21: static char sccsid[] = "@(#)lookup.c   5.4 (Berkeley) 6/1/90";
                     22: #endif /* not lint */
                     23: 
                     24: #include "gprof.h"
                     25: 
                     26:     /*
                     27:      * look up an address in a sorted-by-address namelist
                     28:      *     this deals with misses by mapping them to the next lower 
                     29:      *     entry point.
                     30:      */
                     31: nltype *
                     32: nllookup( address )
                     33:     unsigned long      address;
                     34: {
                     35:     register long      low;
                     36:     register long      middle;
                     37:     register long      high;
                     38: #   ifdef DEBUG
                     39:        register int    probes;
                     40: 
                     41:        probes = 0;
                     42: #   endif DEBUG
                     43:     for ( low = 0 , high = nname - 1 ; low != high ; ) {
                     44: #      ifdef DEBUG
                     45:            probes += 1;
                     46: #      endif DEBUG
                     47:        middle = ( high + low ) >> 1;
                     48:        if ( nl[ middle ].value <= address && nl[ middle+1 ].value > address ) {
                     49: #          ifdef DEBUG
                     50:                if ( debug & LOOKUPDEBUG ) {
                     51:                    printf( "[nllookup] %d (%d) probes\n" , probes , nname-1 );
                     52:                }
                     53: #          endif DEBUG
                     54:            return &nl[ middle ];
                     55:        }
                     56:        if ( nl[ middle ].value > address ) {
                     57:            high = middle;
                     58:        } else {
                     59:            low = middle + 1;
                     60:        }
                     61:     }
                     62:     fprintf( stderr , "[nllookup] binary search fails???\n" );
                     63:     return 0;
                     64: }
                     65: 
                     66: arctype *
                     67: arclookup( parentp , childp )
                     68:     nltype     *parentp;
                     69:     nltype     *childp;
                     70: {
                     71:     arctype    *arcp;
                     72: 
                     73:     if ( parentp == 0 || childp == 0 ) {
                     74:        fprintf( "[arclookup] parentp == 0 || childp == 0\n" );
                     75:        return 0;
                     76:     }
                     77: #   ifdef DEBUG
                     78:        if ( debug & LOOKUPDEBUG ) {
                     79:            printf( "[arclookup] parent %s child %s\n" ,
                     80:                    parentp -> name , childp -> name );
                     81:        }
                     82: #   endif DEBUG
                     83:     for ( arcp = parentp -> children ; arcp ; arcp = arcp -> arc_childlist ) {
                     84: #      ifdef DEBUG
                     85:            if ( debug & LOOKUPDEBUG ) {
                     86:                printf( "[arclookup]\t arc_parent %s arc_child %s\n" ,
                     87:                        arcp -> arc_parentp -> name ,
                     88:                        arcp -> arc_childp -> name );
                     89:            }
                     90: #      endif DEBUG
                     91:        if ( arcp -> arc_childp == childp ) {
                     92:            return arcp;
                     93:        }
                     94:     }
                     95:     return 0;
                     96: }

unix.superglobalmegacorp.com

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