Annotation of 43BSDReno/sys/tahoemath/Kmodf.s, revision 1.1

1.1     ! root        1: /*     Kmodf.s 1.3     86/01/05        */
        !             2: 
        !             3: #include "../tahoe/SYS.h"
        !             4: #include "../tahoemath/fp.h"
        !             5: 
        !             6: /* 
        !             7:  *  float Kmodf (value, iptr, hfs)
        !             8:  *  float value, *iptr;
        !             9:  *  int hfs;
        !            10:  * 
        !            11:  *  Modf returns the fractional part of "value",
        !            12:  *  and stores the integer part indirectly through "iptr".
        !            13:  */ 
        !            14:        .text
        !            15: ENTRY(Kmodf, R8|R7|R6|R5|R4|R3|R2)
        !            16:  /*
        !            17:  * Some initializations:
        !            18:  */
        !            19:        clrl    r3
        !            20:        movl    4(fp),r0        /* fetch operand to r0. */
        !            21:        movl    8(fp),r1
        !            22:        movl    12(fp),r6       /* fetch addr of int to r6. */
        !            23:  /*
        !            24:   * get exponent
        !            25:   */
        !            26:        andl3   $EXPMASK,r0,r2  /* r2 will hold the exponent. */
        !            27:        shrl    $EXPSHIFT,r2,r2
        !            28:        subl2   $BIAS,r2        /* unbias it.  */
        !            29:        jleq    allfrac         /* it's int part is  zero. */
        !            30:        cmpl    r2,$56
        !            31:        jgeq    allint          /* it's fraction part is zero. */
        !            32:  /*
        !            33:   * get fraction
        !            34:   */
        !            35:        movl    r0,r4           /* remember the original number. */
        !            36:        movl    r1,r5
        !            37:        bbc     $31,r0,positive /* if negative remember it. */
        !            38:        incl    r3
        !            39: positive:
        !            40:                                /* clear the non fraction parts. */
        !            41:        andl2   $(0!(EXPMASK | SIGNBIT)),r0
        !            42:                                /* add the hidden bit. */
        !            43:        orl2    $(0!CLEARHID),r0
        !            44: 
        !            45:        cmpl    r2,$HID_POS     /* see if there are bits to clear only in r0 */
        !            46:        jgtr    in_r1           /* some bytes in r1     */
        !            47:        jeql    onlyallr0       /* all r0 must be cleared. */
        !            48:        mnegl   r2,r7           /* r7 - loop counter. */
        !            49:        movl    $CLEARHID,r8    /* first bit to clear. */
        !            50: 1:
        !            51:        andl2   r8,r0           /* clear int. bits from fraction part. */
        !            52:        shar    $1,r8,r8
        !            53:        aoblss  $0,r7,1b
        !            54: 1:
        !            55:        andl2   r8,r4           /* clear frac bits for int calculation: */
        !            56:        shar    $1,r8,r8
        !            57:        cmpl    $0xffffffff,r8
        !            58:        jneq    1b
        !            59:        clrl    r5
        !            60:        jmp     norm
        !            61: 
        !            62: onlyallr0:
        !            63:        clrl    r0
        !            64:        clrl    r5
        !            65:        jmp     norm
        !            66: 
        !            67: in_r1:
        !            68:        clrl    r0
        !            69:        subl3   r2,$HID_POS,r7
        !            70:        movl    $0x7fffffff,r8
        !            71: 1:
        !            72:        andl2   r8,r1
        !            73:        shar    $1,r8,r8
        !            74:        orl2    $0x80000000,r8
        !            75:        aoblss  $0,r7,1b
        !            76: 1:
        !            77:        andl2   r8,r5
        !            78:        shar    $1,r8,r8
        !            79:        cmpl    $0xffffffff,r8
        !            80:        jneq    1b
        !            81: norm:
        !            82:        addl2   $BIAS,r2        /* fnorm expects it biased. */
        !            83:        pushl   16(fp)          /* hfs */
        !            84:        callf   $8,_Kfnorm      /* normelize fraction part. */
        !            85:        cmpl    $0,r0
        !            86:        jeql    1f
        !            87:        bbc     $0,r3,1f
        !            88:        orl2    $0x80000000,r0
        !            89: 1:
        !            90:        movl    r4,(r6)         /* put int part in place. */
        !            91:        movl    r5,4(r6)
        !            92:        ret
        !            93:  
        !            94: allint:
        !            95:        movl    r0,(r6)         /* copy the argument to the int addr. */
        !            96:        movl    r1,4(r6)
        !            97:        clrl    r0              /* clear the fraction part. */
        !            98:        clrl    r1
        !            99:        ret
        !           100: 
        !           101: allfrac:
        !           102:                                /* the fraction is ready in r0. */
        !           103:        clrl    (r6)            /* zero the int part. */
        !           104:        clrl    4(r6)
        !           105:        ret
        !           106: 
        !           107: ret_zero:
        !           108:        clrl    (r6)
        !           109:        clrl    4(r6)   
        !           110:        clrl    r0
        !           111:        clrl    r1
        !           112:        ret

unix.superglobalmegacorp.com

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