mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-17 03:59:28 +02:00
+ implemented normalized huge pointer comparison
git-svn-id: trunk@28157 -
This commit is contained in:
parent
e80ecd4d5b
commit
3bb730d5b9
@ -37,6 +37,8 @@ interface
|
||||
function use_generic_mul32to64: boolean; override;
|
||||
function first_addpointer: tnode; override;
|
||||
function first_addhugepointer: tnode;
|
||||
function first_cmppointer: tnode; override;
|
||||
function first_cmphugepointer: tnode;
|
||||
procedure second_addordinal; override;
|
||||
procedure second_add64bit;override;
|
||||
procedure second_addfarpointer;
|
||||
@ -351,6 +353,53 @@ interface
|
||||
end;
|
||||
|
||||
|
||||
function ti8086addnode.first_cmppointer: tnode;
|
||||
begin
|
||||
if is_hugepointer(left.resultdef) or is_hugepointer(right.resultdef) then
|
||||
result:=first_cmphugepointer
|
||||
else
|
||||
result:=inherited;
|
||||
end;
|
||||
|
||||
|
||||
function ti8086addnode.first_cmphugepointer: tnode;
|
||||
var
|
||||
procname:string;
|
||||
begin
|
||||
result:=nil;
|
||||
|
||||
if not (cs_hugeptr_comparison_normalization in current_settings.localswitches) then
|
||||
begin
|
||||
expectloc:=LOC_FLAGS;
|
||||
exit;
|
||||
end;
|
||||
|
||||
case nodetype of
|
||||
equaln:
|
||||
procname:='fpc_hugeptr_cmp_normalized_e';
|
||||
unequaln:
|
||||
procname:='fpc_hugeptr_cmp_normalized_ne';
|
||||
ltn:
|
||||
procname:='fpc_hugeptr_cmp_normalized_b';
|
||||
lten:
|
||||
procname:='fpc_hugeptr_cmp_normalized_be';
|
||||
gtn:
|
||||
procname:='fpc_hugeptr_cmp_normalized_a';
|
||||
gten:
|
||||
procname:='fpc_hugeptr_cmp_normalized_ae';
|
||||
else
|
||||
internalerror(2014070401);
|
||||
end;
|
||||
|
||||
result := ccallnode.createintern(procname,
|
||||
ccallparanode.create(right,
|
||||
ccallparanode.create(left,nil)));
|
||||
left := nil;
|
||||
right := nil;
|
||||
firstpass(result);
|
||||
end;
|
||||
|
||||
|
||||
procedure ti8086addnode.second_addfarpointer;
|
||||
var
|
||||
tmpreg : tregister;
|
||||
|
Loading…
Reference in New Issue
Block a user