<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN"> <!--Converted with LaTeX2HTML 2008 (1.71) original version by: Nikos Drakos, CBLU, University of Leeds * revised and updated by: Marcus Hennecke, Ross Moore, Herb Swan * with significant contributions from: Jens Lippmann, Marek Rouchal, Martin Wilck and others --> <HTML> <HEAD> <TITLE>8.1.5 Loop Reversing</TITLE> <META NAME="description" CONTENT="8.1.5 Loop Reversing"> <META NAME="keywords" CONTENT="sdccman"> <META NAME="resource-type" CONTENT="document"> <META NAME="distribution" CONTENT="global"> <META NAME="Generator" CONTENT="LaTeX2HTML v2008"> <META HTTP-EQUIV="Content-Style-Type" CONTENT="text/css"> <LINK REL="STYLESHEET" HREF="sdccman.css"> <LINK REL="next" HREF="node175.html"> <LINK REL="previous" HREF="node173.html"> <LINK REL="up" HREF="node169.html"> <LINK REL="next" HREF="node175.html"> </HEAD> <BODY > <!--Navigation Panel--> <A NAME="tex2html3427" HREF="node175.html"> <IMG WIDTH="37" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="next" SRC="next.png"></A> <A NAME="tex2html3421" HREF="node169.html"> <IMG WIDTH="26" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="up" SRC="up.png"></A> <A NAME="tex2html3415" HREF="node173.html"> <IMG WIDTH="63" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="previous" SRC="prev.png"></A> <A NAME="tex2html3423" HREF="node1.html"> <IMG WIDTH="65" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="contents" SRC="contents.png"></A> <A NAME="tex2html3425" HREF="node191.html"> <IMG WIDTH="43" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="index" SRC="index.png"></A> <BR> <B> Next:</B> <A NAME="tex2html3428" HREF="node175.html">8.1.6 Algebraic Simplifications</A> <B> Up:</B> <A NAME="tex2html3422" HREF="node169.html">8.1 Optimizations</A> <B> Previous:</B> <A NAME="tex2html3416" HREF="node173.html">8.1.4 Loop Optimizations</A> <B> <A NAME="tex2html3424" HREF="node1.html">Contents</A></B> <B> <A NAME="tex2html3426" HREF="node191.html">Index</A></B> <BR> <BR> <!--End of Navigation Panel--> <H2><A NAME="SECTION00915000000000000000"></A><A NAME="4072"></A> <BR> 8.1.5 Loop Reversing </H2> <P> This optimization is done to reduce the overhead of checking loop boundaries for every iteration. Some simple loops can be reversed and implemented using a ``decrement and jump if not zero'' instruction. SDCC checks for the following criterion to determine if a loop is reversible (note: more sophisticated compilers use data-dependency analysis to make this determination, SDCC uses a more simple minded analysis). <UL> <LI>The 'for' loop is of the form <BR> <BR><TT>for(<symbol> = <expression>; <sym> [< | <=] <expression>; [<sym>++ | <sym> += 1])</TT> <BR><TT> <for body></TT> </LI> <LI>The <for body> does not contain ``continue'' or 'break''. </LI> <LI>All goto's are contained within the loop. </LI> <LI>No function calls within the loop. </LI> <LI>The loop control variable <sym> is not assigned any value within the loop </LI> <LI>The loop control variable does NOT participate in any arithmetic operation within the loop. </LI> <LI>There are NO switch statements in the loop. </LI> </UL> <P> <BR><HR> <ADDRESS> 2011-03-20 </ADDRESS> </BODY> </HTML>