mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-08-17 19:11:03 +02:00
* when doing a pointer comparison on i8086, don't cast a far pointer to a near one (pchar), but use a far one instead
git-svn-id: trunk@24866 -
This commit is contained in:
parent
894d400a7b
commit
d387182bd6
@ -1618,12 +1618,22 @@ implementation
|
|||||||
{ a voidpointer of 8 bytes). A conversion to voidpointer would be }
|
{ a voidpointer of 8 bytes). A conversion to voidpointer would be }
|
||||||
{ optimized away, since the result already was a voidpointer, so }
|
{ optimized away, since the result already was a voidpointer, so }
|
||||||
{ use a charpointer instead (JM) }
|
{ use a charpointer instead (JM) }
|
||||||
{$ifndef jvm}
|
{$if defined(jvm)}
|
||||||
inserttypeconv_internal(left,charpointertype);
|
|
||||||
inserttypeconv_internal(right,charpointertype);
|
|
||||||
{$else jvm}
|
|
||||||
inserttypeconv_internal(left,java_jlobject);
|
inserttypeconv_internal(left,java_jlobject);
|
||||||
inserttypeconv_internal(right,java_jlobject);
|
inserttypeconv_internal(right,java_jlobject);
|
||||||
|
{$elseif defined(i8086)}
|
||||||
|
{ we don't have a charfarpointertype yet, so for far pointers we use bytefarpointertype }
|
||||||
|
if is_farpointer(left.resultdef) then
|
||||||
|
inserttypeconv_internal(left,bytefarpointertype)
|
||||||
|
else
|
||||||
|
inserttypeconv_internal(left,charpointertype);
|
||||||
|
if is_farpointer(right.resultdef) then
|
||||||
|
inserttypeconv_internal(right,bytefarpointertype)
|
||||||
|
else
|
||||||
|
inserttypeconv_internal(right,charpointertype);
|
||||||
|
{$else}
|
||||||
|
inserttypeconv_internal(left,charpointertype);
|
||||||
|
inserttypeconv_internal(right,charpointertype);
|
||||||
{$endif jvm}
|
{$endif jvm}
|
||||||
end;
|
end;
|
||||||
ltn,lten,gtn,gten:
|
ltn,lten,gtn,gten:
|
||||||
|
Loading…
Reference in New Issue
Block a user