





















|                             | Can these rules execute concurrently 2       |
|-----------------------------|----------------------------------------------|
| rule dofetCn ;              |                                              |
| let ppgE-poytada            |                                              |
| fild apg(FatghiDag          | (peru), peru)<=pper,                         |
| 120.eng(fetChzbec           | <pre>inst:instF});</pre>                     |
| endrule<br>rule doExecute;  | two values for epoch are sufficient          |
| <pre>let x=f2d.first;</pre> | <pre>let pcD=x.pc; let inEp=x.epoch;</pre>   |
| <b>let</b> ppcD = x.ppc     | <pre>; let instD = x.inst;</pre>             |
| <pre>if(inEp == epoch</pre> | ) begin                                      |
| <b>let</b> dInst = de       | <pre>code(instD); register fetch;</pre>      |
| <b>let</b> eInst = ex       | ec(dInst, rVal1, rVal2, pcD, ppcD);          |
| memory oper                 |                                              |
| ri update .                 | to digt )                                    |
| II (einst.misp              | The the delay is a set (and the set ) is and |
| pc[1] <= e                  | and and epoch <= next(epoch); end            |
| f2d deg: endrule            | enno                                         |
| - 12 2015                   | http://csg.csail.mit.edu/6.175               |









| Two-sta                                                                                                | ge pipeline                                                                                              |
|--------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| Decouple                                                                                               | ed code structure                                                                                        |
| module mkProc(Proc<br>Fifo#(Fetch2Exect<br>Fifo#(Addr) redi:<br>Reg#(Bool) fEpocl<br>Reg#(Bool) eEpocl | );<br>lte) f2d <- mkFifo;<br>rect <- mkFifo;<br>l <- mkReg(False);<br>h <- mkReg(False);                 |
| <pre>rule doFetch;<br/>let instF = iMe<br/></pre>                                                      | em.req(pc);                                                                                              |
| f2d.enq( in;<br>endrule<br>rule doExecute;                                                             | stF, fEpoch);                                                                                            |
| if(inEp == eEp<br>Decode and ex<br>In case of misp                                                     | och) <b>begin</b><br>ecute the instruction; update state;<br>rediction, redirect.eng(correct pc);<br>end |
| f2d.deq;<br>endrule<br>endmodule                                                                       |                                                                                                          |
| endmodule<br>October 13, 2015                                                                          | http://csg.csail.mit.edu/6.175 L12-1                                                                     |









