mirror of
https://github.com/pdf2htmlEX/pdf2htmlEX.git
synced 2024-12-22 04:50:09 +00:00
2 lines
79 KiB
Plaintext
2 lines
79 KiB
Plaintext
<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><<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><<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>entry–then<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>
|