From 8de4da147550c707909dac5420e4cf2119a18dc9 Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Mon, 8 Oct 2018 11:06:52 -0400 Subject: [PATCH] softfloat: Specialize udiv_qrnnd for x86_64 The ISA has a 128/64-bit division instruction. Backports commit b299e88d4261b0af30190e74005ad930e04f3a11 from qemu --- qemu/fpu/softfloat-macros.h | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/qemu/fpu/softfloat-macros.h b/qemu/fpu/softfloat-macros.h index 7f058dd5..9f9097a2 100644 --- a/qemu/fpu/softfloat-macros.h +++ b/qemu/fpu/softfloat-macros.h @@ -637,6 +637,11 @@ static inline uint64_t estimateDiv128To64(uint64_t a0, uint64_t a1, uint64_t b) static inline uint64_t udiv_qrnnd(uint64_t *r, uint64_t n1, uint64_t n0, uint64_t d) { +#if defined(__x86_64__) + uint64_t q; + asm("divq %4" : "=a"(q), "=d"(*r) : "0"(n0), "1"(n1), "rm"(d)); + return q; +#else uint64_t d0, d1, q0, q1, r1, r0, m; d0 = (uint32_t)d; @@ -676,6 +681,7 @@ static inline uint64_t udiv_qrnnd(uint64_t *r, uint64_t n1, *r = r0; return (q1 << 32) | q0; +#endif } /*----------------------------------------------------------------------------