aboutsummaryrefslogtreecommitdiffstats
path: root/x86/Machregs.v
diff options
context:
space:
mode:
authorBernhard Schommer <bernhardschommer@gmail.com>2022-02-07 15:10:54 +0100
committerXavier Leroy <xavier.leroy@college-de-france.fr>2022-02-07 15:12:20 +0100
commit38b0425d524cd3e7260ac46e13153f007e8bc00d (patch)
tree987d9d3c42c6b0d7873115ec00fcdd99a714d7b5 /x86/Machregs.v
parent87de3969856cf6a5eb5e1615ec817a015ed90d1c (diff)
downloadcompcert-38b0425d524cd3e7260ac46e13153f007e8bc00d.tar.gz
compcert-38b0425d524cd3e7260ac46e13153f007e8bc00d.zip
Add op for float max and min for x86.
The ops `Omaxf` and `Ominf` have the same semantics as `minsd` and `maxsd` instruction, i.e. if both arguments are equal the second argument is returned as well as for NaN. The operations are the used in SelectOp to implement the built-in function `__builtin_fmax` and `__builtin_fmin`. Bug 32640
Diffstat (limited to 'x86/Machregs.v')
-rw-r--r--x86/Machregs.v2
1 files changed, 2 insertions, 0 deletions
diff --git a/x86/Machregs.v b/x86/Machregs.v
index a440bffc..042248a8 100644
--- a/x86/Machregs.v
+++ b/x86/Machregs.v
@@ -334,6 +334,8 @@ Definition two_address_op (op: operation) : bool :=
| Osubf => true
| Omulf => true
| Odivf => true
+ | Omaxf => true
+ | Ominf => true
| Onegfs => true
| Oabsfs => true
| Oaddfs => true