



word f\_pc = I  
 M\_icode == JXX && M\_Cnd : M\_valA ;  
 W\_icode == JRET : W\_valM ;  
 I: F\_predPC ;  
 J:  
 word f\_predPC = I  
 f.icode in {IJXX, ICALL} : f\_valC ;  
 I: f\_valP ;  
 J:  
 word f\_start = I  
 dmem\_error: SADR ;  
 !instr\_valid: SINS ;  
 f.icode == JHALT: SHLT ;  
 I: SAOK ;  
 J:  
  
 word d\_dstE = I  
 D\_icode in {IRMMOVW, IRMMOVW, IPOP} : D\_valB ;  
 D\_icode in {ICALL, JRET, IPUSHQ, JPOPQ} : RRSP ;  
 I: RNONE ;  
 J:  
 word d\_valA = I  
 D\_icode in {ICALL, IJXX} : D\_valP ;  
 D\_srcA == e\_dstE : e\_valE ;  
 D\_srcA == M\_dstM : m\_valM ;  
 D\_srcA == M\_dstE : M\_valE ;  
 D\_srcA == W\_dstM : W\_valM ;  
 D\_srcA == W\_dstE : W\_valE ;  
 I: d\_rvalA ;  
 J:  
 word d\_valB = I  
 d\_srcB == e\_dstE : e\_valE ;  
 d\_srcB == M\_dstM : m\_valM ;  
 d\_srcB == M\_dstE : M\_valE ;  
 d\_srcB == W\_dstM : W\_valM ;  
 d\_srcB == W\_dstE : W\_valE ;  
 I: d\_rvalB ;  
 J:  
 word e\_dstE = I  
 E\_icode == IRMMOVW && !E\_Cnd : RNONE ;  
 I: E\_dstE ;  
 J:  
  
 bool F\_stall =  
 JRET in {D\_icode, E\_icode, M\_icode} || ret  
 (E\_icode in {JMRMOVW, JPOPQ} &&  
 E\_dstM in {d\_srcA, d\_srcB}) ; load-use  
 bool D\_stall = E\_icode in {JMRMOVW, JPOPQ} &&  
 E\_dstM in {d\_srcA, d\_srcB} ;  
 bool D\_bubble = (JRET in {D\_icode, E\_icode, M\_icode}  
 && !(E\_icode in {JMRMOVW, JPOPQ}) &&  
 wrong pred E\_dstM in {d\_srcA, d\_srcB}) ||  
 (E\_icode == IJXX && !E\_Cnd) ; not-use  
 bool E\_bubble = (E\_icode in {JMRMOVW, JPOPQ} &&  
 E\_dstM in {d\_srcA, d\_srcB}) || ret  
 wrong pred (E\_icode == IJXX && E\_Cnd)  
 bool set\_cc = M\_stall == SAOK && W\_stall == SAOK &&  
 E\_icode == IOPA ; exception not occurred  
 word m\_stat = I  
 dmém\_error: SADR ;  
 I: M\_stat ;  
 J:  
 word M\_bubble = W\_stall in {SADR, SINS, SHLT} || except.  
 m\_stat in {SADR, SINS, SHLT} ; occurred  
 word W\_stall = W\_stall in {SADR, SINS, SHLT} ; occurred

也可以是normal，但是stall更好

|                                           |                     | Pipeline register |        |        |        |        |
|-------------------------------------------|---------------------|-------------------|--------|--------|--------|--------|
| Condition                                 |                     | F                 | D      | E      | M      | W      |
| ret在Decode发现use指令在Decode时发现jXX在Execute时发现 | Processing ret      | stall             | bubble | normal | normal | normal |
|                                           | Load/use hazard     | stall             | stall  | bubble | normal | normal |
|                                           | Mispredicted branch | normal            | bubble | bubble | normal | normal |

也可以是stall



### Pipeline register

| Condition           | F      | D            | E                 | M      | W      |
|---------------------|--------|--------------|-------------------|--------|--------|
| Processing ret      | stall  | bubble       | normal            | normal | normal |
| Mispredicted branch | normal | bubble       | bubble            | normal | normal |
| Combination         | stall  | bubble       | bubble            | normal | normal |
| Condition           | F      | D            | Pipeline register |        |        |
| Processing ret      | stall  | bubble       | normal            | normal | normal |
| Load/use hazard     | stall  | stall        | bubble            | normal | normal |
| Combination         | stall  | bubble+stall | bubble            | normal | normal |
| Desired             | stall  | stall        | bubble            | normal | normal |