1
0
mirror of https://github.com/pdf2htmlEX/pdf2htmlEX.git synced 2024-12-22 04:50:09 +00:00
pdf2htmlEX/demo/demo2.page
2013-09-28 13:30:57 +08:00

2 lines
79 KiB
Plaintext
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<div class="pd w0 h0"><div id="pf2" class="pf" data-page-no="2"><div class="pc pc2"><img class="bi x32 y18 w1 hb" alt="" src=""/><div class="t m0 x2f h5 y5b ff2 fs3 fc0 sc0 ls0 ws0">Hence,<span class="_ _5"> </span>recording<span class="_ _7"> </span>and<span class="_ _5"> </span>compiling<span class="_ _7"> </span>a<span class="_ _5"> </span>trace<span class="_ _5"> </span><span class="ffa">speculates<span class="_ _7"> </span></span>that<span class="_ _5"> </span>the<span class="_ _7"> </span>path<span class="_ _5"> </span>and</div><div class="t m0 x2f h5 y5c ff2 fs3 fc0 sc0 ls0 ws0">typing<span class="_ _5"> </span>will<span class="_ _5"> </span>be<span class="_ _7"> </span>exactly<span class="_ _5"> </span>as<span class="_ _5"> </span>the<span class="_ _2"></span>y<span class="_ _7"> </span>were<span class="_ _5"> </span>during<span class="_ _5"> </span>recording<span class="_ _5"> </span>for<span class="_ _7"> </span>subsequent</div><div class="t m0 x2f h5 y5d ff2 fs3 fc0 sc0 ls0 ws0">iterations<span class="_ _5"> </span>of<span class="_ _5"> </span>the<span class="_ _3"> </span>loop.</div><div class="t m0 x34 h5 y5e ff2 fs3 fc0 sc0 ls0 ws0">Every<span class="_ _3"> </span>compiled<span class="_ _5"> </span>trace<span class="_ _3"> </span>contains<span class="_ _3"> </span>all<span class="_ _5"> </span>the<span class="_ _3"> </span><span class="ffa">guar<span class="_ _2"></span>ds<span class="_ _3"> </span><span class="ff2">(checks)<span class="_ _5"> </span>required</span></span></div><div class="t m0 x2f h5 y5f ff2 fs3 fc0 sc0 ls0 ws0">to<span class="_ _8"> </span>validate<span class="_ _8"> </span>the<span class="_ _8"> </span>speculation.<span class="_ _8"> </span>If<span class="_ _d"> </span>one<span class="_ _8"> </span>of<span class="_ _8"> </span>the<span class="_ _8"> </span>guards<span class="_ _d"> </span>fails<span class="_ _6"> </span>(if<span class="_ _d"> </span>control</div><div class="t m0 x2f h5 y60 ff2 fs3 fc0 sc0 ls0 ws0">flow<span class="_ _6"> </span>is<span class="_ _6"> </span>different,<span class="_ _6"> </span>or<span class="_ _6"> </span>a<span class="_ _6"> </span>value<span class="_ _6"> </span>of<span class="_ _6"> </span>a<span class="_ _6"> </span>different<span class="_ _6"> </span>type<span class="_ _6"> </span>is<span class="_ _8"> </span>generated),<span class="_ _6"> </span>the</div><div class="t m0 x2f h5 y61 ff2 fs3 fc0 sc0 ls0 ws0">trace<span class="_ _6"> </span>exits.<span class="_ _6"> </span>If<span class="_ _8"> </span>an<span class="_ _6"> </span>exit<span class="_ _6"> </span>becomes<span class="_ _8"> </span>hot,<span class="_ _6"> </span>the<span class="_ _8"> </span>VM<span class="_ _8"> </span>can<span class="_ _6"> </span>record<span class="_ _8"> </span>a<span class="_ _6"> </span><span class="ffa">branch</span></div><div class="t m0 x2f h5 y62 ffa fs3 fc0 sc0 ls0 ws0">trace<span class="_ _5"> </span><span class="ff2">starting<span class="_ _5"> </span>at<span class="_ _5"> </span>the<span class="_ _5"> </span>exit<span class="_ _5"> </span>to<span class="_ _5"> </span>cover<span class="_ _5"> </span>the<span class="_ _5"> </span>ne<span class="_ _2"></span>w<span class="_ _5"> </span>path.<span class="_ _5"> </span>In<span class="_ _5"> </span>this<span class="_ _5"> </span>way<span class="_ _2"></span>,<span class="_ _5"> </span>the<span class="_ _5"> </span>VM</span></div><div class="t m0 x2f h5 y63 ff2 fs3 fc0 sc0 ls0 ws0">records<span class="_ _5"> </span>a<span class="_ _5"> </span><span class="ffa">trace<span class="_ _5"> </span>tree<span class="_ _5"> </span></span>cov<span class="_ _2"></span>ering<span class="_ _5"> </span>all<span class="_ _5"> </span>the<span class="_ _5"> </span>hot<span class="_ _3"> </span>paths<span class="_ _5"> </span>through<span class="_ _5"> </span>the<span class="_ _5"> </span>loop.</div><div class="t m0 x34 h5 y7 ff2 fs3 fc0 sc0 ls0 ws0">Nested<span class="_ _6"> </span>loops<span class="_ _6"> </span>can<span class="_ _6"> </span>be<span class="_ _8"> </span>dif<span class="_ _2"></span>ficult<span class="_ _6"> </span>to<span class="_ _6"> </span>optimize<span class="_ _6"> </span>for<span class="_ _8"> </span>tracing<span class="_ _6"> </span>VMs.<span class="_ _6"> </span>In</div><div class="t m0 x2f h5 y64 ff2 fs3 fc0 sc0 ls0 ws0">a<span class="_ _6"> </span>na</div><div class="t m0 x35 h5 y65 ff2 fs3 fc0 sc0 ls0 ws0">¨</div><div class="t m0 x35 h5 y64 ff2 fs3 fc0 sc0 ls0 ws0">ıve<span class="_ _6"> </span>implementation,<span class="_ _6"> </span>inner<span class="_ _6"> </span>loops<span class="_ _6"> </span>would<span class="_ _6"> </span>become<span class="_ _6"> </span>hot<span class="_ _6"> </span>first,<span class="_ _6"> </span>and</div><div class="t m0 x2f h5 y66 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _6"> </span>VM<span class="_ _6"> </span>would<span class="_ _3"> </span>start<span class="_ _6"> </span>tracing<span class="_ _6"> </span>there.<span class="_ _6"> </span>When<span class="_ _6"> </span>the<span class="_ _3"> </span>inner<span class="_ _6"> </span>loop<span class="_ _6"> </span>exits,<span class="_ _6"> </span>the</div><div class="t m0 x2f h5 y67 ff2 fs3 fc0 sc0 ls0 ws0">VM<span class="_ _5"> </span>would<span class="_ _5"> </span>detect<span class="_ _7"> </span>that<span class="_ _5"> </span>a<span class="_ _5"> </span>dif<span class="_ _2"></span>ferent<span class="_ _5"> </span>branch<span class="_ _5"> </span>w<span class="_ _2"></span>as<span class="_ _5"> </span>tak<span class="_ _2"></span>en.<span class="_ _5"> </span>The<span class="_ _5"> </span>VM<span class="_ _7"> </span>would</div><div class="t m0 x2f h5 y68 ff2 fs3 fc0 sc0 ls0 ws0">try<span class="_ _3"> </span>to<span class="_ _5"> </span>record<span class="_ _3"> </span>a<span class="_ _3"> </span>branch<span class="_ _5"> </span>trace,<span class="_ _3"> </span>and<span class="_ _3"> </span>find<span class="_ _3"> </span>that<span class="_ _5"> </span>the<span class="_ _3"> </span>trace<span class="_ _3"> </span>reaches<span class="_ _5"> </span>not<span class="_ _3"> </span>the</div><div class="t m0 x2f h5 y69 ff2 fs3 fc0 sc0 ls0 ws0">inner<span class="_ _5"> </span>loop<span class="_ _3"> </span>header<span class="_ _2"></span>,<span class="_ _5"> </span>but<span class="_ _5"> </span>the<span class="_ _3"> </span>outer<span class="_ _5"> </span>loop<span class="_ _5"> </span>header<span class="_ _2"></span>.<span class="_ _3"> </span>At<span class="_ _5"> </span>this<span class="_ _5"> </span>point,<span class="_ _3"> </span>the<span class="_ _5"> </span>VM</div><div class="t m0 x2f h5 y6a ff2 fs3 fc0 sc0 ls0 ws0">could<span class="_ _3"> </span>continue<span class="_ _5"> </span>tracing<span class="_ _5"> </span>until<span class="_ _3"> </span>it<span class="_ _5"> </span>reaches<span class="_ _3"> </span>the<span class="_ _5"> </span>inner<span class="_ _3"> </span>loop<span class="_ _5"> </span>header<span class="_ _3"> </span>again,</div><div class="t m0 x2f h5 y6b ff2 fs3 fc0 sc0 ls0 ws0">thus<span class="_ _6"> </span>tracing<span class="_ _8"> </span>the<span class="_ _6"> </span>outer<span class="_ _6"> </span>loop<span class="_ _8"> </span>inside<span class="_ _6"> </span>a<span class="_ _8"> </span>trace<span class="_ _6"> </span>tree<span class="_ _8"> </span>for<span class="_ _6"> </span>the<span class="_ _8"> </span>inner<span class="_ _6"> </span>loop.</div><div class="t m0 x2f h5 y6c ff2 fs3 fc0 sc0 ls0 ws0">But<span class="_ _5"> </span>this<span class="_ _5"> </span>requires<span class="_ _5"> </span>tracing<span class="_ _5"> </span>a<span class="_ _5"> </span>cop<span class="_ _2"></span>y<span class="_ _5"> </span>of<span class="_ _5"> </span>the<span class="_ _5"> </span>outer<span class="_ _5"> </span>loop<span class="_ _5"> </span>for<span class="_ _5"> </span>e<span class="_ _2"></span>v<span class="_ _2"></span>ery<span class="_ _5"> </span>side<span class="_ _5"> </span>exit</div><div class="t m0 x2f h5 y6d ff2 fs3 fc0 sc0 ls0 ws0">and<span class="_ _3"> </span>type<span class="_ _3"> </span>combination<span class="_ _6"> </span>in<span class="_ _3"> </span>the<span class="_ _3"> </span>inner<span class="_ _3"> </span>loop.<span class="_ _3"> </span>In<span class="_ _3"> </span>essence,<span class="_ _6"> </span>this<span class="_ _3"> </span>is<span class="_ _3"> </span>a<span class="_ _3"> </span>form</div><div class="t m0 x2f h5 y6e ff2 fs3 fc0 sc0 ls0 ws0">of<span class="_ _3"> </span>unintended<span class="_ _3"> </span>tail<span class="_ _5"> </span>duplication,<span class="_ _3"> </span>which<span class="_ _3"> </span>can<span class="_ _5"> </span>easily<span class="_ _3"> </span>overflo<span class="_ _2"></span>w<span class="_ _5"> </span>the<span class="_ _3"> </span>code</div><div class="t m0 x2f h5 y6f ff2 fs3 fc0 sc0 ls0 ws0">cache.<span class="_ _5"> </span>Alternati<span class="_ _2"></span>v<span class="_ _2"></span>ely<span class="_ _b"></span>,<span class="_ _5"> </span>the<span class="_ _5"> </span>VM<span class="_ _7"> </span>could<span class="_ _5"> </span>simply<span class="_ _5"> </span>stop<span class="_ _7"> </span>tracing,<span class="_ _5"> </span>and<span class="_ _7"> </span>give<span class="_ _7"> </span>up</div><div class="t m0 x2f h5 y70 ff2 fs3 fc0 sc0 ls0 ws0">on<span class="_ _5"> </span>ev<span class="_ _2"></span>er<span class="_ _5"> </span>tracing<span class="_ _5"> </span>outer<span class="_ _3"> </span>loops.</div><div class="t m0 x34 h5 y71 ff2 fs3 fc0 sc0 ls0 ws0">W<span class="_ _b"></span>e<span class="_ _d"> </span>solv<span class="_ _2"></span>e<span class="_ _8"> </span>the<span class="_ _8"> </span>nested<span class="_ _d"> </span>loop<span class="_ _8"> </span>problem<span class="_ _8"> </span>by<span class="_ _d"> </span>recording<span class="_ _8"> </span><span class="ffa">nested<span class="_ _8"> </span>trace</span></div><div class="t m0 x2f h5 y72 ffa fs3 fc0 sc0 ls0 ws0">tr<span class="_ _2"></span>ees<span class="ff2">.<span class="_ _5"> </span>Our<span class="_ _5"> </span>system<span class="_ _5"> </span>traces<span class="_ _7"> </span>the<span class="_ _5"> </span>inner<span class="_ _5"> </span>loop<span class="_ _5"> </span>exactly<span class="_ _5"> </span>as<span class="_ _5"> </span>the<span class="_ _7"> </span>na</span></div><div class="t m0 x5 h5 y73 ff2 fs3 fc0 sc0 ls0 ws0">¨</div><div class="t m0 x5 h5 y72 ff2 fs3 fc0 sc0 ls0 ws0">ıve<span class="_ _5"> </span>v<span class="_ _2"></span>ersion.</div><div class="t m0 x2f h5 y74 ff2 fs3 fc0 sc0 ls0 ws0">The<span class="_ _5"> </span>system<span class="_ _3"> </span>stops<span class="_ _5"> </span>extending<span class="_ _5"> </span>the<span class="_ _5"> </span>inner<span class="_ _3"> </span>tree<span class="_ _5"> </span>when<span class="_ _5"> </span>it<span class="_ _3"> </span>reaches<span class="_ _5"> </span>an<span class="_ _5"> </span>outer</div><div class="t m0 x2f h5 y75 ff2 fs3 fc0 sc0 ls0 ws0">loop,<span class="_ _3"> </span>but<span class="_ _3"> </span>then<span class="_ _3"> </span>it<span class="_ _3"> </span>starts<span class="_ _3"> </span>a<span class="_ _3"> </span>ne<span class="_ _2"></span>w<span class="_ _3"> </span>trace<span class="_ _3"> </span>at<span class="_ _5"> </span>the<span class="_ _3"> </span>outer<span class="_ _3"> </span>loop<span class="_ _3"> </span>header<span class="_ _2"></span>.<span class="_ _3"> </span>When</div><div class="t m0 x2f h5 y76 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _5"> </span>outer<span class="_ _5"> </span>loop<span class="_ _5"> </span>reaches<span class="_ _7"> </span>the<span class="_ _5"> </span>inner<span class="_ _5"> </span>loop<span class="_ _5"> </span>header<span class="_ _2"></span>,<span class="_ _5"> </span>the<span class="_ _5"> </span>system<span class="_ _7"> </span>tries<span class="_ _5"> </span>to<span class="_ _5"> </span>call</div><div class="t m0 x2f h5 y77 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _5"> </span>trac<span class="_ _2"></span>e<span class="_ _7"> </span>tree<span class="_ _5"> </span>for<span class="_ _7"> </span>the<span class="_ _5"> </span>inner<span class="_ _7"> </span>loop.<span class="_ _5"> </span>If<span class="_ _7"> </span>the<span class="_ _5"> </span>call<span class="_ _7"> </span>succeeds,<span class="_ _5"> </span>the<span class="_ _7"> </span>VM<span class="_ _5"> </span>records</div><div class="t m0 x2f h5 y78 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _d"> </span>call<span class="_ _8"> </span>to<span class="_ _d"> </span>the<span class="_ _d"> </span>inner<span class="_ _d"> </span>tree<span class="_ _8"> </span>as<span class="_ _d"> </span>part<span class="_ _d"> </span>of<span class="_ _d"> </span>the<span class="_ _8"> </span>outer<span class="_ _d"> </span>trace<span class="_ _d"> </span>and<span class="_ _8"> </span>finishes</div><div class="t m0 x2f h5 y79 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _6"> </span>outer<span class="_ _8"> </span>trace<span class="_ _8"> </span>as<span class="_ _8"> </span>normal.<span class="_ _6"> </span>In<span class="_ _8"> </span>this<span class="_ _8"> </span>way<span class="_ _b"></span>,<span class="_ _8"> </span>our<span class="_ _8"> </span>system<span class="_ _8"> </span>can<span class="_ _6"> </span>trace<span class="_ _8"> </span>any</div><div class="t m0 x2f h5 y7a ff2 fs3 fc0 sc0 ls0 ws0">number<span class="_ _5"> </span>of<span class="_ _5"> </span>loops<span class="_ _5"> </span>nested<span class="_ _5"> </span>to<span class="_ _3"> </span>an<span class="_ _2"></span>y<span class="_ _5"> </span>depth<span class="_ _5"> </span>without<span class="_ _5"> </span>causing<span class="_ _5"> </span>excessi<span class="_ _2"></span>ve<span class="_ _5"> </span>tail</div><div class="t m0 x2f h5 y7b ff2 fs3 fc0 sc0 ls0 ws0">duplication.</div><div class="t m0 x34 h5 y7c ff2 fs3 fc0 sc0 ls0 ws0">These<span class="_ _6"> </span>techniques<span class="_ _6"> </span>allow<span class="_ _3"> </span>a<span class="_ _8"> </span>VM<span class="_ _6"> </span>to<span class="_ _6"> </span>dynamically<span class="_ _6"> </span>translate<span class="_ _6"> </span>a<span class="_ _6"> </span>pro-</div><div class="t m0 x2f h5 y7d ff2 fs3 fc0 sc0 ls0 ws0">gram<span class="_ _d"> </span>to<span class="_ _8"> </span>nested,<span class="_ _d"> </span>type-specialized<span class="_ _d"> </span>trace<span class="_ _d"> </span>trees.<span class="_ _8"> </span>Because<span class="_ _d"> </span>traces<span class="_ _d"> </span>can</div><div class="t m0 x2f h5 y7e ff2 fs3 fc0 sc0 ls0 ws0">cross<span class="_ _3"> </span>function<span class="_ _3"> </span>call<span class="_ _5"> </span>boundaries,<span class="_ _3"> </span>our<span class="_ _3"> </span>techniques<span class="_ _3"> </span>also<span class="_ _3"> </span>achie<span class="_ _2"></span>v<span class="_ _2"></span>e<span class="_ _3"> </span>the<span class="_ _3"> </span>ef-</div><div class="t m0 x2f h5 y7f ff2 fs3 fc0 sc0 ls0 ws0">fects<span class="_ _5"> </span>of<span class="_ _7"> </span>inlining.<span class="_ _5"> </span>Because<span class="_ _7"> </span>traces<span class="_ _5"> </span>hav<span class="_ _2"></span>e<span class="_ _5"> </span>no<span class="_ _7"> </span>internal<span class="_ _5"> </span>control-flo<span class="_ _2"></span>w<span class="_ _7"> </span>joins,</div><div class="t m0 x2f h5 y80 ff2 fs3 fc0 sc0 ls0 ws0">they<span class="_ _6"> </span>can<span class="_ _8"> </span>be<span class="_ _8"> </span>optimized<span class="_ _8"> </span>in<span class="_ _8"> </span>linear<span class="_ _6"> </span>time<span class="_ _8"> </span>by<span class="_ _8"> </span>a<span class="_ _8"> </span>simple<span class="_ _8"> </span>compiler<span class="_ _8"> </span>(10).</div><div class="t m0 x2f h5 y81 ff2 fs3 fc0 sc0 ls0 ws0">Thus,<span class="_ _8"> </span>our<span class="_ _6"> </span>tracing<span class="_ _8"> </span>VM<span class="_ _8"> </span>efficiently<span class="_ _6"> </span>performs<span class="_ _8"> </span>the<span class="_ _8"> </span>same<span class="_ _8"> </span>kind<span class="_ _8"> </span>of<span class="_ _8"> </span>op-</div><div class="t m0 x2f h5 y82 ff2 fs3 fc0 sc0 ls0 ws0">timizations<span class="_ _6"> </span>that<span class="_ _3"> </span>would<span class="_ _6"> </span>require<span class="_ _6"> </span>interprocedural<span class="_ _6"> </span>analysis<span class="_ _3"> </span>in<span class="_ _6"> </span>a<span class="_ _6"> </span>static</div><div class="t m0 x2f h5 y83 ff2 fs3 fc0 sc0 ls0 ws0">optimization<span class="_ _5"> </span>setting.<span class="_ _3"> </span>This<span class="_ _5"> </span>makes<span class="_ _5"> </span>tracing<span class="_ _3"> </span>an<span class="_ _5"> </span>attracti<span class="_ _2"></span>ve<span class="_ _5"> </span>and<span class="_ _5"> </span>effecti<span class="_ _2"></span>ve</div><div class="t m0 x2f h5 y84 ff2 fs3 fc0 sc0 ls0 ws0">tool<span class="_ _5"> </span>to<span class="_ _5"> </span>type<span class="_ _3"> </span>specialize<span class="_ _5"> </span>e<span class="_ _2"></span>v<span class="_ _2"></span>en<span class="_ _5"> </span>complex<span class="_ _5"> </span>function<span class="_ _5"> </span>call-rich<span class="_ _5"> </span>code.</div><div class="t m0 x34 h5 y85 ff2 fs3 fc0 sc0 ls0 ws0">W<span class="_ _b"></span>e<span class="_ _5"> </span>implemented<span class="_ _3"> </span>these<span class="_ _5"> </span>techniques<span class="_ _5"> </span>for<span class="_ _5"> </span>an<span class="_ _5"> </span>existing<span class="_ _5"> </span>Ja<span class="_ _2"></span>vaScript<span class="_ _5"> </span>in-</div><div class="t m0 x2f h5 y86 ff2 fs3 fc0 sc0 ls0 ws0">terpreter<span class="_ _2"></span>,<span class="_ _3"> </span>SpiderMonkey<span class="_ _b"></span>.<span class="_ _3"> </span>W<span class="_ _2"></span>e<span class="_ _3"> </span>call<span class="_ _3"> </span>the<span class="_ _3"> </span>resulting<span class="_ _3"> </span>tracing<span class="_ _3"> </span>VM<span class="_ _3"> </span><span class="ffa">T<span class="_ _2"></span>r<span class="_ _2"></span>ace-</span></div><div class="t m0 x2f h5 y87 ffa fs3 fc0 sc0 ls0 ws0">Monke<span class="_ _2"></span>y<span class="ff2">.<span class="_ _3"> </span>T<span class="_ _2"></span>raceMonk<span class="_ _2"></span>ey<span class="_ _3"> </span>supports<span class="_ _5"> </span>all<span class="_ _3"> </span>the<span class="_ _3"> </span>Jav<span class="_ _2"></span>aScript<span class="_ _3"> </span>features<span class="_ _5"> </span>of<span class="_ _3"> </span>Spi-</span></div><div class="t m0 x2f h5 y88 ff2 fs3 fc0 sc0 ls0 ws0">derMonkey<span class="_ _b"></span>,<span class="_ _5"> </span>with<span class="_ _5"> </span>a<span class="_ _3"> </span>2x-20x<span class="_ _5"> </span>speedup<span class="_ _5"> </span>for<span class="_ _5"> </span>traceable<span class="_ _5"> </span>programs.</div><div class="t m0 x34 h5 y89 ff2 fs3 fc0 sc0 ls0 ws0">This<span class="_ _5"> </span>paper<span class="_ _5"> </span>makes<span class="_ _5"> </span>the<span class="_ _3"> </span>follo<span class="_ _2"></span>wing<span class="_ _5"> </span>contrib<span class="_ _2"></span>utions:</div><div class="t m0 x36 h4 y8a ff3 fs2 fc0 sc0 ls0 ws0">•</div><div class="t m0 x37 h5 y8b ff2 fs3 fc0 sc0 ls0 ws0">W<span class="_ _b"></span>e<span class="_ _5"> </span>explain<span class="_ _5"> </span>an<span class="_ _5"> </span>algorithm<span class="_ _5"> </span>for<span class="_ _3"> </span>dynam<span class="_ _2"></span>ically<span class="_ _5"> </span>forming<span class="_ _5"> </span>trace<span class="_ _5"> </span>trees<span class="_ _5"> </span>to</div><div class="t m0 x37 h5 y8c ff2 fs3 fc0 sc0 ls0 ws0">cov<span class="_ _2"></span>er<span class="_ _5"> </span>a<span class="_ _7"> </span>program,<span class="_ _5"> </span>representing<span class="_ _7"> </span>nested<span class="_ _7"> </span>loops<span class="_ _5"> </span>as<span class="_ _7"> </span>nested<span class="_ _5"> </span>trace<span class="_ _7"> </span>trees.</div><div class="t m0 x36 h4 y8d ff3 fs2 fc0 sc0 ls0 ws0">•</div><div class="t m0 x37 h5 y8e ff2 fs3 fc0 sc0 ls0 ws0">W<span class="_ _b"></span>e<span class="_ _5"> </span>e<span class="_ _2"></span>xplain<span class="_ _7"> </span>how<span class="_ _7"> </span>to<span class="_ _7"> </span>speculatively<span class="_ _7"> </span>generate<span class="_ _7"> </span>efficient<span class="_ _7"> </span>type-specialized</div><div class="t m0 x37 h5 y8f ff2 fs3 fc0 sc0 ls0 ws0">code<span class="_ _5"> </span>for<span class="_ _5"> </span>traces<span class="_ _3"> </span>from<span class="_ _5"> </span>dynamic<span class="_ _5"> </span>language<span class="_ _5"> </span>programs.</div><div class="t m0 x36 h4 y90 ff3 fs2 fc0 sc0 ls0 ws0">•</div><div class="t m0 x37 h5 y91 ff2 fs3 fc0 sc0 ls0 ws0">W<span class="_ _b"></span>e<span class="_ _3"> </span>v<span class="_ _2"></span>alidate<span class="_ _5"> </span>our<span class="_ _3"> </span>tracing<span class="_ _5"> </span>techniques<span class="_ _5"> </span>in<span class="_ _3"> </span>an<span class="_ _5"> </span>implementation<span class="_ _5"> </span>based</div><div class="t m0 x37 h5 y92 ff2 fs3 fc0 sc0 ls0 ws0">on<span class="_ _3"> </span>the<span class="_ _3"> </span>SpiderMonkey<span class="_ _3"> </span>Jav<span class="_ _2"></span>aScript<span class="_ _3"> </span>interpreter<span class="_ _2"></span>,<span class="_ _3"> </span>achie<span class="_ _2"></span>ving<span class="_ _3"> </span>2x-20x</div><div class="t m0 x37 h5 y93 ff2 fs3 fc0 sc0 ls0 ws0">speedups<span class="_ _5"> </span>on<span class="_ _5"> </span>many<span class="_ _5"> </span>programs.</div><div class="t m0 x34 h5 y94 ff2 fs3 fc0 sc0 ls0 ws0">The<span class="_ _5"> </span>remainder<span class="_ _5"> </span>of<span class="_ _7"> </span>this<span class="_ _5"> </span>paper<span class="_ _5"> </span>is<span class="_ _7"> </span>organized<span class="_ _5"> </span>as<span class="_ _5"> </span>follo<span class="_ _2"></span>ws.<span class="_ _7"> </span>Section<span class="_ _5"> </span>3<span class="_ _5"> </span>is</div><div class="t m0 x2f h5 y95 ff2 fs3 fc0 sc0 ls0 ws0">a<span class="_ _3"> </span>general<span class="_ _3"> </span>o<span class="_ _2"></span>vervie<span class="_ _2"></span>w<span class="_ _3"> </span>of<span class="_ _3"> </span>trace<span class="_ _3"> </span>t<span class="_ _2"></span>ree<span class="_ _3"> </span>based<span class="_ _3"> </span>compilation<span class="_ _3"> </span>we<span class="_ _3"> </span>use<span class="_ _3"> </span>to<span class="_ _5"> </span>cap-</div><div class="t m0 x2f h5 y96 ff2 fs3 fc0 sc0 ls0 ws0">ture<span class="_ _6"> </span>and<span class="_ _8"> </span>compile<span class="_ _8"> </span>frequently<span class="_ _8"> </span>ex<span class="_ _2"></span>ecuted<span class="_ _6"> </span>code<span class="_ _8"> </span>regions.<span class="_ _8"> </span>In<span class="_ _6"> </span>Section<span class="_ _8"> </span>4</div><div class="t m0 x2f h5 y97 ff2 fs3 fc0 sc0 ls0 ws0">we<span class="_ _6"> </span>describe<span class="_ _3"> </span>our<span class="_ _6"> </span>approach<span class="_ _6"> </span>of<span class="_ _6"> </span>cov<span class="_ _2"></span>ering<span class="_ _6"> </span>nested<span class="_ _3"> </span>loops<span class="_ _6"> </span>using<span class="_ _6"> </span>a<span class="_ _6"> </span>num-</div><div class="t m0 x2f h5 y98 ff2 fs3 fc0 sc0 ls0 ws0">ber<span class="_ _6"> </span>of<span class="_ _6"> </span>individual<span class="_ _6"> </span>trace<span class="_ _6"> </span>trees.<span class="_ _6"> </span>In<span class="_ _8"> </span>Section<span class="_ _6"> </span>5<span class="_ _6"> </span>we<span class="_ _8"> </span>describe<span class="_ _6"> </span>our<span class="_ _6"> </span>trace-</div><div class="t m0 x2f h5 y99 ff2 fs3 fc0 sc0 ls0 ws0">compilation<span class="_ _5"> </span>based<span class="_ _5"> </span>speculative<span class="_ _5"> </span>type<span class="_ _5"> </span>specialization<span class="_ _5"> </span>approach<span class="_ _3"> </span>we<span class="_ _5"> </span>use</div><div class="t m0 x2f h5 y9a ff2 fs3 fc0 sc0 ls0 ws0">to<span class="_ _3"> </span>generate<span class="_ _3"> </span>ef<span class="_ _2"></span>ficient<span class="_ _3"> </span>machine<span class="_ _5"> </span>code<span class="_ _3"> </span>from<span class="_ _3"> </span>recorded<span class="_ _3"> </span>bytecode<span class="_ _3"> </span>traces.</div><div class="t m0 x2f h5 y9b ff2 fs3 fc0 sc0 ls0 ws0">Our<span class="_ _6"> </span>implementation<span class="_ _6"> </span>of<span class="_ _8"> </span>a<span class="_ _6"> </span>dynamic<span class="_ _6"> </span>type-specializing<span class="_ _8"> </span>compiler<span class="_ _6"> </span>for</div><div class="t m0 x2f h5 y9c ff2 fs3 fc0 sc0 ls0 ws0">Jav<span class="_ _2"></span>aScript<span class="_ _3"> </span>is<span class="_ _3"> </span>described<span class="_ _3"> </span>in<span class="_ _3"> </span>Section<span class="_ _3"> </span>6.<span class="_ _6"> </span>Related<span class="_ _3"> </span>work<span class="_ _3"> </span>is<span class="_ _3"> </span>discussed<span class="_ _3"> </span>in</div><div class="t m0 x2f h5 y9d ff2 fs3 fc0 sc0 ls0 ws0">Section<span class="_ _5"> </span>8.<span class="_ _5"> </span>In<span class="_ _5"> </span>Section<span class="_ _5"> </span>7<span class="_ _7"> </span>we<span class="_ _5"> </span>ev<span class="_ _2"></span>aluate<span class="_ _5"> </span>our<span class="_ _5"> </span>dynamic<span class="_ _5"> </span>compiler<span class="_ _7"> </span>based<span class="_ _5"> </span>on</div><div class="t m0 x32 hc y9e ff7 fs3 fc0 sc0 ls0 ws0">1<span class="_ _1"> </span>for<span class="_ _e"> </span>(var<span class="_ _1"> </span>i<span class="_ _e"> </span>=<span class="_ _1"> </span>2;<span class="_ _e"> </span>i<span class="_ _1"> </span>&lt;<span class="_ _e"> </span>100;<span class="_ _1"> </span>++i)<span class="_ _e"> </span>{</div><div class="t m0 x32 hc y9f ff7 fs3 fc0 sc0 ls0 ws0">2<span class="_ _f"> </span>if<span class="_ _1"> </span>(!primes[i])</div><div class="t m0 x32 hc ya0 ff7 fs3 fc0 sc0 ls0 ws0">3<span class="_ _10"> </span>continue;</div><div class="t m0 x32 hc ya1 ff7 fs3 fc0 sc0 ls0 ws0">4<span class="_ _f"> </span>for<span class="_ _1"> </span>(var<span class="_ _e"> </span>k<span class="_ _1"> </span>=<span class="_ _e"> </span>i<span class="_ _1"> </span>+<span class="_ _e"> </span>i;<span class="_ _1"> </span>i<span class="_ _e"> </span>&lt;<span class="_ _1"> </span>100;<span class="_ _e"> </span>k<span class="_ _1"> </span>+=<span class="_ _e"> </span>i)</div><div class="t m0 x32 hc ya2 ff7 fs3 fc0 sc0 ls0 ws0">5<span class="_ _10"> </span>primes[k]<span class="_ _1"> </span>=<span class="_ _e"> </span>false;</div><div class="t m0 x32 hc ya3 ff7 fs3 fc0 sc0 ls0 ws0">6<span class="_ _1"> </span>}</div><div class="t m0 x32 h5 y62 ff1 fs3 fc0 sc0 ls0 ws0">Figure<span class="_ _8"> </span>1.<span class="_ _1"> </span>Sample<span class="_ _8"> </span>program:<span class="_ _8"> </span>sieve<span class="_ _8"> </span>of<span class="_ _d"> </span>Eratosthenes.<span class="_ _8"> </span><span class="ff7">primes<span class="_ _d"> </span><span class="ff2">is</span></span></div><div class="t m0 x32 h5 y4 ff2 fs3 fc0 sc0 ls0 ws0">initialized<span class="_ _6"> </span>to<span class="_ _6"> </span>an<span class="_ _6"> </span>array<span class="_ _6"> </span>of<span class="_ _6"> </span>100<span class="_ _6"> </span><span class="ff7">false<span class="_ _6"> </span></span>values<span class="_ _3"> </span>on<span class="_ _6"> </span>entry<span class="_ _6"> </span>to<span class="_ _6"> </span>this<span class="_ _6"> </span>code</div><div class="t m0 x32 h5 ya4 ff2 fs3 fc0 sc0 ls0 ws0">snippet.</div><div class="c x32 ya5 w2 hd"><div class="t m0 x38 he y2d ffd fs6 fc0 sc0 ls0 ws0">Interpret<span class="ffe"> </span></div><div class="t m0 x30 he ya6 ffe fs6 fc0 sc0 ls0 ws0">Bytecodes</div><div class="t m0 x39 he ya7 ffd fs6 fc0 sc0 ls0 ws0">Monitor<span class="ffe"> </span></div><div class="t m0 x3a he y57 ffd fs6 fc0 sc0 ls0 ws0">Record</div><div class="t m0 x3b he ya8 ffe fs6 fc0 sc0 ls0 ws0">LIR T<span class="_ _2"></span>race</div><div class="t m0 x3c he ya9 ffd fs6 fc0 sc0 ls0 ws0">Execute<span class="ffe"> </span></div><div class="t m0 x3d he yaa ffe fs6 fc0 sc0 ls0 ws0">Compiled T<span class="_ _2"></span>race</div><div class="t m0 x3e he y57 ffd fs6 fc0 sc0 ls0 ws0">Enter<span class="ffe"> </span></div><div class="t m0 x3d he ya8 ffe fs6 fc0 sc0 ls0 ws0">Compiled T<span class="_ _2"></span>race</div><div class="t m0 x3f he ya9 ffd fs6 fc0 sc0 ls0 ws0">Compile</div><div class="t m0 x3b he yaa ffe fs6 fc0 sc0 ls0 ws0">LIR T<span class="_ _2"></span>race</div><div class="t m0 x3e he yab ffd fs6 fc0 sc0 ls0 ws0">Leave<span class="ffe"> </span></div><div class="t m0 x3d he yac ffe fs6 fc0 sc0 ls0 ws0">Compiled T<span class="_ _2"></span>race</div><div class="t m0 x30 he yad ffe fs6 fc0 sc0 ls0 ws0">loop </div><div class="t m0 x31 he yae ffe fs6 fc0 sc0 ls0 ws0">edge</div><div class="t m0 x37 he yaf ffe fs6 fc0 sc0 ls0 ws0">hot</div><div class="t m0 x40 he y31 ffe fs6 fc0 sc0 ls0 ws0">loop/exit</div><div class="t m0 x3b he yb0 ffe fs6 fc0 sc0 ls0 ws0">abort </div><div class="t m0 x41 he yb1 ffe fs6 fc0 sc0 ls0 ws0">recording</div><div class="t m0 x42 he yb2 ffe fs6 fc0 sc0 ls0 ws0">finish at </div><div class="t m0 x43 he yb3 ffe fs6 fc0 sc0 ls0 ws0">loop header</div><div class="t m0 x44 he yb4 ffe fs6 fc0 sc0 ls0 ws0">cold/blacklisted</div><div class="t m0 x45 he yb5 ffe fs6 fc0 sc0 ls0 ws0">loop/exit</div><div class="t m0 x46 he ya7 ffe fs6 fc0 sc0 ls0 ws0">compiled trace </div><div class="t m0 x47 he y56 ffe fs6 fc0 sc0 ls0 ws0">ready</div><div class="t m0 x48 he y33 ffe fs6 fc0 sc0 ls0 ws0">loop edge with </div><div class="t m0 x49 he yb6 ffe fs6 fc0 sc0 ls0 ws0">same types</div><div class="t m0 x4a he yb7 ffe fs6 fc0 sc0 ls0 ws0">side exit to </div><div class="t m0 x4b he yb8 ffe fs6 fc0 sc0 ls0 ws0">existing trace</div><div class="t m0 x49 he yb9 ffe fs6 fc0 sc0 ls0 ws0">side exit,</div><div class="t m0 x4c he yba ffe fs6 fc0 sc0 ls0 ws0">no existing trace</div><div class="t m0 x4d he ybb ffe fs6 fc0 sc0 ls0 ws0">Overhead </div><div class="t m0 x4e he ybc ffe fs6 fc0 sc0 ls0 ws0">Interpreting</div><div class="t m0 x4f he ybd ffe fs6 fc0 sc0 ls0 ws0">Native</div></div><div class="c x50 ybe w3 hf"><div class="t m0 x51 he ybf ffd fs6 fc0 sc0 ls0 ws0">Symbol Key</div></div><div class="t m0 x32 h5 yc0 ff1 fs3 fc0 sc0 ls0 ws0">Figure<span class="_ _3"> </span>2.<span class="_ _1"> </span><span class="ff2">State<span class="_ _3"> </span>machine<span class="_ _3"> </span>describing<span class="_ _3"> </span>the<span class="_ _3"> </span>major<span class="_ _3"> </span>activities<span class="_ _3"> </span>of<span class="_ _3"> </span>Trace-</span></div><div class="t m0 x32 h5 yc1 ff2 fs3 fc0 sc0 ls0 ws0">Monkey<span class="_ _3"> </span>and<span class="_ _6"> </span>the<span class="_ _6"> </span>conditions<span class="_ _6"> </span>that<span class="_ _6"> </span>cause<span class="_ _6"> </span>transitions<span class="_ _6"> </span>to<span class="_ _6"> </span>a<span class="_ _6"> </span>new<span class="_ _6"> </span>acti<span class="_ _2"></span>v-</div><div class="t m0 x32 h5 yc2 ff2 fs3 fc0 sc0 ls0 ws0">ity<span class="_ _2"></span>.<span class="_ _6"> </span>In<span class="_ _8"> </span>the<span class="_ _d"> </span>dark<span class="_ _8"> </span>box,<span class="_ _8"> </span>TM<span class="_ _8"> </span>executes<span class="_ _8"> </span>JS<span class="_ _8"> </span>as<span class="_ _8"> </span>compiled<span class="_ _d"> </span>traces.<span class="_ _8"> </span>In<span class="_ _8"> </span>the</div><div class="t m0 x32 h5 yc3 ff2 fs3 fc0 sc0 ls0 ws0">light<span class="_ _5"> </span>gray<span class="_ _5"> </span>boxes,<span class="_ _5"> </span>TM<span class="_ _5"> </span>ex<span class="_ _2"></span>ecutes<span class="_ _5"> </span>JS<span class="_ _5"> </span>in<span class="_ _5"> </span>the<span class="_ _5"> </span>standard<span class="_ _5"> </span>interpreter<span class="_ _2"></span>.<span class="_ _5"> </span>White</div><div class="t m0 x32 h5 yc4 ff2 fs3 fc0 sc0 ls0 ws0">boxes<span class="_ _3"> </span>are<span class="_ _6"> </span>overhead.<span class="_ _6"> </span>Thus,<span class="_ _6"> </span>to<span class="_ _3"> </span>maximize<span class="_ _6"> </span>performance,<span class="_ _6"> </span>we<span class="_ _6"> </span>need<span class="_ _6"> </span>to</div><div class="t m0 x32 h5 yc5 ff2 fs3 fc0 sc0 ls0 ws0">maximize<span class="_ _5"> </span>time<span class="_ _5"> </span>spent<span class="_ _5"> </span>in<span class="_ _5"> </span>the<span class="_ _5"> </span>dark<span class="_ _2"></span>est<span class="_ _5"> </span>box<span class="_ _5"> </span>and<span class="_ _5"> </span>minimize<span class="_ _5"> </span>time<span class="_ _7"> </span>spent<span class="_ _5"> </span>in</div><div class="t m0 x32 h5 yc6 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _5"> </span>white<span class="_ _5"> </span>boxes.<span class="_ _5"> </span>The<span class="_ _5"> </span>best<span class="_ _5"> </span>case<span class="_ _5"> </span>is<span class="_ _5"> </span>a<span class="_ _5"> </span>loop<span class="_ _5"> </span>where<span class="_ _5"> </span>the<span class="_ _5"> </span>types<span class="_ _5"> </span>at<span class="_ _5"> </span>the<span class="_ _5"> </span>loop</div><div class="t m0 x32 h5 yc7 ff2 fs3 fc0 sc0 ls0 ws0">edge<span class="_ _5"> </span>are<span class="_ _5"> </span>the<span class="_ _5"> </span>same<span class="_ _5"> </span>as<span class="_ _5"> </span>the<span class="_ _5"> </span>types<span class="_ _5"> </span>on<span class="_ _5"> </span>entrythen<span class="_ _5"> </span>TM<span class="_ _3"> </span>can<span class="_ _5"> </span>stay<span class="_ _5"> </span>in<span class="_ _5"> </span>nati<span class="_ _2"></span>v<span class="_ _2"></span>e</div><div class="t m0 x32 h5 yc8 ff2 fs3 fc0 sc0 ls0 ws0">code<span class="_ _5"> </span>until<span class="_ _5"> </span>the<span class="_ _3"> </span>loop<span class="_ _5"> </span>is<span class="_ _5"> </span>done.</div><div class="t m0 x32 h5 yc9 ff2 fs3 fc0 sc0 ls0 ws0">a<span class="_ _3"> </span>set<span class="_ _3"> </span>of<span class="_ _3"> </span>industry<span class="_ _3"> </span>benchmarks.<span class="_ _3"> </span>The<span class="_ _3"> </span>paper<span class="_ _3"> </span>ends<span class="_ _3"> </span>with<span class="_ _3"> </span>conclusions<span class="_ _3"> </span>in</div><div class="t m0 x32 h5 yca ff2 fs3 fc0 sc0 ls0 ws0">Section<span class="_ _5"> </span>9<span class="_ _5"> </span>and<span class="_ _5"> </span>an<span class="_ _5"> </span>outlook<span class="_ _7"> </span>on<span class="_ _5"> </span>future<span class="_ _5"> </span>work<span class="_ _5"> </span>is<span class="_ _5"> </span>presented<span class="_ _5"> </span>in<span class="_ _7"> </span>Section<span class="_ _5"> </span>10.</div><div class="t m0 x32 h9 ycb ff1 fs1 fc0 sc0 ls0 ws0">2.<span class="_ _a"> </span>Overview:<span class="_ _3"> </span>Example<span class="_ _3"> </span>T<span class="_ _b"></span>racing<span class="_ _3"> </span>Run</div><div class="t m0 x32 h5 ycc ff2 fs3 fc0 sc0 ls0 ws0">This<span class="_ _d"> </span>section<span class="_ _d"> </span>provides<span class="_ _8"> </span>an<span class="_ _d"> </span>overvie<span class="_ _2"></span>w<span class="_ _d"> </span>of<span class="_ _d"> </span>our<span class="_ _d"> </span>system<span class="_ _d"> </span>by<span class="_ _d"> </span>describing</div><div class="t m0 x32 h5 ycd ff2 fs3 fc0 sc0 ls0 ws0">how<span class="_ _d"> </span>T<span class="_ _2"></span>raceMonk<span class="_ _2"></span>ey<span class="_ _d"> </span>ex<span class="_ _2"></span>ecutes<span class="_ _d"> </span>an<span class="_ _d"> </span>example<span class="_ _d"> </span>program.<span class="_ _d"> </span>The<span class="_ _1"> </span>e<span class="_ _2"></span>xample</div><div class="t m0 x32 h5 yce ff2 fs3 fc0 sc0 ls0 ws0">program,<span class="_ _5"> </span>shown<span class="_ _5"> </span>in<span class="_ _5"> </span>Figure<span class="_ _5"> </span>1,<span class="_ _5"> </span>computes<span class="_ _5"> </span>the<span class="_ _5"> </span>first<span class="_ _5"> </span>100<span class="_ _5"> </span>prime<span class="_ _5"> </span>numbers</div><div class="t m0 x32 h5 ycf ff2 fs3 fc0 sc0 ls0 ws0">with<span class="_ _5"> </span>nested<span class="_ _7"> </span>loops.<span class="_ _7"> </span>The<span class="_ _5"> </span>narra<span class="_ _2"></span>ti<span class="_ _2"></span>ve<span class="_ _7"> </span>should<span class="_ _5"> </span>be<span class="_ _7"> </span>read<span class="_ _7"> </span>along<span class="_ _5"> </span>with<span class="_ _7"> </span>Figure<span class="_ _5"> </span>2,</div><div class="t m0 x32 h5 yd0 ff2 fs3 fc0 sc0 ls0 ws0">which<span class="_ _3"> </span>describes<span class="_ _3"> </span>the<span class="_ _3"> </span>acti<span class="_ _2"></span>vities<span class="_ _3"> </span>T<span class="_ _2"></span>raceMonk<span class="_ _2"></span>e<span class="_ _2"></span>y<span class="_ _3"> </span>performs<span class="_ _3"> </span>and<span class="_ _3"> </span>when<span class="_ _5"> </span>it</div><div class="t m0 x32 h5 yd1 ff2 fs3 fc0 sc0 ls0 ws0">transitions<span class="_ _5"> </span>between<span class="_ _5"> </span>the<span class="_ _3"> </span>loops.</div><div class="t m0 x33 h5 yd2 ff2 fs3 fc0 sc0 ls0 ws0">T<span class="_ _2"></span>raceMonke<span class="_ _2"></span>y<span class="_ _6"> </span>alw<span class="_ _2"></span>ays<span class="_ _3"> </span>begins<span class="_ _6"> </span>ex<span class="_ _2"></span>ecuting<span class="_ _3"> </span>a<span class="_ _6"> </span>program<span class="_ _6"> </span>in<span class="_ _3"> </span>the<span class="_ _6"> </span>byte-</div><div class="t m0 x32 h5 yd3 ff2 fs3 fc0 sc0 ls0 ws0">code<span class="_ _6"> </span>interpreter<span class="_ _2"></span>.<span class="_ _6"> </span>Every<span class="_ _6"> </span>loop<span class="_ _6"> </span>back<span class="_ _6"> </span>edge<span class="_ _6"> </span>is<span class="_ _8"> </span>a<span class="_ _6"> </span>potential<span class="_ _6"> </span>trace<span class="_ _6"> </span>point.</div><div class="t m0 x32 h5 y94 ff2 fs3 fc0 sc0 ls0 ws0">When<span class="_ _8"> </span>the<span class="_ _6"> </span>interpreter<span class="_ _8"> </span>crosses<span class="_ _8"> </span>a<span class="_ _8"> </span>loop<span class="_ _8"> </span>edge,<span class="_ _6"> </span>TraceMonke<span class="_ _2"></span>y<span class="_ _6"> </span>inv<span class="_ _2"></span>okes</div><div class="t m0 x32 h5 y95 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _3"> </span><span class="ffa">tr<span class="_ _2"></span>ace<span class="_ _3"> </span>monitor<span class="ff2">,<span class="_ _3"> </span>which<span class="_ _5"> </span>may<span class="_ _3"> </span>decide<span class="_ _3"> </span>to<span class="_ _5"> </span>record<span class="_ _3"> </span>or<span class="_ _3"> </span>ex<span class="_ _2"></span>ecute<span class="_ _3"> </span>a<span class="_ _5"> </span>native</span></span></div><div class="t m0 x32 h5 y96 ff2 fs3 fc0 sc0 ls0 ws0">trace.<span class="_ _5"> </span>At<span class="_ _5"> </span>the<span class="_ _5"> </span>start<span class="_ _5"> </span>of<span class="_ _3"> </span>e<span class="_ _2"></span>x<span class="_ _2"></span>ecution,<span class="_ _5"> </span>there<span class="_ _5"> </span>are<span class="_ _5"> </span>no<span class="_ _5"> </span>compiled<span class="_ _5"> </span>traces<span class="_ _3"> </span>yet,<span class="_ _5"> </span>so</div><div class="t m0 x32 h5 y97 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _5"> </span>trace<span class="_ _7"> </span>monitor<span class="_ _7"> </span>counts<span class="_ _5"> </span>the<span class="_ _7"> </span>number<span class="_ _5"> </span>of<span class="_ _7"> </span>times<span class="_ _5"> </span>each<span class="_ _7"> </span>loop<span class="_ _7"> </span>back<span class="_ _5"> </span>edge<span class="_ _7"> </span>is</div><div class="t m0 x32 h5 y98 ff2 fs3 fc0 sc0 ls0 ws0">ex<span class="_ _2"></span>ecuted<span class="_ _5"> </span>until<span class="_ _5"> </span>a<span class="_ _7"> </span>loop<span class="_ _5"> </span>becomes<span class="_ _5"> </span><span class="ffa">hot</span>,<span class="_ _7"> </span>currently<span class="_ _5"> </span>after<span class="_ _5"> </span>2<span class="_ _5"> </span>crossings.<span class="_ _7"> </span>Note</div><div class="t m0 x32 h5 y99 ff2 fs3 fc0 sc0 ls0 ws0">that<span class="_ _5"> </span>the<span class="_ _7"> </span>way<span class="_ _5"> </span>our<span class="_ _7"> </span>loops<span class="_ _5"> </span>are<span class="_ _7"> </span>compiled,<span class="_ _5"> </span>the<span class="_ _7"> </span>loop<span class="_ _5"> </span>edge<span class="_ _7"> </span>is<span class="_ _5"> </span>crossed<span class="_ _5"> </span>before</div><div class="t m0 x32 h5 y9a ff2 fs3 fc0 sc0 ls0 ws0">entering<span class="_ _3"> </span>the<span class="_ _5"> </span>loop,<span class="_ _3"> </span>so<span class="_ _5"> </span>the<span class="_ _3"> </span>second<span class="_ _5"> </span>crossing<span class="_ _3"> </span>occurs<span class="_ _5"> </span>immediately<span class="_ _3"> </span>after</div><div class="t m0 x32 h5 y9b ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _5"> </span>first<span class="_ _5"> </span>iteration.</div><div class="t m0 x33 h5 y9c ff2 fs3 fc0 sc0 ls0 ws0">Here<span class="_ _1"> </span>is<span class="_ _d"> </span>the<span class="_ _1"> </span>sequence<span class="_ _d"> </span>of<span class="_ _1"> </span>e<span class="_ _2"></span>v<span class="_ _2"></span>ents<span class="_ _d"> </span>broken<span class="_ _1"> </span>do<span class="_ _2"></span>wn<span class="_ _d"> </span>by<span class="_ _1"> </span>outer<span class="_ _d"> </span>loop</div><div class="t m0 x32 h5 y9d ff2 fs3 fc0 sc0 ls0 ws0">iteration:</div></div><div class="pi" data-data='{"ctm":[1.673203,0.000000,0.000000,1.673203,0.000000,0.000000]}'></div></div></div>