* fixes several issues with loop unrolling

git-svn-id: trunk@29362 -
This commit is contained in:
florian 2014-12-31 15:45:06 +00:00
parent 868ba1560f
commit f813703cf3
2 changed files with 8 additions and 8 deletions

View File

@ -1524,8 +1524,11 @@ implementation
set_varstate(left,vs_written,[]);
{ loop unrolling }
if cs_opt_loopunroll in current_settings.optimizerswitches then
if (cs_opt_loopunroll in current_settings.optimizerswitches) and
{ statements must be error free }
not(nf_error in t2.flags) then
begin
typecheckpass(t2);
res:=t2.simplify(false);
if assigned(res) then
t2:=res;

View File

@ -81,10 +81,7 @@ unit optloop;
function replaceloadnodes(var n: tnode; arg: pointer): foreachnoderesult;
begin
if ((n.nodetype=loadn) and (preplaceinfo(arg)^.node.nodetype=loadn) and
(tloadnode(n).symtableentry=tloadnode(preplaceinfo(arg)^.node).symtableentry)) or
((n.nodetype=temprefn) and (preplaceinfo(arg)^.node.nodetype=temprefn) and
(ttemprefnode(n).tempinfo=ttemprefnode(preplaceinfo(arg)^.node).tempinfo)) then
if n.isequal(preplaceinfo(arg)^.node) then
begin
if n.flags*[nf_modify,nf_write,nf_address_taken]<>[] then
internalerror(2012090402);
@ -135,12 +132,12 @@ unit optloop;
unrollblock:=internalstatements(unrollstatement);
{ can we get rid completly of the for ? }
getridoffor:=(unrolls=counts) and not(usesbreakcontinue);
getridoffor:=(unrolls=counts) and not(usesbreakcontinue) and
{ TP/Macpas allows assignments to the for-variables, so we cannot get rid of the for }
([m_tp7,m_mac]*current_settings.modeswitches=[]);
if getridoffor then
begin
if not(tfornode(node).left.nodetype in [temprefn,loadn]) then
internalerror(2012090301);
replaceinfo.node:=tfornode(node).left;
replaceinfo.value:=tordconstnode(tfornode(node).right).value;
end;