Browse Source

* RiscV: more reliable use_fma

florian 8 months ago
parent
commit
4888442fb4
1 changed files with 4 additions and 1 deletions
  1. 4 1
      compiler/riscv/nrvadd.pas

+ 4 - 1
compiler/riscv/nrvadd.pas

@@ -339,7 +339,10 @@ implementation
 
 
     function trvaddnode.use_fma: boolean;
     function trvaddnode.use_fma: boolean;
       begin
       begin
-        Result:=current_settings.fputype in [fpu_fd];
+        Result:=(is_single(left.resultdef) and is_single(right.resultdef) and
+          (CPURV_HAS_F in cpu_capabilities[current_settings.cputype])) or
+          (is_double(left.resultdef) and is_double(right.resultdef) and
+          (CPURV_HAS_D in cpu_capabilities[current_settings.cputype]));
       end;
       end;