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 |
18 |       For details on the license for this file, please see the
19 |       file, README, in this same directory.
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
162