| /* Test pseudo-denormal operations. */ |
| struct { uint64_t sig; uint16_t sign_exp; } s; |
| volatile union u ld_pseudo_m16382 = { .s = { UINT64_C(1) << 63, 0 } }; |
| volatile long double ld_res; |
| ld_res = ld_pseudo_m16382.ld + ld_pseudo_m16382.ld; |
| if (ld_res != 0x1p-16381L) { |
| printf("FAIL: pseudo-denormal add\n"); |
| if (ld_pseudo_m16382.ld != 0x1p-16382L) { |
| printf("FAIL: pseudo-denormal compare\n"); |
| __asm__ volatile ("fnstcw %0" : "=m" (cw)); |
| cw = (cw & ~0xc00) | 0x800; |
| __asm__ volatile ("fldcw %0" : : "m" (cw)); |
| __asm__ ("frndint" : "=t" (ld_res) : "0" (ld_pseudo_m16382.ld)); |
| printf("FAIL: pseudo-denormal round-to-integer\n"); |