softfloat-specialize.h revision 1.1.122.1 1 1.1.122.1 mjf /* $NetBSD: softfloat-specialize.h,v 1.1.122.1 2008/06/02 13:24:16 mjf Exp $ */
2 1.1 ross
3 1.1 ross /* This is a derivative work. */
4 1.1 ross
5 1.1 ross /*-
6 1.1 ross * Copyright (c) 2001 The NetBSD Foundation, Inc.
7 1.1 ross * All rights reserved.
8 1.1 ross *
9 1.1 ross * This code is derived from software contributed to The NetBSD Foundation
10 1.1 ross * by Ross Harvey.
11 1.1 ross *
12 1.1 ross * Redistribution and use in source and binary forms, with or without
13 1.1 ross * modification, are permitted provided that the following conditions
14 1.1 ross * are met:
15 1.1 ross * 1. Redistributions of source code must retain the above copyright
16 1.1 ross * notice, this list of conditions and the following disclaimer.
17 1.1 ross * 2. Redistributions in binary form must reproduce the above copyright
18 1.1 ross * notice, this list of conditions and the following disclaimer in the
19 1.1 ross * documentation and/or other materials provided with the distribution.
20 1.1 ross *
21 1.1 ross * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
22 1.1 ross * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
23 1.1 ross * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
24 1.1 ross * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
25 1.1 ross * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26 1.1 ross * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27 1.1 ross * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28 1.1 ross * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29 1.1 ross * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 1.1 ross * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31 1.1 ross * POSSIBILITY OF SUCH DAMAGE.
32 1.1 ross */
33 1.1 ross
34 1.1 ross /*
35 1.1 ross ===============================================================================
36 1.1 ross
37 1.1 ross This C source fragment is part of the SoftFloat IEC/IEEE Floating-point
38 1.1 ross Arithmetic Package, Release 2a.
39 1.1 ross
40 1.1 ross Written by John R. Hauser. This work was made possible in part by the
41 1.1 ross International Computer Science Institute, located at Suite 600, 1947 Center
42 1.1 ross Street, Berkeley, California 94704. Funding was partially provided by the
43 1.1 ross National Science Foundation under grant MIP-9311980. The original version
44 1.1 ross of this code was written as part of a project to build a fixed-point vector
45 1.1 ross processor in collaboration with the University of California at Berkeley,
46 1.1 ross overseen by Profs. Nelson Morgan and John Wawrzynek. More information
47 1.1 ross is available through the Web page `http://HTTP.CS.Berkeley.EDU/~jhauser/
48 1.1 ross arithmetic/SoftFloat.html'.
49 1.1 ross
50 1.1 ross THIS SOFTWARE IS DISTRIBUTED AS IS, FOR FREE. Although reasonable effort
51 1.1 ross has been made to avoid it, THIS SOFTWARE MAY CONTAIN FAULTS THAT WILL AT
52 1.1 ross TIMES RESULT IN INCORRECT BEHAVIOR. USE OF THIS SOFTWARE IS RESTRICTED TO
53 1.1 ross PERSONS AND ORGANIZATIONS WHO CAN AND WILL TAKE FULL RESPONSIBILITY FOR ANY
54 1.1 ross AND ALL LOSSES, COSTS, OR OTHER PROBLEMS ARISING FROM ITS USE.
55 1.1 ross
56 1.1 ross Derivative works are acceptable, even for commercial purposes, so long as
57 1.1 ross (1) they include prominent notice that the work is derivative, and (2) they
58 1.1 ross include prominent notice akin to these four paragraphs for those parts of
59 1.1 ross this code that are retained.
60 1.1 ross
61 1.1 ross ===============================================================================
62 1.1 ross */
63 1.1 ross
64 1.1 ross /*
65 1.1 ross -------------------------------------------------------------------------------
66 1.1 ross Underflow tininess-detection mode, statically initialized to default value.
67 1.1 ross -------------------------------------------------------------------------------
68 1.1 ross */
69 1.1 ross
70 1.1 ross /* [ MP safe, does not change dynamically ] */
71 1.1 ross int float_detect_tininess = float_tininess_after_rounding;
72 1.1 ross
73 1.1 ross /*
74 1.1 ross -------------------------------------------------------------------------------
75 1.1 ross Internal canonical NaN format.
76 1.1 ross -------------------------------------------------------------------------------
77 1.1 ross */
78 1.1 ross typedef struct {
79 1.1 ross flag sign;
80 1.1 ross bits64 high, low;
81 1.1 ross } commonNaNT;
82 1.1 ross
83 1.1 ross /*
84 1.1 ross -------------------------------------------------------------------------------
85 1.1 ross The pattern for a default generated single-precision NaN.
86 1.1 ross -------------------------------------------------------------------------------
87 1.1 ross */
88 1.1 ross #define float32_default_nan 0xFFC00000
89 1.1 ross
90 1.1 ross /*
91 1.1 ross -------------------------------------------------------------------------------
92 1.1 ross Returns 1 if the single-precision floating-point value `a' is a NaN;
93 1.1 ross otherwise returns 0.
94 1.1 ross -------------------------------------------------------------------------------
95 1.1 ross */
96 1.1 ross static flag float32_is_nan( float32 a )
97 1.1 ross {
98 1.1 ross
99 1.1 ross return ( 0xFF000000 < (bits32) ( a<<1 ) );
100 1.1 ross
101 1.1 ross }
102 1.1 ross
103 1.1 ross /*
104 1.1 ross -------------------------------------------------------------------------------
105 1.1 ross Returns 1 if the single-precision floating-point value `a' is a signaling
106 1.1 ross NaN; otherwise returns 0.
107 1.1 ross -------------------------------------------------------------------------------
108 1.1 ross */
109 1.1 ross flag float32_is_signaling_nan( float32 a )
110 1.1 ross {
111 1.1 ross
112 1.1 ross return ( ( ( a>>22 ) & 0x1FF ) == 0x1FE ) && ( a & 0x003FFFFF );
113 1.1 ross
114 1.1 ross }
115 1.1 ross
116 1.1 ross /*
117 1.1 ross -------------------------------------------------------------------------------
118 1.1 ross Returns the result of converting the single-precision floating-point NaN
119 1.1 ross `a' to the canonical NaN format. If `a' is a signaling NaN, the invalid
120 1.1 ross exception is raised.
121 1.1 ross -------------------------------------------------------------------------------
122 1.1 ross */
123 1.1 ross static commonNaNT float32ToCommonNaN( float32 a )
124 1.1 ross {
125 1.1 ross commonNaNT z;
126 1.1 ross
127 1.1 ross if ( float32_is_signaling_nan( a ) ) float_raise( float_flag_invalid );
128 1.1 ross z.sign = a>>31;
129 1.1 ross z.low = 0;
130 1.1 ross z.high = ( (bits64) a )<<41;
131 1.1 ross return z;
132 1.1 ross
133 1.1 ross }
134 1.1 ross
135 1.1 ross /*
136 1.1 ross -------------------------------------------------------------------------------
137 1.1 ross Returns the result of converting the canonical NaN `a' to the single-
138 1.1 ross precision floating-point format.
139 1.1 ross -------------------------------------------------------------------------------
140 1.1 ross */
141 1.1 ross static float32 commonNaNToFloat32( commonNaNT a )
142 1.1 ross {
143 1.1 ross
144 1.1 ross return ( ( (bits32) a.sign )<<31 ) | 0x7FC00000 | ( a.high>>41 );
145 1.1 ross
146 1.1 ross }
147 1.1 ross
148 1.1 ross /*
149 1.1 ross -------------------------------------------------------------------------------
150 1.1 ross Takes two single-precision floating-point values `a' and `b', one of which
151 1.1 ross is a NaN, and returns the appropriate NaN result. If either `a' or `b' is a
152 1.1 ross signaling NaN, the invalid exception is raised.
153 1.1 ross -------------------------------------------------------------------------------
154 1.1 ross */
155 1.1 ross static float32 propagateFloat32NaN( float32 a, float32 b )
156 1.1 ross {
157 1.1 ross flag aIsNaN, aIsSignalingNaN, bIsNaN, bIsSignalingNaN;
158 1.1 ross
159 1.1 ross aIsNaN = float32_is_nan( a );
160 1.1 ross aIsSignalingNaN = float32_is_signaling_nan( a );
161 1.1 ross bIsNaN = float32_is_nan( b );
162 1.1 ross bIsSignalingNaN = float32_is_signaling_nan( b );
163 1.1 ross a |= 0x00400000;
164 1.1 ross b |= 0x00400000;
165 1.1 ross if ( aIsSignalingNaN | bIsSignalingNaN ) float_raise( float_flag_invalid );
166 1.1 ross if ( aIsSignalingNaN ) {
167 1.1 ross if ( bIsSignalingNaN ) goto returnLargerSignificand;
168 1.1 ross return bIsNaN ? b : a;
169 1.1 ross }
170 1.1 ross else if ( aIsNaN ) {
171 1.1 ross if ( bIsSignalingNaN | ! bIsNaN ) return a;
172 1.1 ross returnLargerSignificand:
173 1.1 ross if ( (bits32) ( a<<1 ) < (bits32) ( b<<1 ) ) return b;
174 1.1 ross if ( (bits32) ( b<<1 ) < (bits32) ( a<<1 ) ) return a;
175 1.1 ross return ( a < b ) ? a : b;
176 1.1 ross }
177 1.1 ross else {
178 1.1 ross return b;
179 1.1 ross }
180 1.1 ross
181 1.1 ross }
182 1.1 ross
183 1.1 ross
184 1.1 ross /*
185 1.1 ross -------------------------------------------------------------------------------
186 1.1 ross Returns the result of converting the double-precision floating-point NaN
187 1.1 ross `a' to the canonical NaN format. If `a' is a signaling NaN, the invalid
188 1.1 ross exception is raised.
189 1.1 ross -------------------------------------------------------------------------------
190 1.1 ross */
191 1.1 ross static commonNaNT float64ToCommonNaN( float64 a )
192 1.1 ross {
193 1.1 ross commonNaNT z;
194 1.1 ross
195 1.1 ross if ( float64_is_signaling_nan( a ) ) float_raise( float_flag_invalid );
196 1.1 ross z.sign = a>>63;
197 1.1 ross z.low = 0;
198 1.1 ross z.high = a<<12;
199 1.1 ross return z;
200 1.1 ross
201 1.1 ross }
202 1.1 ross
203 1.1 ross /*
204 1.1 ross -------------------------------------------------------------------------------
205 1.1 ross Returns the result of converting the canonical NaN `a' to the double-
206 1.1 ross precision floating-point format.
207 1.1 ross -------------------------------------------------------------------------------
208 1.1 ross */
209 1.1 ross static float64 commonNaNToFloat64( commonNaNT a )
210 1.1 ross {
211 1.1 ross
212 1.1 ross return
213 1.1 ross ( ( (bits64) a.sign )<<63 )
214 1.1 ross | LIT64( 0x7FF8000000000000 )
215 1.1 ross | ( a.high>>12 );
216 1.1 ross
217 1.1 ross }
218 1.1 ross
219 1.1 ross /*
220 1.1 ross -------------------------------------------------------------------------------
221 1.1 ross Takes two double-precision floating-point values `a' and `b', one of which
222 1.1 ross is a NaN, and returns the appropriate NaN result. If either `a' or `b' is a
223 1.1 ross signaling NaN, the invalid exception is raised.
224 1.1 ross -------------------------------------------------------------------------------
225 1.1 ross */
226 1.1 ross static float64 propagateFloat64NaN( float64 a, float64 b )
227 1.1 ross {
228 1.1 ross flag aIsNaN, aIsSignalingNaN, bIsNaN, bIsSignalingNaN;
229 1.1 ross
230 1.1 ross aIsNaN = float64_is_nan( a );
231 1.1 ross aIsSignalingNaN = float64_is_signaling_nan( a );
232 1.1 ross bIsNaN = float64_is_nan( b );
233 1.1 ross bIsSignalingNaN = float64_is_signaling_nan( b );
234 1.1 ross a |= LIT64( 0x0008000000000000 );
235 1.1 ross b |= LIT64( 0x0008000000000000 );
236 1.1 ross if ( aIsSignalingNaN | bIsSignalingNaN ) float_raise( float_flag_invalid );
237 1.1 ross if ( aIsSignalingNaN ) {
238 1.1 ross if ( bIsSignalingNaN ) goto returnLargerSignificand;
239 1.1 ross return bIsNaN ? b : a;
240 1.1 ross }
241 1.1 ross else if ( aIsNaN ) {
242 1.1 ross if ( bIsSignalingNaN | ! bIsNaN ) return a;
243 1.1 ross returnLargerSignificand:
244 1.1 ross if ( (bits64) ( a<<1 ) < (bits64) ( b<<1 ) ) return b;
245 1.1 ross if ( (bits64) ( b<<1 ) < (bits64) ( a<<1 ) ) return a;
246 1.1 ross return ( a < b ) ? a : b;
247 1.1 ross }
248 1.1 ross else {
249 1.1 ross return b;
250 1.1 ross }
251 1.1 ross
252 1.1 ross }
253 1.1 ross
254 1.1 ross #ifdef FLOATX80
255 1.1 ross
256 1.1 ross /*
257 1.1 ross -------------------------------------------------------------------------------
258 1.1 ross The pattern for a default generated extended double-precision NaN. The
259 1.1 ross `high' and `low' values hold the most- and least-significant bits,
260 1.1 ross respectively.
261 1.1 ross -------------------------------------------------------------------------------
262 1.1 ross */
263 1.1 ross #define floatx80_default_nan_high 0xFFFF
264 1.1 ross #define floatx80_default_nan_low LIT64( 0xC000000000000000 )
265 1.1 ross
266 1.1 ross /*
267 1.1 ross -------------------------------------------------------------------------------
268 1.1 ross Returns 1 if the extended double-precision floating-point value `a' is a
269 1.1 ross NaN; otherwise returns 0.
270 1.1 ross -------------------------------------------------------------------------------
271 1.1 ross */
272 1.1 ross static flag floatx80_is_nan( floatx80 a )
273 1.1 ross {
274 1.1 ross
275 1.1 ross return ( ( a.high & 0x7FFF ) == 0x7FFF ) && (bits64) ( a.low<<1 );
276 1.1 ross
277 1.1 ross }
278 1.1 ross
279 1.1 ross /*
280 1.1 ross -------------------------------------------------------------------------------
281 1.1 ross Returns 1 if the extended double-precision floating-point value `a' is a
282 1.1 ross signaling NaN; otherwise returns 0.
283 1.1 ross -------------------------------------------------------------------------------
284 1.1 ross */
285 1.1 ross flag floatx80_is_signaling_nan( floatx80 a )
286 1.1 ross {
287 1.1 ross bits64 aLow;
288 1.1 ross
289 1.1 ross aLow = a.low & ~ LIT64( 0x4000000000000000 );
290 1.1 ross return
291 1.1 ross ( ( a.high & 0x7FFF ) == 0x7FFF )
292 1.1 ross && (bits64) ( aLow<<1 )
293 1.1 ross && ( a.low == aLow );
294 1.1 ross
295 1.1 ross }
296 1.1 ross
297 1.1 ross /*
298 1.1 ross -------------------------------------------------------------------------------
299 1.1 ross Returns the result of converting the extended double-precision floating-
300 1.1 ross point NaN `a' to the canonical NaN format. If `a' is a signaling NaN, the
301 1.1 ross invalid exception is raised.
302 1.1 ross -------------------------------------------------------------------------------
303 1.1 ross */
304 1.1 ross static commonNaNT floatx80ToCommonNaN( floatx80 a )
305 1.1 ross {
306 1.1 ross commonNaNT z;
307 1.1 ross
308 1.1 ross if ( floatx80_is_signaling_nan( a ) ) float_raise( float_flag_invalid );
309 1.1 ross z.sign = a.high>>15;
310 1.1 ross z.low = 0;
311 1.1 ross z.high = a.low<<1;
312 1.1 ross return z;
313 1.1 ross
314 1.1 ross }
315 1.1 ross
316 1.1 ross /*
317 1.1 ross -------------------------------------------------------------------------------
318 1.1 ross Returns the result of converting the canonical NaN `a' to the extended
319 1.1 ross double-precision floating-point format.
320 1.1 ross -------------------------------------------------------------------------------
321 1.1 ross */
322 1.1 ross static floatx80 commonNaNToFloatx80( commonNaNT a )
323 1.1 ross {
324 1.1 ross floatx80 z;
325 1.1 ross
326 1.1 ross z.low = LIT64( 0xC000000000000000 ) | ( a.high>>1 );
327 1.1 ross z.high = ( ( (bits16) a.sign )<<15 ) | 0x7FFF;
328 1.1 ross return z;
329 1.1 ross
330 1.1 ross }
331 1.1 ross
332 1.1 ross /*
333 1.1 ross -------------------------------------------------------------------------------
334 1.1 ross Takes two extended double-precision floating-point values `a' and `b', one
335 1.1 ross of which is a NaN, and returns the appropriate NaN result. If either `a' or
336 1.1 ross `b' is a signaling NaN, the invalid exception is raised.
337 1.1 ross -------------------------------------------------------------------------------
338 1.1 ross */
339 1.1 ross static floatx80 propagateFloatx80NaN( floatx80 a, floatx80 b )
340 1.1 ross {
341 1.1 ross flag aIsNaN, aIsSignalingNaN, bIsNaN, bIsSignalingNaN;
342 1.1 ross
343 1.1 ross aIsNaN = floatx80_is_nan( a );
344 1.1 ross aIsSignalingNaN = floatx80_is_signaling_nan( a );
345 1.1 ross bIsNaN = floatx80_is_nan( b );
346 1.1 ross bIsSignalingNaN = floatx80_is_signaling_nan( b );
347 1.1 ross a.low |= LIT64( 0xC000000000000000 );
348 1.1 ross b.low |= LIT64( 0xC000000000000000 );
349 1.1 ross if ( aIsSignalingNaN | bIsSignalingNaN ) float_raise( float_flag_invalid );
350 1.1 ross if ( aIsSignalingNaN ) {
351 1.1 ross if ( bIsSignalingNaN ) goto returnLargerSignificand;
352 1.1 ross return bIsNaN ? b : a;
353 1.1 ross }
354 1.1 ross else if ( aIsNaN ) {
355 1.1 ross if ( bIsSignalingNaN | ! bIsNaN ) return a;
356 1.1 ross returnLargerSignificand:
357 1.1 ross if ( a.low < b.low ) return b;
358 1.1 ross if ( b.low < a.low ) return a;
359 1.1 ross return ( a.high < b.high ) ? a : b;
360 1.1 ross }
361 1.1 ross else {
362 1.1 ross return b;
363 1.1 ross }
364 1.1 ross
365 1.1 ross }
366 1.1 ross
367 1.1 ross #endif
368 1.1 ross
369 1.1 ross #ifdef FLOAT128
370 1.1 ross
371 1.1 ross /*
372 1.1 ross -------------------------------------------------------------------------------
373 1.1 ross The pattern for a default generated quadruple-precision NaN. The `high' and
374 1.1 ross `low' values hold the most- and least-significant bits, respectively.
375 1.1 ross -------------------------------------------------------------------------------
376 1.1 ross */
377 1.1 ross #define float128_default_nan_high LIT64( 0xFFFF800000000000 )
378 1.1 ross #define float128_default_nan_low LIT64( 0x0000000000000000 )
379 1.1 ross
380 1.1 ross /*
381 1.1 ross -------------------------------------------------------------------------------
382 1.1 ross Returns 1 if the quadruple-precision floating-point value `a' is a NaN;
383 1.1 ross otherwise returns 0.
384 1.1 ross -------------------------------------------------------------------------------
385 1.1 ross */
386 1.1 ross flag float128_is_nan( float128 a )
387 1.1 ross {
388 1.1 ross
389 1.1 ross return
390 1.1 ross ( LIT64( 0xFFFE000000000000 ) <= (bits64) ( a.high<<1 ) )
391 1.1 ross && ( a.low || ( a.high & LIT64( 0x0000FFFFFFFFFFFF ) ) );
392 1.1 ross
393 1.1 ross }
394 1.1 ross
395 1.1 ross /*
396 1.1 ross -------------------------------------------------------------------------------
397 1.1 ross Returns 1 if the quadruple-precision floating-point value `a' is a
398 1.1 ross signaling NaN; otherwise returns 0.
399 1.1 ross -------------------------------------------------------------------------------
400 1.1 ross */
401 1.1 ross flag float128_is_signaling_nan( float128 a )
402 1.1 ross {
403 1.1 ross
404 1.1 ross return
405 1.1 ross ( ( ( a.high>>47 ) & 0xFFFF ) == 0xFFFE )
406 1.1 ross && ( a.low || ( a.high & LIT64( 0x00007FFFFFFFFFFF ) ) );
407 1.1 ross
408 1.1 ross }
409 1.1 ross
410 1.1 ross /*
411 1.1 ross -------------------------------------------------------------------------------
412 1.1 ross Returns the result of converting the quadruple-precision floating-point NaN
413 1.1 ross `a' to the canonical NaN format. If `a' is a signaling NaN, the invalid
414 1.1 ross exception is raised.
415 1.1 ross -------------------------------------------------------------------------------
416 1.1 ross */
417 1.1 ross static commonNaNT float128ToCommonNaN( float128 a )
418 1.1 ross {
419 1.1 ross commonNaNT z;
420 1.1 ross
421 1.1 ross if ( float128_is_signaling_nan( a ) ) float_raise( float_flag_invalid );
422 1.1 ross z.sign = a.high>>63;
423 1.1 ross shortShift128Left( a.high, a.low, 16, &z.high, &z.low );
424 1.1 ross return z;
425 1.1 ross
426 1.1 ross }
427 1.1 ross
428 1.1 ross /*
429 1.1 ross -------------------------------------------------------------------------------
430 1.1 ross Returns the result of converting the canonical NaN `a' to the quadruple-
431 1.1 ross precision floating-point format.
432 1.1 ross -------------------------------------------------------------------------------
433 1.1 ross */
434 1.1 ross static float128 commonNaNToFloat128( commonNaNT a )
435 1.1 ross {
436 1.1 ross float128 z;
437 1.1 ross
438 1.1 ross shift128Right( a.high, a.low, 16, &z.high, &z.low );
439 1.1 ross z.high |= ( ( (bits64) a.sign )<<63 ) | LIT64( 0x7FFF800000000000 );
440 1.1 ross return z;
441 1.1 ross
442 1.1 ross }
443 1.1 ross
444 1.1 ross /*
445 1.1 ross -------------------------------------------------------------------------------
446 1.1 ross Takes two quadruple-precision floating-point values `a' and `b', one of
447 1.1 ross which is a NaN, and returns the appropriate NaN result. If either `a' or
448 1.1 ross `b' is a signaling NaN, the invalid exception is raised.
449 1.1 ross -------------------------------------------------------------------------------
450 1.1 ross */
451 1.1 ross static float128 propagateFloat128NaN( float128 a, float128 b )
452 1.1 ross {
453 1.1 ross flag aIsNaN, aIsSignalingNaN, bIsNaN, bIsSignalingNaN;
454 1.1 ross
455 1.1 ross aIsNaN = float128_is_nan( a );
456 1.1 ross aIsSignalingNaN = float128_is_signaling_nan( a );
457 1.1 ross bIsNaN = float128_is_nan( b );
458 1.1 ross bIsSignalingNaN = float128_is_signaling_nan( b );
459 1.1 ross a.high |= LIT64( 0x0000800000000000 );
460 1.1 ross b.high |= LIT64( 0x0000800000000000 );
461 1.1 ross if ( aIsSignalingNaN | bIsSignalingNaN ) float_raise( float_flag_invalid );
462 1.1 ross if ( aIsSignalingNaN ) {
463 1.1 ross if ( bIsSignalingNaN ) goto returnLargerSignificand;
464 1.1 ross return bIsNaN ? b : a;
465 1.1 ross }
466 1.1 ross else if ( aIsNaN ) {
467 1.1 ross if ( bIsSignalingNaN | ! bIsNaN ) return a;
468 1.1 ross returnLargerSignificand:
469 1.1 ross if ( lt128( a.high<<1, a.low, b.high<<1, b.low ) ) return b;
470 1.1 ross if ( lt128( b.high<<1, b.low, a.high<<1, a.low ) ) return a;
471 1.1 ross return ( a.high < b.high ) ? a : b;
472 1.1 ross }
473 1.1 ross else {
474 1.1 ross return b;
475 1.1 ross }
476 1.1 ross
477 1.1 ross }
478 1.1 ross
479 1.1 ross #endif
480 1.1 ross
481