

### Assembler University 206: Powerful New z/Architecture Instructions That Don't Require AMODE(64), Part 1

SHARE 116 in Anaheim, Session 8982

Avri J. Adleman, IBM adleman@us.ibm.com

(Presented by John Ehrman, IBM) March 2, 2011

#### Topics



- Extended displacements
  - Many instructions allow for increased range of base register
- Reduced and enhanced memory access
  - Load, Store, and Insert Immediate Instructions
  - Boolean Immediate Instructions
  - Halfword-register operations
  - Reversed operand access
- Register comparison and testing
  - Registers, storage, swap, sign conversion
- Testing register operands Under Mask: register halfword-immediate
- Arithmetic instructions: 64-bit arithmetic, carry/borrow processing
- High-word instructions ("more registers")
- "Distinct-operand" and "load/store on condition" instructions

### **Terminology: all machine generations**



| Byte            | 8 bits              |
|-----------------|---------------------|
| Halfword        | 2 Bytes (16 Bits)   |
| Fullword (Word) | 4 Bytes (32 Bits)   |
| Doubleword      | 8 Bytes (64 Bits)   |
| Quadword        | 16 Bytes (128 Bits) |

- Notation: 64-bit based [32-bit based]
  - 64-bit based (Doubleword)
  - 32-bit based (Fullword)
- Positions:
  - "High Order" refers to the low numbered bits
  - "Low Order" refers to the high numbered bits

#### **Extended displacements**



- Traditional 12- bit displacements
  - Maximum +4K bytes from origin (base address)
  - Previously, all instructions that use base-displacement addressing
    - Range limits supported by HLASM
      - e.g. USING (FROM, TO), register list
- Extended 20-bit signed displacements
  - ±0.5M bytes from origin (base address)
    - 8 additional bits appended to the <u>left</u> of 12 bit displacement
      - Illustrated on next slide
    - HLASM range limits apply only to "short" displacements
  - Some old, many new instructions support 20 bit displacements
    - Initial z/OS instructions that had reserved fields in instruction format
      - Examples: LG, OG, ...
    - Specifically-enhanced "old" instructions
      - Mnemonics suffixed with "Y"
      - Examples: LY, MVIY, ...
    - Consult Principles of Operation; most are very easy to use

#### **Extended displacement: operation**





## **Register layout and notation for register-immediate instructions**



Technology - Connections - Results



| Byte <sub>0</sub> | $Byte_1$         | $Byte_2$           | Byte <sub>3</sub> Byte <sub>4</sub> Byte <sub>5</sub> |                            | $Byte_5$  | Byte <sub>6</sub>  | Byte <sub>7</sub> |  |  |
|-------------------|------------------|--------------------|-------------------------------------------------------|----------------------------|-----------|--------------------|-------------------|--|--|
| 1                 |                  | <b>A</b>           | 4                                                     |                            |           |                    | Î                 |  |  |
| High Hi           | gh ( <b>HH</b> ) | High Lo            | ow (HL)                                               | Low High (LH) Low Low (LL) |           |                    |                   |  |  |
|                   | High Full        | word ( <b>HF</b> ) |                                                       |                            | Low Fullv | vord ( <b>LF</b> ) |                   |  |  |
|                   |                  |                    |                                                       |                            |           |                    |                   |  |  |
|                   | 64-bit Register  |                    |                                                       |                            |           |                    |                   |  |  |

#### Instruction mnemonic usage



| Mnemonic                                | Name                                         | Instruction<br>Examples | Additional Remarks                                                                                                      |  |  |  |  |
|-----------------------------------------|----------------------------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| LL????                                  | Load Logical                                 | LLGT, LLGC, LLGH,       | Loads specific bytes of a register, fills remainder with zeroes.                                                        |  |  |  |  |
| ??G??                                   | Grande Register                              | LGR, AG, LTGR,          | Applies to full 64-Bit register as target or target and<br>source; may widen value with or without sign<br>propagation. |  |  |  |  |
| ??F??                                   | Fullword<br>("traditional register")         | LGF, LGFR, ALGF,        | Applies to 32-bit word as source; value is widened when target is a 64-bit register.                                    |  |  |  |  |
| ??T??                                   | Thirty-One Bit                               | LLGTR, LLGT             | Applies to source as the lower 31 bits: bit 33[1] to bit 63 [31]                                                        |  |  |  |  |
| ??H??                                   | Halfword (2 bytes)                           | LGH, AGH,               | Applies to a halfword (a pair of specified bytes) of a 64 bit register.                                                 |  |  |  |  |
| ??H??                                   | High word of a 64-bit register               | LMH, STMH               | Applies to the high word, bits 0 to 31, of a 64 bit register                                                            |  |  |  |  |
| ????LL,<br>????LH,<br>????HL,<br>????HH | Low-Low<br>Low-High<br>High-Low<br>High-High | TMLL, LLIHH,            | Specfied halfwords of a 64-bit register, or low and high halves of a 64-bit register                                    |  |  |  |  |
| II????                                  | Insert-Immediate                             | IILL, IILH,             | Load specific bytes of a register, leaving remainder alone.                                                             |  |  |  |  |

# Store/Load (Multiple) high halves of registers



- Store/Load High Half of "*Grande*" Registers
   Only high word's 32 bits saved
- Format RSY (extended displacement)

- **STMH**  $R_1, R_3, D_2 (B_2)$ 

- LMH  $R_1, R_3, D_2(B_2)$ 



- Analogous to STM and LM
  - Acts on range of registers
    - No Store or Load instructions for high half of a single register
    - Use multiple-type instruction with  $R_1 = R_3$

#### Store/Load 64-bit registers



- STG and LG
  - Store and Load single 64-bit register
  - Analogous to ST (STY) and L (LY)
  - Format RXY:
    - STG  $R_1, D_2(X_2, B_2)$

• LG  $R_1, D_2(X_2, B_2)$ 

**E3** 
$$R_1 X_2 B_2 DL_2 DH_2$$
 **24**  
**E3**  $R_1 X_2 B_2 DL_2 DH_2$  **04**

- STMG and LMG
  - Store and Load multiple 64-bit registers
  - Analogous to STM (STMY) and LM (LMY)
  - Format RSY:
    - STMG  $R_1, R_3, D_2(B_2)$

### Load Multiple Disjoint



 $R_1, R_3, D_2(B_2), D_4(B_4)$ LMD

- Format SS:  $EF R_1 R_3 B_2 D_2 B_4 D_4$
- Loads range of full 64-bit registers
- Uses two different locations
  - High half registers loaded from Arg<sub>2</sub>
  - Low half registers loaded from Arg<sub>4</sub>

| *       | Example of LMD           |  |  |  |  |  |  |  |  |
|---------|--------------------------|--|--|--|--|--|--|--|--|
|         | STMH R2,R5,HIREGS        |  |  |  |  |  |  |  |  |
|         | STM R2, R5, LOWREGS      |  |  |  |  |  |  |  |  |
|         |                          |  |  |  |  |  |  |  |  |
|         | LMD R2,R5,HIREGS,LOWREGS |  |  |  |  |  |  |  |  |
|         |                          |  |  |  |  |  |  |  |  |
| HIREGS  | DS 4F Save High Half     |  |  |  |  |  |  |  |  |
| LOWREGS | DS 4F Save Low Half      |  |  |  |  |  |  |  |  |

- Equivalent to doing a LMH and LM in one instruction!
- Allows AMODE=64 code to load saved "*Grande*" registers from two different save areas (high and low words)
  - Prevents register corruption on needed addresses
- Notes:
  - For performance, use sparingly:
    - Use LMH and LM or LMG if possible
  - There is **no** "Store Multiple Disjoint"

#### **Load and Store Pair**



- Load Register Pair from Storage
  - LPQ  $R_1, D_2(X_2, B_2)$  [RXY-Format]
  - R<sub>1</sub> represents an even/odd 64-bit register pair
  - D<sub>2</sub>(X<sub>2</sub>,B<sub>2</sub>) addresses 16 bytes of *quadword-aligned* storage
  - Process similar to:
    - LG  $R_1$ ,  $D_2(X_2, B_2)$  and LG  $R_1+1$ ,  $D_2+8(X_2, B_2)$
- Store Register Pair into Storage
  - **STPQ**  $\mathbf{R}_1$ ,  $\mathbf{D}_2$  ( $\mathbf{X}_2$ ,  $\mathbf{B}_2$ ) [RXY-Format]
  - R<sub>1</sub> represents an even/odd 64-bit register pair
  - D<sub>2</sub>(X<sub>2</sub>,B<sub>2</sub>) addresses 16 bytes of *quadword-aligned* storage
  - Process similar to:
    - STG  $R_1$ ,  $D_2(X_2, B_2)$  and STG  $R_1+1$ ,  $D_2+8(X_2, B_2)$
- Storage accesses are serialized

#### **Data-reversing instructions**



- Load and Store Reversed
  - Destination bytes are set in reverse order of the source
    - Source bytes from left to right set destination bytes right to left
  - Both source and destination use the same number of bytes
    - Possibly only the low order bytes in a destination register may be used
    - No sign bit propagation
    - Unused bytes in destination are untouched
  - The bit order in the bytes remains unchanged
- Load Reversed instructions
  - Register to Register: LRVR, LRVGR
  - Storage to Register: LRVH, LRV, LRVG
- Store Reversed instructions: STRVH, STRV, STRVG

#### **Reverse instructions: examples**



| *        | <pre>c(R2) = X'ABCDEF12' LRVR R3,R2 Register to Register Reverse c(R3) = X'12EFCDAB'</pre> |
|----------|--------------------------------------------------------------------------------------------|
| *        | c(R4) = X'01020304' (BEFORE)                                                               |
|          | LRVH R4,HALFWORD Storage to Register Reverse                                               |
| *        | c(R4) = X'0102D2C1' (AFTER)                                                                |
| HALFWORD | DC XL2'C1D2'                                                                               |
| *        | c(G5) = X'0011223344556677'                                                                |
|          | STRVG G5, DBLWORD Register to Storage Reverse                                              |
|          |                                                                                            |
| *        | c(DBLWORD) = XL8'7766554433221100'                                                         |
| DBLWORD  | DS D                                                                                       |

#### **Register comparison and testing**



- <u>Register Comparison with possible widening</u>
  - Register to Register (Similar to CR and CLR)
    - CGR, CGFR, CLGR, CLGFR
  - Register to Storage (Similar to C and CL)
    - CY, CG, CGF, CLY, CLG, *CLGF*
  - Compare and Swap (Similar to CS and CDS)
    - CSY, CDSY, CSG, CDSG
  - Compare Logical Characters (Similar to CLM)
    - CLMY, CLMH
- <u>Register Testing with possible widening</u>
  - Load and Test (Similar to LTR)
    - LTGR, LTGFR
- <u>Register Sign Conversion with possible widening</u>
  - Load Complement (Similar to LCR)
    - LCGR, LCGFR
  - Load Positive (Similar to LPR)
    - LPGR, LPGFR
  - Load Negative (Similar to LNR)
    - LNGR, LNGFR

For "Compare Logical Grande with Fullword," widening is with zeroes

All other "Grande with Fullword" compare and/ or test, widening is with sign extension

#### **Test Under Mask for register operands**



- Test bit settings in registers
  - Similar to the TM instruction
  - <u>Except</u>:
    - Test bits in a register  $(R_1)$  directly, not storage
    - Mask field maps a halfword  $(I_2)$ , not a byte
    - Condition code for <u>mixed</u>!! (*Different from TM!*)
      - Left most bit tested is zero sets CC = 1
      - Left most bit tested is one sets CC = 2
- Each instruction acts on a specific halfword
  - Four different instructions
    - TMHH  $R_1, I_2$ 
      - Test Under Mask High High (bits 0 to 15)
    - TMHL  $R_1, I_2$ 
      - Test Under Mask High Low (bits 16 to 31)
    - TMLH  $R_1, I_2$  or TMH  $R_1, I_2$ 
      - Test Under Mask Low High (bits 32[0] to 47[15])
    - TMLL  $R_1, I_2$  or TML  $R_1, I_2$ 
      - Test Under Mask Low Low (bits 48[16] to 63[31])



#### **Test Under Mask in registers: examples**



- \* Example #3: (Set the Condition Code to 2)
  LGHIR1,2
  TMLLR1,X'0003' Leftmost tested bit = 1

# Fullword register-immediate instructions (1)



63

Low Fullword

→ 31 32←

- Similar to Halfword Immediate Instructions
  - 64 bit registers considered as two fullwords
    - **xxHF** (high): Bits 0 to 31
    - **xxLF** (low): Bits 32 to 63
- Use them to eliminate literals (and storage references)
  - **IIxF** Insert Fullword Immediate High or Low
    - Places fullword into high or low fullword of register

High Fullword

- Remainder of register is unchanged
- Condition Code is unchanged
- **LLxF** Load Logical Immediate High or Low
  - Places fullword into high or low fullword of register
  - Remainder of register is set to 0
  - Condition Code is unchanged

# Fullword register-immediate instructions (2)



- Load Immediate
  - Sign bit extended (if necessary for 64-bit operation)
  - Condition code remains unchanged
  - LGFI (64 bits) and LFI (32 bits)
- Arithmetic Immediate
  - Sign bit extended (if necessary for 64-bit operation)
  - Condition code set arithmetically
  - Arithmetic: AGFI and AFI
  - Comparison: CGFI and CFI
- Logical Immediate
  - No sign extension, zero filled (if necessary for 64-bit operation)
  - Condition code set logically
  - Arithmetic: ALGFI, ALFI, SLGFI and SLFI
  - Comparison: CLGFI and CLFI

#### **Load Logical instructions**



- Load Logical
  - Loads specified part of a 32 or 64 bit target register
    - Source comes from register, storage or immediate operand
  - Remainder of the target register is <u>zero</u> filled, not sign extended!
- Instruction Types
  - Byte to 64 bit register
    - LLGC
  - Halfword to 64 bit register
    - LLGH, LLIHH, LLIHL, LLILH, LLILL
  - Fullword to 64 bit register
    - LLGFR, LLGF



#### **Register-processing instructions**



- Load and Test in a single instruction!
  - Load register from storage
    - LTG, LT and LTGF
  - Load register from register
    - LTGR, LTGFR
  - Same as Load, except condition code is set
    - 0 Result is zero
    - 1 Result is less than zero
    - 2 Result is greater than zero
    - 3 Unused
- Fullword-Immediate instructions
  - Six-byte instructions
  - Four-byte immediate operand
  - Similar to Halfword-Immediate

### Handy Dandy LLGT and LLGTR



- Load Logical "Grande" Thirty One Bits
  - $LLGT \quad R_1, D_2(X_2, B_2)$ 
    - RXY Format: **E3**  $R_1 X_2 B_2 DL_2 DH_2$  **17**
  - LLGTR  $R_1, R_2$ 
    - RRE Format: **B9 17**  $// \mathbb{R}_1 \mathbb{R}_2$
- Source (Register or Storage).
  - Fullword, 32 bits (Arg<sub>2</sub>)
- Target Register  $(\mathbf{R}_1)$ 
  - Doubleword, 64 bits
    - High word set to all zeroes
    - Low order word copied from source
    - Low order word's high bit 32[0] set to 0

FF

FF

FF

FF

 $\mathbf{F}\mathbf{F}$ 

7F

00

00

00

00

FF

 $\mathbf{FF}$ 

### **Operand-widening instructions (1)**



- Properties
  - Storage or low part of source register to full register
  - No Condition Code set
- From <u>C</u>haracter (unsigned byte) without sign extension
  - Storage to register:
    - **LLC**  $R_1$ , RX and **LLGC**  $R_1$ , RX
  - Register to Register:
    - LLCR  $R_1, R_2$  and LLGCR  $R_1, R_2$
- From <u>signed</u> **B**yte, with sign extension
  - LGBR  $R_1, R_2$  and LBR  $R_1, R_2$
- From halfword with sign extension
  - LGHR  $R_1, R_2$  and LHR  $R_1, R_2$

#### **Insert-Immediate instructions**



- Insert Immediate halfwords into a register
  - IIHH, IIHL, IILH and IILL
  - Places halfword into specified register position
  - Remainder of register is unchanged
  - Condition Code is unchanged







#### **Boolean-immediate instructions**



- Perform Boolean operation on selected register fullword component.
- Properties
  - Only designated halfword or fullword of a "Grande" register is operated on
  - Condition code is set as with other boolean operations
- Instructions operating on fullwords
  - And Immediate:
    - NIHF  $R_1, I_2$
    - NILF R<sub>1</sub>, I<sub>2</sub>
  - Exclusive OR Immediate:
    - XIHF  $R_1, I_2$
    - XILF R<sub>1</sub>, I<sub>2</sub>
  - OR Immediate:
    - OIHF R<sub>1</sub>, I<sub>2</sub>
    - OILF R<sub>1</sub>, I<sub>2</sub>

#### **Boolean-immediate halfword operations**



- NIxx, OIxx (but no XIxx instructions for halfwords!)
   xx = HH, HL, LH or LL
- Performs **halfword** boolean operation into specific register location
- Remainder of register is unchanged
- Sets condition code based on the halfword result



Register R1 Before



# Load-arithmetic instructions: operand widening (2)



- Load full 32 or 64 bit register
  - Source comes from register, storage or immediate operand
  - Sign extension
  - Widening: byte, halfword, or fullword to 64-bit register
- Instruction types
  - Byte to 32- or 64-bit register
    - LB, LGB
  - Halfword to 64-bit register
    - LGHI, LGH
  - Fullword to 64-bit register
    - LGF, LGFR

| <pre>Example: LGB R1,=X'A0'</pre> |    |    |    |    |    |    | <u>Exa</u> | ample | <u>=</u> : L( | GF R1 | ,=F' | 10' |    |    |    |    |    |
|-----------------------------------|----|----|----|----|----|----|------------|-------|---------------|-------|------|-----|----|----|----|----|----|
| R1                                | FF         | A0    | R1 →          | 00    | 00   | 00  | 00 | 00 | 00 | 00 | 0A |

#### 64-bit arithmetic instructions



- Full 64-bit signed addition and subtraction
  - Analogous to 32-bit arithmetic
    - AG, AGR, SG, SGR, ALG, ALGR, SLG, SLGR
  - Widening from halfword or word to doubleword
    - Sign extension: AGF, AGFR, SGF, SGFR
    - Zero extension: ALGF, ALGFR, SLGF, SLGFR
- Single-register Processing
  - Reduces the need for even/odd register pairs
  - Operand widening in certain cases with sign extension
    - MSG, MSGF, MSGFR, MSGR
    - DSG, DSGF, DSGFR, DSGR *do* require register pairs for quotient/remainder!
- Logical Arithmetic on even/odd pairs
  - Allows for 64- or 128-bit *unsigned* product or quotient
  - Unsigned values treated similarly as used with AL, ALR, etc. instructions
    - ML, MLG, MLR, MLGR
    - **DL**, DLG, DLGR, **DLR** (also require register pairs!)

#### 64-bit arithmetic: examples



\* Example #1:

\* Example #2:

MSGF R1,=F'3' Note: same as MSG R1,=FD'3'
\* Before: R1 = X'000000000000000002'

- \* Example #3:

### Logical-arithmetic instructions with Carry and Borrow feature



- New Logical Arithmetic Instructions
  - Performs logical addition or subtraction
    - Similar to the "traditional" ALx and SLx type instructions
  - Carry or borrow is indicated by the Condition Code
    - Set by previous logical arithmetic statement, as usual
    - Continues to propagate carry or borrow
      - Intermediate instructions must not alter the CC!
- Instructions use 32- or 64-bit registers
  - Addition
    - ALC, ALCR, ALCG, ALCGR
  - Subtraction
    - SLB, SLBR, SLBG, SLBGR

### Logical Arithmetic Instructions with Carry and Borrow Feature



- Allows easy addition or subtraction of large binary numbers
  - No need to code branches around carry or borrow
    - Condition codes 2 or 3 for add logical
    - Condition code 1 for subtract logical
  - No need to include special instructions for adding or subtracting the carry or borrow
- Process
  - Arithmetic proceeds right to left
  - First instruction is the traditional logical addition or subtraction
    - Be careful to preserve the condition code!
  - Remaining instructions are Add With Carry or Subtract With Borrow
    - Propagates the condition code for each successive operation

## Logical-arithmetic instructions with Carry and Borrow: example



| * Old Sty | yle      |               | * <u>New Style</u>          |
|-----------|----------|---------------|-----------------------------|
| STCK      | CLOCK    |               | STCK CLOCK                  |
| LM        | R2,R3,C  | LOCK          | LM R2, R3, CLOCK            |
| LM        | R4,R5,F2 | ACTOR         | LM R4, R5, FACTOR           |
| SRDI      | R2,12    |               | SRDL R2,12                  |
| * Additic | on       |               | * Addition                  |
| ALR       | R3,R5    | Add Low       | ALR R3,R5 Add Low           |
| BC        | 12,*+8   | Carry ?       | ALCR R2, R4 Add High        |
| AL        | R2,ONE   | Yes!!!        |                             |
| ALR       | R2,R4    | Add High      |                             |
| * Subtrac | ction    |               | * Subtraction               |
| SLR       | R3,R5    | Subtract Low  | SLR R3,R5 Subtract Low      |
| BC        | 3,*+8    | Borrow ?      | SLBR R2,R4 Subtract High    |
| SL        | R2,ONE   | Yes!!!        |                             |
| SLR       | R2,R4    | Subtract High |                             |
| CLOCK     | DS D     |               | CLOCK DS D                  |
| FACTOR    | DC FD    | 'nnnnn'       | FACTOR DC FD' <i>nnnn</i> ' |
| ONE DC    | F'1'     |               |                             |
|           |          |               |                             |
|           |          |               |                             |
|           |          |               |                             |
|           |          |               |                             |

### **High-word instructions (z196)**



- High 32 bits of a 64-bit register
- 16 more 32-bit registers!
  - Add/subtract (signed, logical, immediate)
  - Comparison (signed, logical, immediate)
  - Load/Store (byte, character, halfword, word; register and memory)
  - Logical operations (AND, OR, XOR)
  - Logical shifts
  - Branch Relative on Count
- Many instructions use high- and lowhalf 32-bit operands
- Add/subtract can be non-destructive

- Examples:
- AHHLR  $R_1, R_2, R_3$ 
  - R<sub>1</sub> = High-half for sum
  - $-R_2 = High-half operand$
  - $R_3 = Low-half operand$
  - Possible use:
    - Accumulate subtotals in 32-bit lowhalf of a register
    - Accumulate grand total in 32-bit high-half of the register
- BRCTH  $R_1, I_2$ 
  - Use it for loop counts to free up low-half registers for addressing

#### **High-word instructions: summary**



- Mnemonics look complex, but make sense after a while
- Add: AHHHR, AHHLR, AIH
  - Logical: ALHHHR, ALHHLR,ALSIH, ALSIHN (CC not set!)
- Subtract: SHHHR, SHHLR
  - Logical: SLHHHR, SLHHLR
- Compare: CHHR, CHLR, CIH
  - Logical: CLHHR, CLHLR, CLIH
- Memory load: LBH, LHH, LFH
  - Logical: LLCH, LLHH
- Store: STCH, STHH, STFH
- Load Immediate: **LLIHF** (not new with z196)

- Register Logical load
  - 32-bit: LHHR, LHLR, LLHFR
  - 16-bit: LLHHHR, LLHHLR, LLHLHR
  - 8-bit: LLCHHR, LLCHLR, LLCLHR
- Logical operations **XXXX**  $\mathbf{R}_{1}, \mathbf{R}_{2}$ 
  - AND: NHHR, NHLR, NLHR
  - OR: OHHR, OHLR, OLHR
  - XOR: XHHR, XHLR, XLHR
- Logical Shifts **xxxx**  $\mathbf{R}_1, \mathbf{R}_2, \mathbf{I}_3$  (!)
  - SLLHH, SLLLH, SRLHH,
     SRLLH

# Distinct-operand and load/store on condition instructions



- Many common instructions destroy the target operand
  - A, AR, SLL, XR, etc.
- Some new (familiar) 3-operand instructions let you preserve it
  - Target register distinct from operand register(s)
  - Mnemonics suffixed with **K**
  - Example: **ARK**  $\mathbf{R}_1, \mathbf{R}_2, \mathbf{R}_3$
  - $c(\mathbf{R}_{1}) = c(\mathbf{R}_{2}) + c(\mathbf{R}_{3})$
- Add/subtract arithmetic and logical
- AND, OR, XOR
- Single-length logical and arithmetic shifts

- Load on condition:
  - LOC, LOCG, LOCR, LOCGR
  - Format: **xxx**  $\mathbf{R}_1, \mathbf{Op}_2, \mathbf{M}_3$
  - Example: Max of R1,R2 in R1
     <u>Old way:</u> <u>New way:</u>
     CR 1,2 CR 1,2
     JL \*+6 LROC 1,2,4
     LR 1,2
- Store on condition:
  - STOC, STOCG
  - Example: Load R1 if contents = 0
     Old way: New way:
     LTR 1,1
     LTR 1,1