// // arch/x86_64/fpu/sqrt_64.h // // This file is subject to the terms and conditions defined in // 'LICENSE', which is part of this source code package. // #include "common.h" #include #include static inline void fpu_sqrt_64(const uint64_t *fs, uint64_t *fd) { double fs_double, fd_double; __m128d fs_reg, fd_reg; // Prevent aliasing. memcpy(&fs_double, fs, sizeof(fs_double)); fs_reg = _mm_set_sd(fs_double); fd_reg = _mm_sqrt_sd(fs_reg, fs_reg); fd_double = _mm_cvtsd_f64(fd_reg); // Prevent aliasing. memcpy(fd, &fd_double, sizeof(fd_double)); }