diff options
author | Bernhard Schommer <bernhardschommer@gmail.com> | 2022-02-07 15:10:54 +0100 |
---|---|---|
committer | Xavier Leroy <xavier.leroy@college-de-france.fr> | 2022-02-07 15:12:20 +0100 |
commit | 38b0425d524cd3e7260ac46e13153f007e8bc00d (patch) | |
tree | 987d9d3c42c6b0d7873115ec00fcdd99a714d7b5 /x86/Machregs.v | |
parent | 87de3969856cf6a5eb5e1615ec817a015ed90d1c (diff) | |
download | compcert-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.v | 2 |
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 |