[PATCH] D86453: [AArch64] Support conversion between fp16 and fp128
Adhemerval Zanella via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Sep 8 12:58:44 PDT 2020
zatrazz added inline comments.
================
Comment at: compiler-rt/lib/builtins/fp_extend.h:43
#elif defined SRC_HALF
+#if defined COMPILER_RT_HAS_FLOAT16
+typedef _Float16 src_t;
----------------
MaskRay wrote:
> zatrazz wrote:
> > MaskRay wrote:
> > > MaskRay wrote:
> > > > `#ifdef` ? ditto below
> > > You can mark the comment above as "Done".
> > >
> > > _Float16 and uint16_t are different types. Do all the `*hf*` functions change their signatures when `_Float16` is supported? This still looks strange.
> > I think using _Float16 for generic support does make more sense, since float16 support is really an extension and with different calling convention on each architecture and even on some different ABIs. While it is uint16_t for armv6 due the soft-fp ABI, it is a complete different type with a different calling convention for aarch64. And I expect that other architectures to use similar strategies now that it is supported on some vector extensions in some new chips (POWER10 for instance).
> >
> > Also, for ABI which expects *hf* to have 'uint16_t' as calling convetion it would be better to compartmentalize it to the specific arch folder, for instance for arm (and this is what libgcc does for instance).
> If 'uint16_t' is more of an anomaly, @ab should the arm softfp implementation be moved to the specific arch folder?
I would say so, although I am not fully sure if any other architecture does use such routines (which in this case would need to add such routines as well).
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D86453/new/
https://reviews.llvm.org/D86453
More information about the llvm-commits
mailing list