On 3/2/2022 05:49, Richard Earnshaw wrote:


On 01/03/2022 16:23, Kinsey Moore wrote:
Hi,

I'm looking at working on Cortex-R5F support for RTEMS, but it seems as if latest GCC supports the Cortex-R5. This R5 has implicit FPU support which would make it really R5F. The ARM reference page on this core (https://developer.arm.com/Processors/Cortex-R5) specifies that the FPU is optional. I see that the FPU support can probably be disabled using the nofp option to achieve Cortex-R5 support, but I was wondering why this is handled differently from the Cortex-R4[F] support since that is broken out into two different CPU entries in gcc/config/arm/arm-cpus.in. It appears that R7 and R8 are handled the same way as R5.

Is the R4/R4F just the legacy way of handling this and R5/7/8 are the new way?


Arm no-longer gives distinct product names for products that come in multiple guises.  Another example of this is that many armv8-a products have an optional crypto unit but have the same product name.

So to answer your question more directly, the -mcpu=cortex-r5 will by default be considered to have an FPU, provided that the compiler was built with --with-fpu=auto (the default).  If you specify --with-float-abi=soft, then even if the product has an FPU, or for some cases a SIMD unit, then these will never be used.  So I'd recommend:

For FP support: -mcpu=cortex-r5 -mfloat-abi=hard
For no FP support: -mcpu=cortex-r5 -mfloat-abi=soft

There's also a mid-way variant of -mcpu=cortex-r5 -mfloat-abi=softfp, which would use the FP hardware but use the soft-float calling conventions; this code is abi-compatible with the no-fp variant above.

Ah, ok. Thanks for that info. I guess ARM or their downstream vendors are just inconsistent about naming of those cores since I'm seeing R5F references in official documentation from the downstream vendors.


Kinsey

Reply via email to