Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | | |
| 2 | | smovecr.sa 3.1 12/10/90 |
| 3 | | |
| 4 | | The entry point sMOVECR returns the constant at the |
| 5 | | offset given in the instruction field. |
| 6 | | |
| 7 | | Input: An offset in the instruction word. |
| 8 | | |
| 9 | | Output: The constant rounded to the user's rounding |
| 10 | | mode unchecked for overflow. |
| 11 | | |
| 12 | | Modified: fp0. |
| 13 | | |
| 14 | | |
| 15 | | Copyright (C) Motorola, Inc. 1990 |
| 16 | | All Rights Reserved |
| 17 | | |
Matt Waddel | e00d82d | 2006-02-11 17:55:48 -0800 | [diff] [blame^] | 18 | | For details on the license for this file, please see the |
| 19 | | file, README, in this same directory. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 20 | |
| 21 | |SMOVECR idnt 2,1 | Motorola 040 Floating Point Software Package |
| 22 | |
| 23 | |section 8 |
| 24 | |
| 25 | #include "fpsp.h" |
| 26 | |
| 27 | |xref nrm_set |
| 28 | |xref round |
| 29 | |xref PIRN |
| 30 | |xref PIRZRM |
| 31 | |xref PIRP |
| 32 | |xref SMALRN |
| 33 | |xref SMALRZRM |
| 34 | |xref SMALRP |
| 35 | |xref BIGRN |
| 36 | |xref BIGRZRM |
| 37 | |xref BIGRP |
| 38 | |
| 39 | FZERO: .long 00000000 |
| 40 | | |
| 41 | | FMOVECR |
| 42 | | |
| 43 | .global smovcr |
| 44 | smovcr: |
| 45 | bfextu CMDREG1B(%a6){#9:#7},%d0 |get offset |
| 46 | bfextu USER_FPCR(%a6){#26:#2},%d1 |get rmode |
| 47 | | |
| 48 | | check range of offset |
| 49 | | |
| 50 | tstb %d0 |if zero, offset is to pi |
| 51 | beqs PI_TBL |it is pi |
| 52 | cmpib #0x0a,%d0 |check range $01 - $0a |
| 53 | bles Z_VAL |if in this range, return zero |
| 54 | cmpib #0x0e,%d0 |check range $0b - $0e |
| 55 | bles SM_TBL |valid constants in this range |
| 56 | cmpib #0x2f,%d0 |check range $10 - $2f |
| 57 | bles Z_VAL |if in this range, return zero |
| 58 | cmpib #0x3f,%d0 |check range $30 - $3f |
| 59 | ble BG_TBL |valid constants in this range |
| 60 | Z_VAL: |
| 61 | fmoves FZERO,%fp0 |
| 62 | rts |
| 63 | PI_TBL: |
| 64 | tstb %d1 |offset is zero, check for rmode |
| 65 | beqs PI_RN |if zero, rn mode |
| 66 | cmpib #0x3,%d1 |check for rp |
| 67 | beqs PI_RP |if 3, rp mode |
| 68 | PI_RZRM: |
| 69 | leal PIRZRM,%a0 |rmode is rz or rm, load PIRZRM in a0 |
| 70 | bra set_finx |
| 71 | PI_RN: |
| 72 | leal PIRN,%a0 |rmode is rn, load PIRN in a0 |
| 73 | bra set_finx |
| 74 | PI_RP: |
| 75 | leal PIRP,%a0 |rmode is rp, load PIRP in a0 |
| 76 | bra set_finx |
| 77 | SM_TBL: |
| 78 | subil #0xb,%d0 |make offset in 0 - 4 range |
| 79 | tstb %d1 |check for rmode |
| 80 | beqs SM_RN |if zero, rn mode |
| 81 | cmpib #0x3,%d1 |check for rp |
| 82 | beqs SM_RP |if 3, rp mode |
| 83 | SM_RZRM: |
| 84 | leal SMALRZRM,%a0 |rmode is rz or rm, load SMRZRM in a0 |
| 85 | cmpib #0x2,%d0 |check if result is inex |
| 86 | ble set_finx |if 0 - 2, it is inexact |
| 87 | bra no_finx |if 3, it is exact |
| 88 | SM_RN: |
| 89 | leal SMALRN,%a0 |rmode is rn, load SMRN in a0 |
| 90 | cmpib #0x2,%d0 |check if result is inex |
| 91 | ble set_finx |if 0 - 2, it is inexact |
| 92 | bra no_finx |if 3, it is exact |
| 93 | SM_RP: |
| 94 | leal SMALRP,%a0 |rmode is rp, load SMRP in a0 |
| 95 | cmpib #0x2,%d0 |check if result is inex |
| 96 | ble set_finx |if 0 - 2, it is inexact |
| 97 | bra no_finx |if 3, it is exact |
| 98 | BG_TBL: |
| 99 | subil #0x30,%d0 |make offset in 0 - f range |
| 100 | tstb %d1 |check for rmode |
| 101 | beqs BG_RN |if zero, rn mode |
| 102 | cmpib #0x3,%d1 |check for rp |
| 103 | beqs BG_RP |if 3, rp mode |
| 104 | BG_RZRM: |
| 105 | leal BIGRZRM,%a0 |rmode is rz or rm, load BGRZRM in a0 |
| 106 | cmpib #0x1,%d0 |check if result is inex |
| 107 | ble set_finx |if 0 - 1, it is inexact |
| 108 | cmpib #0x7,%d0 |second check |
| 109 | ble no_finx |if 0 - 7, it is exact |
| 110 | bra set_finx |if 8 - f, it is inexact |
| 111 | BG_RN: |
| 112 | leal BIGRN,%a0 |rmode is rn, load BGRN in a0 |
| 113 | cmpib #0x1,%d0 |check if result is inex |
| 114 | ble set_finx |if 0 - 1, it is inexact |
| 115 | cmpib #0x7,%d0 |second check |
| 116 | ble no_finx |if 0 - 7, it is exact |
| 117 | bra set_finx |if 8 - f, it is inexact |
| 118 | BG_RP: |
| 119 | leal BIGRP,%a0 |rmode is rp, load SMRP in a0 |
| 120 | cmpib #0x1,%d0 |check if result is inex |
| 121 | ble set_finx |if 0 - 1, it is inexact |
| 122 | cmpib #0x7,%d0 |second check |
| 123 | ble no_finx |if 0 - 7, it is exact |
| 124 | | bra set_finx ;if 8 - f, it is inexact |
| 125 | set_finx: |
| 126 | orl #inx2a_mask,USER_FPSR(%a6) |set inex2/ainex |
| 127 | no_finx: |
| 128 | mulul #12,%d0 |use offset to point into tables |
| 129 | movel %d1,L_SCR1(%a6) |load mode for round call |
| 130 | bfextu USER_FPCR(%a6){#24:#2},%d1 |get precision |
| 131 | tstl %d1 |check if extended precision |
| 132 | | |
| 133 | | Precision is extended |
| 134 | | |
| 135 | bnes not_ext |if extended, do not call round |
| 136 | fmovemx (%a0,%d0),%fp0-%fp0 |return result in fp0 |
| 137 | rts |
| 138 | | |
| 139 | | Precision is single or double |
| 140 | | |
| 141 | not_ext: |
| 142 | swap %d1 |rnd prec in upper word of d1 |
| 143 | addl L_SCR1(%a6),%d1 |merge rmode in low word of d1 |
| 144 | movel (%a0,%d0),FP_SCR1(%a6) |load first word to temp storage |
| 145 | movel 4(%a0,%d0),FP_SCR1+4(%a6) |load second word |
| 146 | movel 8(%a0,%d0),FP_SCR1+8(%a6) |load third word |
| 147 | clrl %d0 |clear g,r,s |
| 148 | lea FP_SCR1(%a6),%a0 |
| 149 | btstb #sign_bit,LOCAL_EX(%a0) |
| 150 | sne LOCAL_SGN(%a0) |convert to internal ext. format |
| 151 | |
| 152 | bsr round |go round the mantissa |
| 153 | |
| 154 | bfclr LOCAL_SGN(%a0){#0:#8} |convert back to IEEE ext format |
| 155 | beqs fin_fcr |
| 156 | bsetb #sign_bit,LOCAL_EX(%a0) |
| 157 | fin_fcr: |
| 158 | fmovemx (%a0),%fp0-%fp0 |
| 159 | rts |
| 160 | |
| 161 | |end |