summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUros Bizjak <uros@gcc.gnu.org>2016-06-13 23:34:07 +0200
committerUros Bizjak <uros@gcc.gnu.org>2016-06-13 23:34:07 +0200
commit385c7747b78f0e178666fb7f376d21389a3f0bb8 (patch)
treec7b6909eb3ebaf242aa655314fa820d26e2c5b3a
parent85ecd05c26d107921b166374dd77c40a393312c8 (diff)
downloadgcc-385c7747b78f0e178666fb7f376d21389a3f0bb8.tar.gz
i386-builtin-types.def (INT_FTYPE_FLOAT128): New function type.
* config/i386/i386-builtin-types.def (INT_FTYPE_FLOAT128): New function type. * config/i386/i386.c (enum ix86_builtins) [IX86_BUILTIN_SIGNBITQ]: New. (ix86_init_builtins): Add __builtin_signbitq function. (ix86_expand_args_builtin): Handle INT_FTYPE_FLOAT128. (ix86_expand_builtin): Handle IX86_BUILTIN_SIGNBITQ. * config/i386/i386.md (signbittf2): New expander. * config/i386/sse.md (ptesttf2): New insn pattern. * doc/extend.texi (x86 Built-in Functions): Document __builtin_signbitq. libgcc/ChangeLog: * config.host (i[34567]86-*-* | x86_64-*-*): Always include i386/${host_address}/t-softfp in tmake_file. * config/i386/32/t-softfp: Update comment for __builtin_copysignq. * config/i386/32/tf-signs.c: Add __signbittf2 fallback function. * config/i386/64/t-softfp: New file. * config/i386/64/tf-signs.c: Ditto. * config/i386/libgcc-bsd.ver: Add __signbittf2. * config/i386/libgcc-glibc.ver: Ditto. * config/i386/libgcc-sol2.ver: Ditto. testsuite/ChangeLog: * gcc.target/i386/float128-3.c: New test. * gcc.target/i386/quad-sse4.c: Ditto. * gcc.target/i386/quad-sse.c: Use -msse instead of -msse2. Update scan strings. From-SVN: r237415
-rw-r--r--gcc/ChangeLog18
-rw-r--r--gcc/config/i386/i386-builtin-types.def1
-rw-r--r--gcc/config/i386/i386.c41
-rw-r--r--gcc/config/i386/i386.md16
-rw-r--r--gcc/config/i386/sse.md13
-rw-r--r--gcc/doc/extend.texi1
-rw-r--r--gcc/testsuite/ChangeLog7
-rw-r--r--gcc/testsuite/gcc.target/i386/float128-3.c21
-rw-r--r--gcc/testsuite/gcc.target/i386/quad-sse.c4
-rw-r--r--gcc/testsuite/gcc.target/i386/quad-sse4.c11
-rw-r--r--libgcc/ChangeLog26
-rw-r--r--libgcc/config.host4
-rw-r--r--libgcc/config/i386/32/t-softfp3
-rw-r--r--libgcc/config/i386/32/tf-signs.c11
-rw-r--r--libgcc/config/i386/64/t-softfp2
-rw-r--r--libgcc/config/i386/64/tf-signs.c46
-rw-r--r--libgcc/config/i386/libgcc-bsd.ver4
-rw-r--r--libgcc/config/i386/libgcc-glibc.ver8
-rw-r--r--libgcc/config/i386/libgcc-sol2.ver4
19 files changed, 216 insertions, 25 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 7486c3245d4..5e62a97dcff 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,16 @@
+2016-06-13 Uros Bizjak <ubizjak@gmail.com>
+
+ * config/i386/i386-builtin-types.def (INT_FTYPE_FLOAT128):
+ New function type.
+ * config/i386/i386.c (enum ix86_builtins) [IX86_BUILTIN_SIGNBITQ]: New.
+ (ix86_init_builtins): Add __builtin_signbitq function.
+ (ix86_expand_args_builtin): Handle INT_FTYPE_FLOAT128.
+ (ix86_expand_builtin): Handle IX86_BUILTIN_SIGNBITQ.
+ * config/i386/i386.md (signbittf2): New expander.
+ * config/i386/sse.md (ptesttf2): New insn pattern.
+ * doc/extend.texi (x86 Built-in Functions): Document
+ __builtin_signbitq.
+
2016-06-13 David Malcolm <dmalcolm@redhat.com>
PR bootstrap/71481
@@ -201,8 +214,9 @@
* config/i386/i386.c (enum ix86_builtins) [IX86_BUILTIN_NANQ]: New.
[IX86_BUILTIN_NANSQ]: Ditto.
(ix86_fold_builtin): Handle IX86_BUILTIN_NANQ and IX86_BUILTIN_NANSQ.
- (ix86_init_builtin_types) Declare const_string_type_node.
- Add __builtin_nanq and __builtin_nansq builtin functions.
+ (ix86_init_builtin_types): Declare const_string_type_node.
+ (ix86_init_builtins): Add __builtin_nanq and __builtin_nansq
+ builtin functions.
(ix86_expand_builtin): Handle IX86_BUILTIN_NANQ and IX86_BUILTIN_NANSQ.
* doc/extend.texi (x86 Built-in Functions): Document
__builtin_nanq and __builtin_nansq.
diff --git a/gcc/config/i386/i386-builtin-types.def b/gcc/config/i386/i386-builtin-types.def
index 7eb6fc96e66..dba9ecb28e1 100644
--- a/gcc/config/i386/i386-builtin-types.def
+++ b/gcc/config/i386/i386-builtin-types.def
@@ -202,6 +202,7 @@ DEF_FUNCTION_TYPE (INT, V8QI)
DEF_FUNCTION_TYPE (INT, V8SF)
DEF_FUNCTION_TYPE (INT, V32QI)
DEF_FUNCTION_TYPE (INT, PCCHAR)
+DEF_FUNCTION_TYPE (INT, FLOAT128)
DEF_FUNCTION_TYPE (INT64, INT64)
DEF_FUNCTION_TYPE (INT64, V2DF)
DEF_FUNCTION_TYPE (INT64, V4SF)
diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c
index c5e5e1238a5..4e52d939141 100644
--- a/gcc/config/i386/i386.c
+++ b/gcc/config/i386/i386.c
@@ -32722,6 +32722,7 @@ enum ix86_builtins
IX86_BUILTIN_NANSQ,
IX86_BUILTIN_FABSQ,
IX86_BUILTIN_COPYSIGNQ,
+ IX86_BUILTIN_SIGNBITQ,
/* Vectorizer support builtins. */
IX86_BUILTIN_CPYSGNPS,
@@ -33983,6 +33984,8 @@ static const struct builtin_description bdesc_args[] =
{ OPTION_MASK_ISA_SSE4_1, CODE_FOR_sse4_1_mulv2siv2di3, "__builtin_ia32_pmuldq128", IX86_BUILTIN_PMULDQ128, UNKNOWN, (int) V2DI_FTYPE_V4SI_V4SI },
{ OPTION_MASK_ISA_SSE4_1, CODE_FOR_mulv4si3, "__builtin_ia32_pmulld128", IX86_BUILTIN_PMULLD128, UNKNOWN, (int) V4SI_FTYPE_V4SI_V4SI },
+ { OPTION_MASK_ISA_SSE4_1, CODE_FOR_signbittf2, 0, IX86_BUILTIN_SIGNBITQ, UNKNOWN, (int) INT_FTYPE_FLOAT128 },
+
/* SSE4.1 */
{ OPTION_MASK_ISA_ROUND, CODE_FOR_sse4_1_roundpd, "__builtin_ia32_roundpd", IX86_BUILTIN_ROUNDPD, UNKNOWN, (int) V2DF_FTYPE_V2DF_INT },
{ OPTION_MASK_ISA_ROUND, CODE_FOR_sse4_1_roundps, "__builtin_ia32_roundps", IX86_BUILTIN_ROUNDPS, UNKNOWN, (int) V4SF_FTYPE_V4SF_INT },
@@ -38299,6 +38302,13 @@ ix86_init_builtins (void)
TREE_READONLY (decl) = 1;
ix86_builtins[(int) IX86_BUILTIN_COPYSIGNQ] = decl;
+ ftype = ix86_get_builtin_func_type (INT_FTYPE_FLOAT128);
+ decl = add_builtin_function ("__builtin_signbitq", ftype,
+ IX86_BUILTIN_SIGNBITQ, BUILT_IN_MD,
+ "__signbittf2", NULL_TREE);
+ TREE_READONLY (decl) = 1;
+ ix86_builtins[(int) IX86_BUILTIN_SIGNBITQ] = decl;
+
ix86_init_tm_builtins ();
ix86_init_mmx_sse_builtins ();
ix86_init_mpx_builtins ();
@@ -39128,6 +39138,7 @@ ix86_expand_args_builtin (const struct builtin_description *d,
case INT_FTYPE_V4SF:
case INT_FTYPE_V2DF:
case INT_FTYPE_V32QI:
+ case INT_FTYPE_FLOAT128:
case V16QI_FTYPE_V16QI:
case V8SI_FTYPE_V8SF:
case V8SI_FTYPE_V4SI:
@@ -42638,16 +42649,26 @@ rdseed_step:
i < ARRAY_SIZE (bdesc_args);
i++, d++)
if (d->code == fcode)
- switch (fcode)
- {
- case IX86_BUILTIN_FABSQ:
- case IX86_BUILTIN_COPYSIGNQ:
- if (!TARGET_SSE)
- /* Emit a normal call if SSE isn't available. */
- return expand_call (exp, target, ignore);
- default:
- return ix86_expand_args_builtin (d, exp, target);
- }
+ {
+ switch (fcode)
+ {
+ case IX86_BUILTIN_FABSQ:
+ case IX86_BUILTIN_COPYSIGNQ:
+ if (!TARGET_SSE)
+ /* Emit a normal call if SSE isn't available. */
+ return expand_call (exp, target, ignore);
+ break;
+ case IX86_BUILTIN_SIGNBITQ:
+ if (!TARGET_SSE4_1)
+ /* Emit a normal call if SSE4_1 isn't available. */
+ return expand_call (exp, target, ignore);
+ break;
+ default:
+ break;
+ }
+
+ return ix86_expand_args_builtin (d, exp, target);
+ }
for (i = 0, d = bdesc_comi; i < ARRAY_SIZE (bdesc_comi); i++, d++)
if (d->code == fcode)
diff --git a/gcc/config/i386/i386.md b/gcc/config/i386/i386.md
index 86837525628..e69a7e44267 100644
--- a/gcc/config/i386/i386.md
+++ b/gcc/config/i386/i386.md
@@ -16198,6 +16198,22 @@
DONE;
})
+(define_expand "signbittf2"
+ [(use (match_operand:SI 0 "register_operand"))
+ (use (match_operand:TF 1 "register_operand"))]
+ "TARGET_SSE4_1"
+{
+ rtx mask = ix86_build_signbit_mask (TFmode, 0, 0);
+ rtx scratch = gen_reg_rtx (QImode);
+
+ emit_insn (gen_ptesttf2 (operands[1], mask));
+ ix86_expand_setcc (scratch, NE,
+ gen_rtx_REG (CCZmode, FLAGS_REG), const0_rtx);
+
+ emit_insn (gen_zero_extendqisi2 (operands[0], scratch));
+ DONE;
+})
+
(define_expand "signbitxf2"
[(use (match_operand:SI 0 "register_operand"))
(use (match_operand:XF 1 "register_operand"))]
diff --git a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md
index 82ef04a2a03..6056ddc2ee5 100644
--- a/gcc/config/i386/sse.md
+++ b/gcc/config/i386/sse.md
@@ -15212,6 +15212,19 @@
(const_string "*")))
(set_attr "mode" "<sseinsnmode>")])
+(define_insn "ptesttf2"
+ [(set (reg:CC FLAGS_REG)
+ (unspec:CC [(match_operand:TF 0 "register_operand" "Yr, *x, x")
+ (match_operand:TF 1 "vector_operand" "YrBm, *xBm, xm")]
+ UNSPEC_PTEST))]
+ "TARGET_SSE4_1"
+ "%vptest\t{%1, %0|%0, %1}"
+ [(set_attr "isa" "noavx,noavx,avx")
+ (set_attr "type" "ssecomi")
+ (set_attr "prefix_extra" "1")
+ (set_attr "prefix" "orig,orig,vex")
+ (set_attr "mode" "TI")])
+
(define_insn "<sse4_1>_round<ssemodesuffix><avxsizesuffix>"
[(set (match_operand:VF_128_256 0 "register_operand" "=Yr,*x,x")
(unspec:VF_128_256
diff --git a/gcc/doc/extend.texi b/gcc/doc/extend.texi
index 06d52b8ce0d..859f6847fda 100644
--- a/gcc/doc/extend.texi
+++ b/gcc/doc/extend.texi
@@ -18480,6 +18480,7 @@ of them implement the function that is part of the name.
@smallexample
__float128 __builtin_fabsq (__float128)
__float128 __builtin_copysignq (__float128, __float128)
+int __builtin_signbitq (__float128)
@end smallexample
The following built-in functions are always available.
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 45862f3851c..d77a5eabca8 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,10 @@
+2016-06-13 Uros Bizjak <ubizjak@gmail.com>
+
+ * gcc.target/i386/float128-3.c: New test.
+ * gcc.target/i386/quad-sse4.c: Ditto.
+ * gcc.target/i386/quad-sse.c: Use -msse instead of -msse2.
+ Update scan strings.
+
2016-06-13 Jakub Jelinek <jakub@redhat.com>
PR sanitizer/71498
diff --git a/gcc/testsuite/gcc.target/i386/float128-3.c b/gcc/testsuite/gcc.target/i386/float128-3.c
new file mode 100644
index 00000000000..99bcd4906e8
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/float128-3.c
@@ -0,0 +1,21 @@
+/* { dg-do run } */
+/* { dg-options "-O2 -msse4.1" } */
+/* { dg-require-effective-target sse4 } */
+
+#include "sse4_1-check.h"
+
+extern void abort (void);
+
+static void
+sse4_1_test (void)
+{
+ static volatile __float128 a;
+
+ a = -1.2q;
+ if (!__builtin_signbitq (a))
+ abort ();
+
+ a = 1.2q;
+ if (__builtin_signbitq (a))
+ abort ();
+}
diff --git a/gcc/testsuite/gcc.target/i386/quad-sse.c b/gcc/testsuite/gcc.target/i386/quad-sse.c
index 4b6fe792575..cd09bd17db5 100644
--- a/gcc/testsuite/gcc.target/i386/quad-sse.c
+++ b/gcc/testsuite/gcc.target/i386/quad-sse.c
@@ -1,5 +1,5 @@
/* { dg-do compile } */
-/* { dg-options "-O2 -msse2" } */
+/* { dg-options "-O2 -msse" } */
__float128 x, y;
@@ -18,4 +18,4 @@ __float128 test_3(void)
return __builtin_copysignq (x, y);
}
-/* { dg-final { scan-assembler-not "call.*(neg|fabs|copysign)" } } */
+/* { dg-final { scan-assembler-not "neg|fabs|copysign" } } */
diff --git a/gcc/testsuite/gcc.target/i386/quad-sse4.c b/gcc/testsuite/gcc.target/i386/quad-sse4.c
new file mode 100644
index 00000000000..a08ea27afed
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/quad-sse4.c
@@ -0,0 +1,11 @@
+/* { dg-do compile } */
+/* { dg-options "-O2 -msse4.1" } */
+
+__float128 x;
+
+int __test_1(void)
+{
+ return __builtin_signbitq (x);
+}
+
+/* { dg-final { scan-assembler-not "signbit" } } */
diff --git a/libgcc/ChangeLog b/libgcc/ChangeLog
index 544ea65f102..557a041f71a 100644
--- a/libgcc/ChangeLog
+++ b/libgcc/ChangeLog
@@ -1,3 +1,15 @@
+2016-06-13 Uros Bizjak <ubizjak@gmail.com>
+
+ * config.host (i[34567]86-*-* | x86_64-*-*): Always include
+ i386/${host_address}/t-softfp in tmake_file.
+ * config/i386/32/t-softfp: Update comment for __builtin_copysignq.
+ * config/i386/32/tf-signs.c: Add __signbittf2 fallback function.
+ * config/i386/64/t-softfp: New file.
+ * config/i386/64/tf-signs.c: Ditto.
+ * config/i386/libgcc-bsd.ver: Add __signbittf2.
+ * config/i386/libgcc-glibc.ver: Ditto.
+ * config/i386/libgcc-sol2.ver: Ditto.
+
2016-06-05 Aaron Conole <aconole@redhat.com>
Nathan Sidwell <nathan@acm.org>
@@ -30,7 +42,7 @@
2016-05-19 Sandra Loosemore <sandra@codesourcery.com>
- * config.host [x86_64-*-cygwin*]: Handle tmake_eh_file for mixed
+ * config.host [x86_64-*-cygwin*]: Handle tmake_eh_file for mixed
dw2/seh configuration.
[x86_64-*-mingw*]: Likewise.
@@ -104,7 +116,7 @@
2016-03-28 James Bowman <james.bowman@ftdichip.com>
- * libgcc/config/ft32/lib1funcs.S (*divsi3, *modsi3): New.
+ * libgcc/config/ft32/lib1funcs.S (*divsi3, *modsi3): New.
2016-03-22 Michael Meissner <meissner@linux.vnet.ibm.com>
@@ -519,7 +531,7 @@
2015-10-02 Kirill Yukhin <kirill.yukhin@intel.com>
- * config/i386/cpuinfo.c (processor_features): Add
+ * config/i386/cpuinfo.c (processor_features): Add
FEATURE_AVX512VBMI and FEATURE_AVX512VBMI.
2015-09-28 Joseph Myers <joseph@codesourcery.com>
@@ -884,10 +896,10 @@
2015-05-15 Martin Galvan <martin.galvan@tallertechnologies.com>
- * config/arm/lib1funcs.S (CFI_START_FUNCTION, CFI_END_FUNCTION):
- New macros.
- * config/arm/ieee754-df.S: Add CFI directives.
- * config/arm/ieee754-sf.S: Add CFI directives.
+ * config/arm/lib1funcs.S (CFI_START_FUNCTION, CFI_END_FUNCTION):
+ New macros.
+ * config/arm/ieee754-df.S: Add CFI directives.
+ * config/arm/ieee754-sf.S: Add CFI directives.
2015-05-13 Eric Botcazou <ebotcazou@adacore.com>
diff --git a/libgcc/config.host b/libgcc/config.host
index 7899216af6c..0cd688ddd69 100644
--- a/libgcc/config.host
+++ b/libgcc/config.host
@@ -1361,9 +1361,7 @@ i[34567]86-*-darwin* | x86_64-*-darwin* | \
i[34567]86-*-freebsd* | x86_64-*-freebsd* | \
i[34567]86-*-openbsd* | x86_64-*-openbsd*)
tmake_file="${tmake_file} t-softfp-tf"
- if test "${host_address}" = 32; then
- tmake_file="${tmake_file} i386/${host_address}/t-softfp"
- fi
+ tmake_file="${tmake_file} i386/${host_address}/t-softfp"
tmake_file="${tmake_file} i386/t-softfp t-softfp"
;;
esac
diff --git a/libgcc/config/i386/32/t-softfp b/libgcc/config/i386/32/t-softfp
index a48a5b3b116..f27e7e64c22 100644
--- a/libgcc/config/i386/32/t-softfp
+++ b/libgcc/config/i386/32/t-softfp
@@ -1,5 +1,6 @@
# Omit TImode functions
softfp_int_modes := si di
-# Provide fallbacks for __builtin_copysignq and __builtin_fabsq.
+# Provide fallbacks for __builtin_copysignq, __builtin_fabsq
+# and __builtin_signbitq.
LIB2ADD += $(srcdir)/config/i386/32/tf-signs.c
diff --git a/libgcc/config/i386/32/tf-signs.c b/libgcc/config/i386/32/tf-signs.c
index 1e30626715f..d74c86a7282 100644
--- a/libgcc/config/i386/32/tf-signs.c
+++ b/libgcc/config/i386/32/tf-signs.c
@@ -37,6 +37,7 @@ union _FP_UNION_Q
__float128 __copysigntf3 (__float128, __float128);
__float128 __fabstf2 (__float128);
+int __signbittf2 (__float128);
__float128
__copysigntf3 (__float128 a, __float128 b)
@@ -60,3 +61,13 @@ __fabstf2 (__float128 a)
return A.flt;
}
+
+int
+__signbittf2 (__float128 a)
+{
+ union _FP_UNION_Q A;
+
+ A.flt = a;
+
+ return A.bits.sign;
+}
diff --git a/libgcc/config/i386/64/t-softfp b/libgcc/config/i386/64/t-softfp
new file mode 100644
index 00000000000..f159f74fe50
--- /dev/null
+++ b/libgcc/config/i386/64/t-softfp
@@ -0,0 +1,2 @@
+# Provide fallbacks for __builtin_signbitq
+LIB2ADD += $(srcdir)/config/i386/64/tf-signs.c
diff --git a/libgcc/config/i386/64/tf-signs.c b/libgcc/config/i386/64/tf-signs.c
new file mode 100644
index 00000000000..29dfaef09a4
--- /dev/null
+++ b/libgcc/config/i386/64/tf-signs.c
@@ -0,0 +1,46 @@
+/* Copyright (C) 2016 Free Software Foundation, Inc.
+
+This file is part of GCC.
+
+GCC is free software; you can redistribute it and/or modify it under
+the terms of the GNU General Public License as published by the Free
+Software Foundation; either version 3, or (at your option) any later
+version.
+
+GCC is distributed in the hope that it will be useful, but WITHOUT ANY
+WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+for more details.
+
+Under Section 7 of GPL version 3, you are granted additional
+permissions described in the GCC Runtime Library Exception, version
+3.1, as published by the Free Software Foundation.
+
+You should have received a copy of the GNU General Public License and
+a copy of the GCC Runtime Library Exception along with this program;
+see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+<http://www.gnu.org/licenses/>. */
+
+union _FP_UNION_Q
+{
+ __float128 flt;
+ struct
+ {
+ unsigned long long frac0 : 64;
+ unsigned long long frac1 : 48;
+ unsigned exp : 15;
+ unsigned sign : 1;
+ } bits __attribute__((packed));
+};
+
+int __signbittf3 (__float128);
+
+int
+__signbittf2 (__float128 a)
+{
+ union _FP_UNION_Q A;
+
+ A.flt = a;
+
+ return A.bits.sign;
+}
diff --git a/libgcc/config/i386/libgcc-bsd.ver b/libgcc/config/i386/libgcc-bsd.ver
index f80193ead36..c89f87ec266 100644
--- a/libgcc/config/i386/libgcc-bsd.ver
+++ b/libgcc/config/i386/libgcc-bsd.ver
@@ -111,3 +111,7 @@ GCC_4.8.0 {
__cpu_model
__cpu_indicator_init
}
+
+GCC_7.0.0 {
+ __signbittf2
+}
diff --git a/libgcc/config/i386/libgcc-glibc.ver b/libgcc/config/i386/libgcc-glibc.ver
index 443f8d6647a..6f664dc3f56 100644
--- a/libgcc/config/i386/libgcc-glibc.ver
+++ b/libgcc/config/i386/libgcc-glibc.ver
@@ -152,6 +152,10 @@ GCC_4.8.0 {
__cpu_model
__cpu_indicator_init
}
+
+GCC_7.0.0 {
+ __signbittf2
+}
%else
GCC_4.4.0 {
__addtf3
@@ -193,4 +197,8 @@ GCC_4.8.0 {
__cpu_model
__cpu_indicator_init
}
+
+GCC_7.0.0 {
+ __signbittf2
+}
%endif
diff --git a/libgcc/config/i386/libgcc-sol2.ver b/libgcc/config/i386/libgcc-sol2.ver
index cb9801ca9ec..185b424d4b8 100644
--- a/libgcc/config/i386/libgcc-sol2.ver
+++ b/libgcc/config/i386/libgcc-sol2.ver
@@ -111,3 +111,7 @@ GCC_4.8.0 {
__cpu_model
__cpu_indicator_init
}
+
+GCC_7.0.0 {
+ __signbittf2
+}