Follow @Openwall on Twitter for new release announcements and other news
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date: Fri, 28 Jul 2023 09:46:36 -0700
From: Khem Raj <raj.khem@...il.com>
To: musl@...ts.openwall.com
Cc: dalias@...c.org, zhangfei <zhangfei@...iscas.ac.cn>
Subject: Re: [PATCH 1/1] RISC-V: Add some mathematical functions to riscv64

On Thu, Jul 27, 2023 at 11:21 PM zhangfei <zhang_fei_0403@....com> wrote:
>
> From: zhangfei <zhangfei@...iscas.ac.cn>
>
> Add a series of function implementations such as lrint and lround.
>

Do you have some performance numbers with these implementations to share ?

> Signed-off-by: Zhang Fei<zhangfei@...iscas.ac.cn>
> ---
>  src/math/riscv64/llrint.c   | 16 ++++++++++++++++
>  src/math/riscv64/llrintf.c  | 16 ++++++++++++++++
>  src/math/riscv64/llround.c  | 16 ++++++++++++++++
>  src/math/riscv64/llroundf.c | 16 ++++++++++++++++
>  src/math/riscv64/lrint.c    | 16 ++++++++++++++++
>  src/math/riscv64/lrintf.c   | 16 ++++++++++++++++
>  src/math/riscv64/lround.c   | 16 ++++++++++++++++
>  src/math/riscv64/lroundf.c  | 16 ++++++++++++++++
>  8 files changed, 128 insertions(+)
>  create mode 100644 src/math/riscv64/llrint.c
>  create mode 100644 src/math/riscv64/llrintf.c
>  create mode 100644 src/math/riscv64/llround.c
>  create mode 100644 src/math/riscv64/llroundf.c
>  create mode 100644 src/math/riscv64/lrint.c
>  create mode 100644 src/math/riscv64/lrintf.c
>  create mode 100644 src/math/riscv64/lround.c
>  create mode 100644 src/math/riscv64/lroundf.c
>
> diff --git a/src/math/riscv64/llrint.c b/src/math/riscv64/llrint.c
> new file mode 100644
> index 0000000..2b5ea25
> --- /dev/null
> +++ b/src/math/riscv64/llrint.c
> @@ -0,0 +1,16 @@
> +#include <math.h>
> +
> +#if __riscv_flen >= 64
> +
> +long long llrint (double x)
> +{
> +       long long res;
> +       __asm__ ("fcvt.l.d %0, %1" : "=r" (res) : "f" (x));
> +       return res;
> +}
> +
> +#else
> +
> +#include "../llrint.c"
> +
> +#endif
> diff --git a/src/math/riscv64/llrintf.c b/src/math/riscv64/llrintf.c
> new file mode 100644
> index 0000000..d69566b
> --- /dev/null
> +++ b/src/math/riscv64/llrintf.c
> @@ -0,0 +1,16 @@
> +#include <math.h>
> +
> +#if __riscv_flen >= 32
> +
> +long long llrintf (float x)
> +{
> +       long long res;
> +       __asm__ ("fcvt.l.s %0, %1" : "=r" (res) : "f" (x));
> +       return res;
> +}
> +
> +#else
> +
> +#include "../llrintf.c"
> +
> +#endif
> diff --git a/src/math/riscv64/llround.c b/src/math/riscv64/llround.c
> new file mode 100644
> index 0000000..d6d2619
> --- /dev/null
> +++ b/src/math/riscv64/llround.c
> @@ -0,0 +1,16 @@
> +#include <math.h>
> +
> +#if __riscv_flen >= 64
> +
> +long long llround (double x)
> +{
> +       long long res;
> +       __asm__ ("fcvt.l.d %0, %1, rmm" : "=r" (res) : "f" (x));
> +       return res;
> +}
> +
> +#else
> +
> +#include "../llround.c"
> +
> +#endif
> diff --git a/src/math/riscv64/llroundf.c b/src/math/riscv64/llroundf.c
> new file mode 100644
> index 0000000..72b343a
> --- /dev/null
> +++ b/src/math/riscv64/llroundf.c
> @@ -0,0 +1,16 @@
> +#include <math.h>
> +
> +#if __riscv_flen >= 32
> +
> +long long llroundf (float x)
> +{
> +       long long res;
> +       __asm__ ("fcvt.l.s %0, %1, rmm" : "=r" (res) : "f" (x));
> +       return res;
> +}
> +
> +#else
> +
> +#include "../llroundf.c"
> +
> +#endif
> diff --git a/src/math/riscv64/lrint.c b/src/math/riscv64/lrint.c
> new file mode 100644
> index 0000000..c62e306
> --- /dev/null
> +++ b/src/math/riscv64/lrint.c
> @@ -0,0 +1,16 @@
> +#include <math.h>
> +
> +#if __riscv_flen >= 64
> +
> +long lrint (double x)
> +{
> +       long res;
> +       __asm__ ("fcvt.l.d %0, %1" : "=r" (res) : "f" (x));
> +       return res;
> +}
> +
> +#else
> +
> +#include "../lrint.c"
> +
> +#endif
> diff --git a/src/math/riscv64/lrintf.c b/src/math/riscv64/lrintf.c
> new file mode 100644
> index 0000000..6f3b120
> --- /dev/null
> +++ b/src/math/riscv64/lrintf.c
> @@ -0,0 +1,16 @@
> +#include <math.h>
> +
> +#if __riscv_flen >= 32
> +
> +long lrintf (float x)
> +{
> +       long res;
> +       __asm__ ("fcvt.l.s %0, %1" : "=r" (res) : "f" (x));
> +       return res;
> +}
> +
> +#else
> +
> +#include "../lrintf.c"
> +
> +#endif
> diff --git a/src/math/riscv64/lround.c b/src/math/riscv64/lround.c
> new file mode 100644
> index 0000000..7d061e8
> --- /dev/null
> +++ b/src/math/riscv64/lround.c
> @@ -0,0 +1,16 @@
> +#include <math.h>
> +
> +#if __riscv_flen >= 64
> +
> +long lround (double x)
> +{
> +       long res;
> +       __asm__ ("fcvt.l.d %0, %1, rmm" : "=r" (res) : "f" (x));
> +       return res;
> +}
> +
> +#else
> +
> +#include "../lround.c"
> +
> +#endif
> diff --git a/src/math/riscv64/lroundf.c b/src/math/riscv64/lroundf.c
> new file mode 100644
> index 0000000..34d978b
> --- /dev/null
> +++ b/src/math/riscv64/lroundf.c
> @@ -0,0 +1,16 @@
> +#include <math.h>
> +
> +#if __riscv_flen >= 32
> +
> +long lroundf (float x)
> +{
> +       long res;
> +       __asm__ ("fcvt.l.s %0, %1, rmm" : "=r" (res) : "f" (x));
> +       return res;
> +}
> +
> +#else
> +
> +#include "../lroundf.c"
> +
> +#endif
> --
> 2.34.1
>

Powered by blists - more mailing lists

Confused about mailing lists and their use? Read about mailing lists on Wikipedia and check out these guidelines on proper formatting of your messages.