Commit 6ce98c8199 for qemu.org

commit 6ce98c8199f52ea52ee0995da504c0cbff6b8f8c
Author: Richard Henderson <richard.henderson@linaro.org>
Date:   Fri May 1 16:16:33 2026 +1000

    fpu: Use of {get,set}_floatx80_rounding_precision everywhere

    Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
    Signed-off-by: Richard Henderson <richard.henderson@linaro.org>

diff --git a/fpu/softfloat.c b/fpu/softfloat.c
index d99543cc60..d2a9f97089 100644
--- a/fpu/softfloat.c
+++ b/fpu/softfloat.c
@@ -1515,7 +1515,7 @@ float128 float128_round_pack_canonical(FloatParts128 *p, float_status *s)
 bool floatx80_unpack_canonical(FloatParts128 *p, floatx80 f, float_status *s)
 {
     /* Ensure rounding precision is set before beginning. */
-    switch (s->floatx80_rounding_precision) {
+    switch (get_floatx80_rounding_precision(s)) {
     case floatx80_precision_x:
     case floatx80_precision_d:
     case floatx80_precision_s:
@@ -1550,14 +1550,14 @@ bool floatx80_unpack_canonical(FloatParts128 *p, floatx80 f, float_status *s)

 floatx80 floatx80_round_pack_canonical(FloatParts128 *p, float_status *s)
 {
-    const FloatFmt *fmt = &floatx80_params[s->floatx80_rounding_precision];
+    const FloatFmt *fmt = &floatx80_params[get_floatx80_rounding_precision(s)];
     uint64_t frac;
     int exp;

     switch (p->cls) {
     case float_class_normal:
     case float_class_denormal:
-        if (s->floatx80_rounding_precision == floatx80_precision_x) {
+        if (get_floatx80_rounding_precision(s) == floatx80_precision_x) {
             parts128_uncanon_normal(p, s, fmt, false);
             frac = p->frac_hi;
             exp = p->exp;
@@ -2853,7 +2853,7 @@ floatx80 floatx80_round_to_int(floatx80 a, float_status *status)
     }

     p = parts128_round_to_int(&p, get_float_rounding_mode(status), 0, status,
-                              &floatx80_params[status->floatx80_rounding_precision]);
+                              &floatx80_params[get_floatx80_rounding_precision(status)]);
     return floatx80_round_pack_canonical(&p, status);
 }

@@ -4503,7 +4503,7 @@ floatx80 floatx80_sqrt(floatx80 a, float_status *s)
     if (!floatx80_unpack_canonical(&p, a, s)) {
         return floatx80_default_nan(s);
     }
-    parts128_sqrt(&p, s, &floatx80_params[s->floatx80_rounding_precision]);
+    parts128_sqrt(&p, s, &floatx80_params[get_floatx80_rounding_precision(s)]);
     return floatx80_round_pack_canonical(&p, s);
 }

diff --git a/target/i386/tcg/fpu_helper.c b/target/i386/tcg/fpu_helper.c
index 7b0b0dd520..978eb1411b 100644
--- a/target/i386/tcg/fpu_helper.c
+++ b/target/i386/tcg/fpu_helper.c
@@ -1185,9 +1185,9 @@ void helper_f2xm1(CPUX86State *env)
         uint64_t asig0, asig1, asig2, bsig0, bsig1;
         FloatRoundMode save_mode = get_float_rounding_mode(&env->fp_status);
         FloatX80RoundPrec save_prec =
-            env->fp_status.floatx80_rounding_precision;
+            get_floatx80_rounding_precision(&env->fp_status);
         set_float_rounding_mode(float_round_nearest_even, &env->fp_status);
-        env->fp_status.floatx80_rounding_precision = floatx80_precision_x;
+        set_floatx80_rounding_precision(floatx80_precision_x, &env->fp_status);

         /* Find the nearest multiple of 1/32 to the argument.  */
         tmp = floatx80_scalbn(ST0, 5, &env->fp_status);
@@ -1290,7 +1290,7 @@ void helper_f2xm1(CPUX86State *env)
                                                 &env->fp_status);
         }

-        env->fp_status.floatx80_rounding_precision = save_prec;
+        set_floatx80_rounding_precision(save_prec, &env->fp_status);
     }
     merge_exception_flags(env, old_flags);
 }
@@ -1406,10 +1406,10 @@ void helper_fpatan(CPUX86State *env)
          * (and underflowing where appropriate).
          */
         FloatX80RoundPrec save_prec =
-            env->fp_status.floatx80_rounding_precision;
-        env->fp_status.floatx80_rounding_precision = floatx80_precision_x;
+            get_floatx80_rounding_precision(&env->fp_status);
+        set_floatx80_rounding_precision(floatx80_precision_x, &env->fp_status);
         ST1 = floatx80_div(ST1, ST0, &env->fp_status);
-        env->fp_status.floatx80_rounding_precision = save_prec;
+        set_floatx80_rounding_precision(save_prec, &env->fp_status);
         if (!floatx80_is_zero(ST1) &&
             !(get_float_exception_flags(&env->fp_status) &
               float_flag_inexact)) {
@@ -1485,9 +1485,10 @@ void helper_fpatan(CPUX86State *env)
             floatx80 x8;
             FloatRoundMode save_mode = get_float_rounding_mode(&env->fp_status);
             FloatX80RoundPrec save_prec =
-                env->fp_status.floatx80_rounding_precision;
+                get_floatx80_rounding_precision(&env->fp_status);
             set_float_rounding_mode(float_round_nearest_even, &env->fp_status);
-            env->fp_status.floatx80_rounding_precision = floatx80_precision_x;
+            set_floatx80_rounding_precision(floatx80_precision_x,
+                                            &env->fp_status);

             if (arg0_exp == 0) {
                 normalizeFloatx80Subnormal(arg0_sig, &arg0_exp, &arg0_sig);
@@ -1794,7 +1795,7 @@ void helper_fpatan(CPUX86State *env)
             }

             set_float_rounding_mode(save_mode, &env->fp_status);
-            env->fp_status.floatx80_rounding_precision = save_prec;
+            set_floatx80_rounding_precision(save_prec, &env->fp_status);
         }
         /* This result is inexact.  */
         rsig1 |= 1;
@@ -2123,9 +2124,9 @@ void helper_fyl2xp1(CPUX86State *env)
         uint64_t asig0, asig1, asig2;
         FloatRoundMode save_mode = get_float_rounding_mode(&env->fp_status);
         FloatX80RoundPrec save_prec =
-            env->fp_status.floatx80_rounding_precision;
+            get_floatx80_rounding_precision(&env->fp_status);
         set_float_rounding_mode(float_round_nearest_even, &env->fp_status);
-        env->fp_status.floatx80_rounding_precision = floatx80_precision_x;
+        set_floatx80_rounding_precision(floatx80_precision_x, &env->fp_status);

         helper_fyl2x_common(env, ST0, &aexp, &asig0, &asig1);
         /*
@@ -2143,7 +2144,7 @@ void helper_fyl2xp1(CPUX86State *env)
         ST1 = normalizeRoundAndPackFloatx80(floatx80_precision_x,
                                             arg0_sign ^ arg1_sign, aexp,
                                             asig0, asig1, &env->fp_status);
-        env->fp_status.floatx80_rounding_precision = save_prec;
+        set_floatx80_rounding_precision(save_prec, &env->fp_status);
     }
     fpop(env);
     merge_exception_flags(env, old_flags);
@@ -2226,9 +2227,9 @@ void helper_fyl2x(CPUX86State *env)
         floatx80 arg0_m1;
         FloatRoundMode save_mode = get_float_rounding_mode(&env->fp_status);
         FloatX80RoundPrec save_prec =
-            env->fp_status.floatx80_rounding_precision;
+            get_floatx80_rounding_precision(&env->fp_status);
         set_float_rounding_mode(float_round_nearest_even, &env->fp_status);
-        env->fp_status.floatx80_rounding_precision = floatx80_precision_x;
+        set_floatx80_rounding_precision(floatx80_precision_x, &env->fp_status);

         if (arg0_exp == 0) {
             normalizeFloatx80Subnormal(arg0_sig, &arg0_exp, &arg0_sig);
@@ -2290,7 +2291,7 @@ void helper_fyl2x(CPUX86State *env)
                                                 asig0, asig1, &env->fp_status);
         }

-        env->fp_status.floatx80_rounding_precision = save_prec;
+        set_floatx80_rounding_precision(save_prec, &env->fp_status);
     }
     fpop(env);
     merge_exception_flags(env, old_flags);
@@ -2368,14 +2369,14 @@ void helper_fscale(CPUX86State *env)
         }
     } else {
         int n;
-        FloatX80RoundPrec save = env->fp_status.floatx80_rounding_precision;
+        FloatX80RoundPrec save = get_floatx80_rounding_precision(&env->fp_status);
         int save_flags = get_float_exception_flags(&env->fp_status);
         set_float_exception_flags(0, &env->fp_status);
         n = floatx80_to_int32_round_to_zero(ST1, &env->fp_status);
         set_float_exception_flags(save_flags, &env->fp_status);
-        env->fp_status.floatx80_rounding_precision = floatx80_precision_x;
+        set_floatx80_rounding_precision(floatx80_precision_x, &env->fp_status);
         ST0 = floatx80_scalbn(ST0, n, &env->fp_status);
-        env->fp_status.floatx80_rounding_precision = save;
+        set_floatx80_rounding_precision(save, &env->fp_status);
     }
     merge_exception_flags(env, old_flags);
 }
diff --git a/target/m68k/softfloat.c b/target/m68k/softfloat.c
index 51706f6db8..f5d683bcc5 100644
--- a/target/m68k/softfloat.c
+++ b/target/m68k/softfloat.c
@@ -72,7 +72,8 @@ floatx80 floatx80_getman(floatx80 a, float_status *status)
         normalizeFloatx80Subnormal(aSig, &aExp, &aSig);
     }

-    return roundAndPackFloatx80(status->floatx80_rounding_precision, aSign,
+    return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
+                                aSign,
                                 0x3FFF, aSig, 0, status);
 }

@@ -160,7 +161,7 @@ floatx80 floatx80_scale(floatx80 a, floatx80 b, float_status *status)

     if (0x400F < bExp) {
         aExp = bSign ? -0x6001 : 0xE000;
-        return roundAndPackFloatx80(status->floatx80_rounding_precision,
+        return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
                                     aSign, aExp, aSig, 0, status);
     }

@@ -168,7 +169,7 @@ floatx80 floatx80_scale(floatx80 a, floatx80 b, float_status *status)
     bSig >>= shiftCount;
     aExp = bSign ? (aExp - bSig) : (aExp + bSig);

-    return roundAndPackFloatx80(status->floatx80_rounding_precision,
+    return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
                                 aSign, aExp, aSig, 0, status);
 }

@@ -192,10 +193,11 @@ floatx80 floatx80_move(floatx80 a, float_status *status)
         if (aSig == 0) {
             return a;
         }
-        normalizeRoundAndPackFloatx80(status->floatx80_rounding_precision,
+        normalizeRoundAndPackFloatx80(get_floatx80_rounding_precision(status),
                                       aSign, aExp, aSig, 0, status);
     }
-    return roundAndPackFloatx80(status->floatx80_rounding_precision, aSign,
+    return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
+                                aSign,
                                 aExp, aSig, 0, status);
 }

@@ -267,9 +269,9 @@ floatx80 floatx80_lognp1(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     compact = floatx80_make_compact(aExp, aSig);

@@ -337,7 +339,7 @@ floatx80 floatx80_lognp1(floatx80 a, float_status *status)
         fp0 = floatx80_add(fp0, fp1, status); /* FP0 IS LOG(F) + LOG(1+U) */

         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_add(fp0, klog2, status);

@@ -403,7 +405,7 @@ floatx80 floatx80_lognp1(floatx80 a, float_status *status)
                            status); /* U*V*([B1+W*(B3+W*B5)] + [V*(B2+W*B4)]) */

         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_add(fp0, saveu, status);

@@ -465,9 +467,9 @@ floatx80 floatx80_logn(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     compact = floatx80_make_compact(aExp, aSig);

@@ -524,7 +526,7 @@ floatx80 floatx80_logn(floatx80 a, float_status *status)
         fp0 = floatx80_add(fp0, fp1, status); /* FP0 IS LOG(F) + LOG(1+U) */

         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_add(fp0, klog2, status);

@@ -570,7 +572,7 @@ floatx80 floatx80_logn(floatx80 a, float_status *status)
                            status); /* U*V*([B1+W*(B3+W*B5)] + [V*(B2+W*B4)]) */

         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_add(fp0, saveu, status);

@@ -621,15 +623,15 @@ floatx80 floatx80_log10(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     fp0 = floatx80_logn(a, status);
     fp1 = packFloatx80(0, 0x3FFD, UINT64_C(0xDE5BD8A937287195)); /* INV_L10 */

     set_float_rounding_mode(user_rnd_mode, status);
-    status->floatx80_rounding_precision = user_rnd_prec;
+    set_floatx80_rounding_precision(user_rnd_prec, status);

     a = floatx80_mul(fp0, fp1, status); /* LOGN(X)*INV_L10 */

@@ -680,13 +682,13 @@ floatx80 floatx80_log2(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     if (aSig == one_sig) { /* X is 2^k */
         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = int32_to_floatx80(aExp - 0x3FFF, status);
     } else {
@@ -694,7 +696,7 @@ floatx80 floatx80_log2(floatx80 a, float_status *status)
         fp1 = packFloatx80(0, 0x3FFF, UINT64_C(0xB8AA3B295C17F0BC)); /* INV_L2 */

         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_mul(fp0, fp1, status); /* LOGN(X)*INV_L2 */
     }
@@ -740,9 +742,9 @@ floatx80 floatx80_etox(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     adjflag = 0;

@@ -818,7 +820,7 @@ floatx80 floatx80_etox(floatx80 a, float_status *status)
             }

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_mul(fp0, scale, status);

@@ -828,15 +830,13 @@ floatx80 floatx80_etox(floatx80 a, float_status *status)
         } else { /* |X| >= 16380 log2 */
             if (compact > 0x400CB27C) { /* |X| >= 16480 log2 */
                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);
                 if (aSign) {
-                    a = roundAndPackFloatx80(
-                                           status->floatx80_rounding_precision,
-                                           0, -0x1000, aSig, 0, status);
+                    a = roundAndPackFloatx80(get_floatx80_rounding_precision(status),
+                                             0, -0x1000, aSig, 0, status);
                 } else {
-                    a = roundAndPackFloatx80(
-                                           status->floatx80_rounding_precision,
-                                           0, 0x8000, aSig, 0, status);
+                    a = roundAndPackFloatx80(get_floatx80_rounding_precision(status),
+                                             0, 0x8000, aSig, 0, status);
                 }
                 float_raise(float_flag_inexact, status);

@@ -877,7 +877,7 @@ floatx80 floatx80_etox(floatx80 a, float_status *status)
         }
     } else { /* |X| < 2^(-65) */
         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_add(a, float32_to_floatx80(make_float32(0x3F800000),
                          status), status); /* 1 + X */
@@ -923,9 +923,9 @@ floatx80 floatx80_twotox(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     fp0 = a;

@@ -935,18 +935,18 @@ floatx80 floatx80_twotox(floatx80 a, float_status *status)
         /* |X| > 16480 or |X| < 2^(-70) */
         if (compact > 0x3FFF8000) { /* |X| > 16480 */
             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             if (aSign) {
-                return roundAndPackFloatx80(status->floatx80_rounding_precision,
+                return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
                                             0, -0x1000, aSig, 0, status);
             } else {
-                return roundAndPackFloatx80(status->floatx80_rounding_precision,
+                return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
                                             0, 0x8000, aSig, 0, status);
             }
         } else { /* |X| < 2^(-70) */
             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_add(fp0, float32_to_floatx80(
                              make_float32(0x3F800000), status),
@@ -1028,7 +1028,7 @@ floatx80 floatx80_twotox(floatx80 a, float_status *status)
         fp0 = floatx80_add(fp0, fact1, status);

         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_mul(fp0, adjfact, status);

@@ -1073,9 +1073,9 @@ floatx80 floatx80_tentox(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     fp0 = a;

@@ -1085,18 +1085,18 @@ floatx80 floatx80_tentox(floatx80 a, float_status *status)
         /* |X| > 16480 LOG2/LOG10 or |X| < 2^(-70) */
         if (compact > 0x3FFF8000) { /* |X| > 16480 */
             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             if (aSign) {
-                return roundAndPackFloatx80(status->floatx80_rounding_precision,
+                return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
                                             0, -0x1000, aSig, 0, status);
             } else {
-                return roundAndPackFloatx80(status->floatx80_rounding_precision,
+                return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
                                             0, 0x8000, aSig, 0, status);
             }
         } else { /* |X| < 2^(-70) */
             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_add(fp0, float32_to_floatx80(
                              make_float32(0x3F800000), status),
@@ -1183,7 +1183,7 @@ floatx80 floatx80_tentox(floatx80 a, float_status *status)
         fp0 = floatx80_add(fp0, fact1, status);

         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_mul(fp0, adjfact, status);

@@ -1228,9 +1228,9 @@ floatx80 floatx80_tan(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     compact = floatx80_make_compact(aExp, aSig);

@@ -1295,7 +1295,7 @@ floatx80 floatx80_tan(floatx80 a, float_status *status)
             goto loop;
         } else {
             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_move(a, status);

@@ -1355,7 +1355,7 @@ floatx80 floatx80_tan(floatx80 a, float_status *status)
             fp1 = packFloatx80(xSign, xExp, xSig);

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_div(fp0, fp1, status);

@@ -1393,7 +1393,7 @@ floatx80 floatx80_tan(floatx80 a, float_status *status)
                                status); /* 1+S(Q1+S(Q2+S(Q3+SQ4))) */

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_div(fp0, fp1, status);

@@ -1439,9 +1439,9 @@ floatx80 floatx80_sin(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     compact = floatx80_make_compact(aExp, aSig);

@@ -1510,7 +1510,7 @@ floatx80 floatx80_sin(floatx80 a, float_status *status)
                                       status); /* 1 */

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             /* SINTINY */
             a = floatx80_move(a, status);
@@ -1583,7 +1583,7 @@ floatx80 floatx80_sin(floatx80 a, float_status *status)
             fp0 = floatx80_mul(fp0, x, status);

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_add(fp0, float32_to_floatx80(posneg1, status), status);

@@ -1633,7 +1633,7 @@ floatx80 floatx80_sin(floatx80 a, float_status *status)
             fp0 = floatx80_mul(fp0, fp1, status); /* SIN(R')-R' */

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_add(fp0, x, status);

@@ -1679,9 +1679,9 @@ floatx80 floatx80_cos(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     compact = floatx80_make_compact(aExp, aSig);

@@ -1749,7 +1749,7 @@ floatx80 floatx80_cos(floatx80 a, float_status *status)
             fp0 = float32_to_floatx80(make_float32(0x3F800000), status); /* 1 */

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             /* COSTINY */
             a = floatx80_sub(fp0, float32_to_floatx80(
@@ -1823,7 +1823,7 @@ floatx80 floatx80_cos(floatx80 a, float_status *status)
             fp0 = floatx80_mul(fp0, x, status);

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_add(fp0, float32_to_floatx80(posneg1, status), status);

@@ -1871,7 +1871,7 @@ floatx80 floatx80_cos(floatx80 a, float_status *status)
             fp0 = floatx80_mul(fp0, fp1, status); /* SIN(R')-R' */

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_add(fp0, x, status);

@@ -1918,9 +1918,9 @@ floatx80 floatx80_atan(floatx80 a, float_status *status)
     compact = floatx80_make_compact(aExp, aSig);

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     if (compact < 0x3FFB8000 || compact > 0x4002FFFF) {
         /* |X| >= 16 or |X| < 1/16 */
@@ -1930,7 +1930,7 @@ floatx80 floatx80_atan(floatx80 a, float_status *status)
                 fp1 = packFloatx80(aSign, 0x0001, one_sig);

                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);

                 a = floatx80_sub(fp0, fp1, status);

@@ -1970,7 +1970,7 @@ floatx80 floatx80_atan(floatx80 a, float_status *status)
                 fp1 = packFloatx80(aSign, piby2_exp, pi_sig);

                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);

                 a = floatx80_add(fp0, fp1, status);

@@ -1981,7 +1981,7 @@ floatx80 floatx80_atan(floatx80 a, float_status *status)
         } else { /* |X| < 1/16 */
             if (compact < 0x3FD78000) { /* |X| < 2^(-40) */
                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);

                 a = floatx80_move(a, status);

@@ -2021,7 +2021,7 @@ floatx80 floatx80_atan(floatx80 a, float_status *status)
                 fp0 = floatx80_mul(fp0, fp1, status);

                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);

                 a = floatx80_add(fp0, xsave, status);

@@ -2070,7 +2070,7 @@ floatx80 floatx80_atan(floatx80 a, float_status *status)
         fp0 = floatx80_add(fp0, fp1, status); /* ATAN(U) */

         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_add(fp0, fp3, status); /* ATAN(X) */

@@ -2123,9 +2123,9 @@ floatx80 floatx80_asin(floatx80 a, float_status *status)
     } /* |X| < 1 */

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     one = packFloatx80(0, one_exp, one_sig);
     fp0 = a;
@@ -2137,7 +2137,7 @@ floatx80 floatx80_asin(floatx80 a, float_status *status)
     fp0 = floatx80_div(fp0, fp1, status);   /* X/SQRT((1+X)*(1-X)) */

     set_float_rounding_mode(user_rnd_mode, status);
-    status->floatx80_rounding_precision = user_rnd_prec;
+    set_floatx80_rounding_precision(user_rnd_prec, status);

     a = floatx80_atan(fp0, status);         /* ATAN(X/SQRT((1+X)*(1-X))) */

@@ -2171,7 +2171,8 @@ floatx80 floatx80_acos(floatx80 a, float_status *status)
     }
     if (aExp == 0 && aSig == 0) {
         float_raise(float_flag_inexact, status);
-        return roundAndPackFloatx80(status->floatx80_rounding_precision, 0,
+        return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
+                                    0,
                                     piby2_exp, pi_sig, 0, status);
     }

@@ -2193,9 +2194,9 @@ floatx80 floatx80_acos(floatx80 a, float_status *status)
     } /* |X| < 1 */

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     one = packFloatx80(0, one_exp, one_sig);
     fp0 = a;
@@ -2207,7 +2208,7 @@ floatx80 floatx80_acos(floatx80 a, float_status *status)
     fp0 = floatx80_atan(fp0, status);       /* ATAN(SQRT((1-X)/(1+X))) */

     set_float_rounding_mode(user_rnd_mode, status);
-    status->floatx80_rounding_precision = user_rnd_prec;
+    set_floatx80_rounding_precision(user_rnd_prec, status);

     a = floatx80_add(fp0, fp0, status);     /* 2 * ATAN(SQRT((1-X)/(1+X))) */

@@ -2257,9 +2258,9 @@ floatx80 floatx80_atanh(floatx80 a, float_status *status)
     } /* |X| < 1 */

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     one = packFloatx80(0, one_exp, one_sig);
     fp2 = packFloatx80(aSign, 0x3FFE, one_sig); /* SIGN(X) * (1/2) */
@@ -2271,7 +2272,7 @@ floatx80 floatx80_atanh(floatx80 a, float_status *status)
     fp0 = floatx80_lognp1(fp0, status); /* LOG1P(Z) */

     set_float_rounding_mode(user_rnd_mode, status);
-    status->floatx80_rounding_precision = user_rnd_prec;
+    set_floatx80_rounding_precision(user_rnd_prec, status);

     a = floatx80_mul(fp0, fp2,
                      status); /* ATANH(X) = SIGN(X) * (1/2) * LOG1P(Z) */
@@ -2316,9 +2317,9 @@ floatx80 floatx80_etoxm1(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     if (aExp >= 0x3FFD) { /* |X| >= 1/4 */
         compact = floatx80_make_compact(aExp, aSig);
@@ -2411,7 +2412,7 @@ floatx80 floatx80_etoxm1(floatx80 a, float_status *status)
             sc = packFloatx80(0, m + 0x3FFF, one_sig);

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_mul(fp0, sc, status);

@@ -2424,7 +2425,7 @@ floatx80 floatx80_etoxm1(floatx80 a, float_status *status)
                       status); /* -1 */

                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);

                 a = floatx80_add(fp0, float32_to_floatx80(
                                  make_float32(0x00800000), status),
@@ -2435,7 +2436,7 @@ floatx80 floatx80_etoxm1(floatx80 a, float_status *status)
                 return a;
             } else {
                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);

                 return floatx80_etox(a, status);
             }
@@ -2496,7 +2497,7 @@ floatx80 floatx80_etoxm1(floatx80 a, float_status *status)
             fp0 = floatx80_add(fp0, fp1, status); /* S*B1+Q */

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_add(fp0, a, status);

@@ -2514,14 +2515,14 @@ floatx80 floatx80_etoxm1(floatx80 a, float_status *status)
                 fp0 = floatx80_add(fp0, sc, status);

                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);

                 a = floatx80_mul(fp0, float64_to_floatx80(
                                  make_float64(0x3730000000000000), status),
                                  status);
             } else {
                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);

                 a = floatx80_add(fp0, sc, status);
             }
@@ -2566,9 +2567,9 @@ floatx80 floatx80_tanh(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     compact = floatx80_make_compact(aExp, aSig);

@@ -2577,7 +2578,7 @@ floatx80 floatx80_tanh(floatx80 a, float_status *status)
         if (compact < 0x3FFF8000) {
             /* TANHSM */
             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_move(a, status);

@@ -2594,7 +2595,7 @@ floatx80 floatx80_tanh(floatx80 a, float_status *status)
                 sign ^= 0x80800000; /* -SIGN(X)*EPS */

                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);

                 a = floatx80_add(fp0, float32_to_floatx80(make_float32(sign),
                                  status), status);
@@ -2616,7 +2617,7 @@ floatx80 floatx80_tanh(floatx80 a, float_status *status)
                                           status); /* SIGN */

                 set_float_rounding_mode(user_rnd_mode, status);
-                status->floatx80_rounding_precision = user_rnd_prec;
+                set_floatx80_rounding_precision(user_rnd_prec, status);

                 a = floatx80_add(fp1, fp0, status);

@@ -2639,7 +2640,7 @@ floatx80 floatx80_tanh(floatx80 a, float_status *status)
         fp1 = packFloatx80(vSign ^ aSign, vExp, vSig);

         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_div(fp0, fp1, status);

@@ -2682,9 +2683,9 @@ floatx80 floatx80_sinh(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     compact = floatx80_make_compact(aExp, aSig);

@@ -2692,9 +2693,9 @@ floatx80 floatx80_sinh(floatx80 a, float_status *status)
         /* SINHBIG */
         if (compact > 0x400CB2B3) {
             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

-            return roundAndPackFloatx80(status->floatx80_rounding_precision,
+            return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
                                         aSign, 0x8000, aSig, 0, status);
         } else {
             fp0 = floatx80_abs(a); /* Y = |X| */
@@ -2708,7 +2709,7 @@ floatx80 floatx80_sinh(floatx80 a, float_status *status)
             fp2 = packFloatx80(aSign, 0x7FFB, one_sig);

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_mul(fp0, fp2, status);

@@ -2728,7 +2729,7 @@ floatx80 floatx80_sinh(floatx80 a, float_status *status)
         fact = packFloat32(aSign, 0x7E, 0);

         set_float_rounding_mode(user_rnd_mode, status);
-        status->floatx80_rounding_precision = user_rnd_prec;
+        set_floatx80_rounding_precision(user_rnd_prec, status);

         a = floatx80_mul(fp0, float32_to_floatx80(fact, status), status);

@@ -2768,17 +2769,18 @@ floatx80 floatx80_cosh(floatx80 a, float_status *status)
     }

     user_rnd_mode = get_float_rounding_mode(status);
-    user_rnd_prec = status->floatx80_rounding_precision;
+    user_rnd_prec = get_floatx80_rounding_precision(status);
     set_float_rounding_mode(float_round_nearest_even, status);
-    status->floatx80_rounding_precision = floatx80_precision_x;
+    set_floatx80_rounding_precision(floatx80_precision_x, status);

     compact = floatx80_make_compact(aExp, aSig);

     if (compact > 0x400CB167) {
         if (compact > 0x400CB2B3) {
             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
-            return roundAndPackFloatx80(status->floatx80_rounding_precision, 0,
+            set_floatx80_rounding_precision(user_rnd_prec, status);
+            return roundAndPackFloatx80(get_floatx80_rounding_precision(status),
+                                        0,
                                         0x8000, one_sig, 0, status);
         } else {
             fp0 = packFloatx80(0, aExp, aSig);
@@ -2792,7 +2794,7 @@ floatx80 floatx80_cosh(floatx80 a, float_status *status)
             fp1 = packFloatx80(0, 0x7FFB, one_sig);

             set_float_rounding_mode(user_rnd_mode, status);
-            status->floatx80_rounding_precision = user_rnd_prec;
+            set_floatx80_rounding_precision(user_rnd_prec, status);

             a = floatx80_mul(fp0, fp1, status);

@@ -2810,7 +2812,7 @@ floatx80 floatx80_cosh(floatx80 a, float_status *status)
     fp1 = floatx80_div(fp1, fp0, status); /* 1/(2*EXP(|X|)) */

     set_float_rounding_mode(user_rnd_mode, status);
-    status->floatx80_rounding_precision = user_rnd_prec;
+    set_floatx80_rounding_precision(user_rnd_prec, status);

     a = floatx80_add(fp0, fp1, status);

diff --git a/tests/fp/fp-test.c b/tests/fp/fp-test.c
index fdb0cccf14..326a1201f3 100644
--- a/tests/fp/fp-test.c
+++ b/tests/fp/fp-test.c
@@ -996,7 +996,7 @@ void run_test(void)

                 verCases_roundingPrecision = 0;
                 slow_extF80_roundingPrecision = prec80;
-                qsf.floatx80_rounding_precision = qsf_prec80;
+                set_floatx80_rounding_precision(qsf_prec80, &qsf);

                 if (attrs & FUNC_EFF_ROUNDINGPRECISION) {
                     verCases_roundingPrecision = prec80;