Răsfoiți Sursa

* Float constants must be pooled using their the actual type, not the mapped type of assembler instruction. Otherwise e.g. extended may be mixed up with cextended, because both are mapped to ait_real_80bit.

git-svn-id: trunk@17787 -
sergei 14 ani în urmă
părinte
comite
3dba3a0219
1 a modificat fișierele cu 2 adăugiri și 2 ștergeri
  1. 2 2
      compiler/ncgcon.pas

+ 2 - 2
compiler/ncgcon.pas

@@ -116,7 +116,7 @@ implementation
       type
       type
         tfloatkey = record
         tfloatkey = record
           value: bestreal;
           value: bestreal;
-          aitype: taitype;
+          typ: tfloattype;
           swapped: boolean;
           swapped: boolean;
         end;
         end;
 
 
@@ -145,7 +145,7 @@ implementation
             { there may be gap between record fields, zero it out }
             { there may be gap between record fields, zero it out }
             fillchar(key,sizeof(key),0);
             fillchar(key,sizeof(key),0);
             key.value:=value_real;
             key.value:=value_real;
-            key.aitype:=realait;
+            key.typ:=tfloatdef(resultdef).floattype;
 {$ifdef ARM}
 {$ifdef ARM}
             key.swapped:=hiloswapped;
             key.swapped:=hiloswapped;
 {$endif ARM}
 {$endif ARM}