# Assembler Language Programming

for

IBM System z<sup>TM</sup> Servers

# Mini-Slides and Lecturer Notes, Version 2.00

Chapters I to VIII

John R. Ehrman

IBM Silicon Valley Lab

Note

These pages have space below the miniature copies of the lecture slides where a lecturer can write notes for added explanations, digressions, etc.

Because the font sizes used for the full-size slides do not scale exactly to the miniature forms, some of the miniature slides might overflow the space in which the full-size slides will fit. I expect that these miniature slides will be used only to connect the full-size lecture slides to these lecturer notes, so the overflows won't be a major concern.

## Second Edition (March 2016)

IBM welcomes your comments. Please address them to

John Ehrman IBM Silicon Valley Lab 555 Bailey Avenue San Jose, CA 95141 ehrman@us.ibm.com

After June 1, 2016, please address comments to

john.ehrman@comcast.net

## © Copyright IBM Corporation 2015

US Government Users Restricted Rights – Use, duplication or disclosure restricted by GSA ADP Schedule Contract with IBM Corp.

| his | chapter reviews some basic aspects of System z processors                                                                                                                                                                                                                                                           |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S   | ection 1 introduces notation, terminology, and conventions<br>ection 2 describes basic properties of the number representations<br>sed in System z processors:<br>Binary and hexadecimal numbers<br>Arithmetic and logical representations<br>2's complement arithmetic<br>Conversions among number representations |
|     |                                                                                                                                                                                                                                                                                                                     |

| C  | often use a figure like this:                                                                                                                                          |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | 4 4 ← Field widths                                                                                                                                                     |
|    | Field1 Field2                                                                                                                                                          |
|    | 0 34 7 🖛 Start and end positions of fields                                                                                                                             |
| ٧  | Ve number positions from <b>left</b> to <b>right</b> .                                                                                                                 |
| li | When we refer to a sequence of similar items, we may use subscripts ike $B_j$ , or appended letters like $B_j$ , or the programming-language subscript notation $B(j)$ |
| Г  | The contents of some item X is often denoted c(X)                                                                                                                      |
|    | The operators $+$ - $*$ / represent addition, subtraction, multiplication, and division, respectively                                                                  |
| 6  |                                                                                                                                                                        |
|    | o show a blank space, we sometimes use a • character                                                                                                                   |







|                |                    | the<br>f 4 b                       |                      |                           |                         |                       |                       |                        |                    |                   |                 |                 |                 | rger,           | we    | use   |
|----------------|--------------------|------------------------------------|----------------------|---------------------------|-------------------------|-----------------------|-----------------------|------------------------|--------------------|-------------------|-----------------|-----------------|-----------------|-----------------|-------|-------|
| T              | he 1               | 6 po                               | ssibl                | e he                      | x va                    | lues                  | from                  | n 0 to                 | o 15               | are               | repr            | esen            | ted I           | oy 0-           | •9, A | -F    |
| 0000<br>0<br>0 | 0001<br>1<br>1     | 0010<br>2<br>2                     | 0011<br>3<br>3       | 0010<br>4<br>4            | 0101<br>5<br>5          | 0110<br>6<br>6        | 0111<br>7<br>7        | 1000<br>8<br>8         | 1001<br>9<br>9     | 1010<br>10<br>A   | 1011<br>11<br>B | 1100<br>12<br>C | 1101<br>13<br>D | 1110<br>14<br>E |       | (dec) |
| -<br>E:        | So<br>xerc<br>xerc | lecim<br>B'110<br>ise: d<br>ise: d | )10′<br>conv<br>conv | = X'1<br>ert to<br>ert to | A'; E<br>b hex<br>b dee | 3'101<br>kade<br>cima | 1′ =<br>cima<br>I: X′ | X′B′<br>I: 14<br>763′, | B′1<br>5, 5<br>X′F | 1111(<br>00<br>7' | 00111           | l' = )          | X′3E7           | ,,              |       |       |
| • E:           | xerc               | ise: (                             | conv                 | ert to                    | o bin                   | ary:                  | X′76                  | 53', )                 | 〈'F7'              |                   |                 |                 |                 |                 |       |       |





| Two's Complement                                                                                                                                            | 9         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| • Binary addition is very simple:<br>$ \begin{array}{ccccccccccccccccccccccccccccccccccc$                                                                   |           |
| • Finding the two's complement (negation) of a binary number:                                                                                               |           |
| <ul> <li>Take its ones' complement: change all 0s to 1s and 1s to 0s;<br/>then add a low-order 1 bit</li> </ul>                                             |           |
| <ul> <li>Examples, using signed 8-bit values:</li> </ul>                                                                                                    |           |
| 10000001         (signed -127)         00000001         (signed +1)           01111110         ones' complement         11111110         ones' complement   |           |
| + 1<br>01111111 (signed +127) + 1<br>11111111 (signed -1)                                                                                                   |           |
| 11111101         (signed -3)         00011111         (signed +31)           00000010         ones' complement         11100000         ones' complement    |           |
| 00000011 (signed +3) 11100001 (signed -31)                                                                                                                  |           |
| <ul> <li>Carries out of the leftmost bit: ignored for unsigned, important for sig</li> <li>But most arithmetic instructions take note of carries</li> </ul> | gned      |
| Chap. I, Sec. 2.8 System z Assembler Language                                                                                                               | ©IBM 2015 |

| Sign Extension                                                                                                   | 10     |
|------------------------------------------------------------------------------------------------------------------|--------|
| Binary numbers can be lengthened to greater precision by sign extension                                          |        |
| If the sign bit is copied to the left, the value of the number is<br>unchanged in the new, longer representation |        |
| - Examples, using signed 16-bit values extended from 8 bits:                                                     |        |
| 1111111110000001(signed -127)0000000000000001(signed +1)0000000001111111(signed +127)1111111111111111(signed -1) |        |
| - Many instructions do sign extension automatically                                                              |        |
|                                                                                                                  |        |
|                                                                                                                  |        |
| hap. I, Sec. 2.9 System z Assembler Language © IB                                                                | M 2015 |

| Ac | ddition, Subtraction, and Arithmetic Overflow                                                                                                                     | 11 |
|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| •  | All bits are added; high-order carries are lost (but noted)                                                                                                       |    |
|    | - Examples, using signed 4-bit values (range -8 $\leq$ value $\leq$ +7):                                                                                          |    |
|    | $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                              |    |
|    | <ul> <li>Arithmetic addition: overflow possible only when adding like-signed operands.</li> </ul>                                                                 |    |
|    | • Actions vary: signed overflow can be ignored, or cause an "interruption"                                                                                        |    |
| •  | Unsigned (logical) addition: carries are noted, no overflows                                                                                                      |    |
|    | - Examples, using unsigned 4-bit values (range 0 $\leq$ value $\leq$ 15):                                                                                         |    |
|    | 1111 (15)       0010 (2)       1100 (12)         +0001 (1)       +0010 (2)       +1001 (9)         0000 (0, carry)       0100 (4, no carry)       0101 (5, carry) |    |
| •  | Conditional branch instructions (described in Section 15) can te<br>overflow (arithmetic addition or subtraction) and carries (logica<br>addition or subtraction) |    |
|    |                                                                                                                                                                   |    |

| • | Subtraction is slightly                                              | , more complicate   | ed than addition                                                        |            |
|---|----------------------------------------------------------------------|---------------------|-------------------------------------------------------------------------|------------|
|   | <b>U</b> .                                                           | •                   | ond (subtrahend) opera                                                  | nd         |
|   |                                                                      | end) and compleme   | nted second operands a                                                  |            |
|   | - Examples, using sigr                                               | red 4-bit values:   |                                                                         |            |
|   | -1-(+1)<br>1111 (-1)<br>1110 (+1,comp)<br>+ <u>1</u> 110 (-2, carry) | 0010 (+2)           | 3-5<br>0011 (+3)<br>1010 (+5,comp)<br><u>+ 1</u><br>1110 (-2, no carry) |            |
|   | <ul> <li>Arithmetic subtractio<br/>noted</li> </ul>                  | n: overflows possib | le; logical subtraction: c                                              | arries are |
| • | Adding the first oper second operand work                            |                     | •                                                                       | of the     |
|   |                                                                      |                     |                                                                         |            |
|   |                                                                      |                     |                                                                         |            |





|                  | terns from logic<br>only the overflow |                    |                     |                     |
|------------------|---------------------------------------|--------------------|---------------------|---------------------|
| -                | esentations for                       | ,                  |                     | unterent            |
| Binary<br>Digits | Logical<br>Representation             | Sign-<br>Magnitude | Ones'<br>Complement | Two's<br>Complement |
| 0000             | 0                                     | +0                 | +0                  | 0                   |
| 0001             | 1                                     | +1                 | +1                  | +1                  |
| 0010             | 2                                     | +2                 | +2                  | +2                  |
| 0011             | 3                                     | +3                 | +3                  | +3                  |
| 0100             | 4                                     | +4                 | +4                  | +4                  |
| 0101             | 5                                     | +5                 | +5                  | +5                  |
| 0110             | 6                                     | +6                 | +6                  | +6                  |
| 0111             | 7                                     | +7                 | +7                  | +7                  |
| 1000             | 8                                     | -0                 | -7                  | -8                  |
| 1001             | 9                                     | -1                 | -6                  | -7                  |
| 1010             | 10                                    | -2                 | -5                  | -6                  |
| 1011             | 11                                    | -3                 | -4                  | -5                  |
| 1100             | 12                                    | -4                 | -3                  | -4                  |
| 1101             | 13                                    | -5                 | -2                  | -3                  |
| 1110             | 14                                    | -6                 | -1                  | -2                  |
| 1111             | 15                                    | -7                 | -0                  | -1                  |

| Exercise Answers                                   |                             | 16         |
|----------------------------------------------------|-----------------------------|------------|
| • Slide 5:                                         |                             |            |
| - B'01010001', B'111111                            | 1'                          |            |
| - 170, 241                                         |                             |            |
| • Slide 6:                                         |                             |            |
| - X'91', X'1F4'                                    |                             |            |
| - 1891, 247                                        |                             |            |
| - B'11101100011', B'1111                           | 01111'                      |            |
| • Slide 7:                                         |                             |            |
| - X'929', 6560 <sub>7</sub> , 10B5 <sub>13</sub> . |                             |            |
| • Slide 8:                                         |                             |            |
| 86, 170                                            |                             |            |
|                                                    |                             |            |
|                                                    |                             |            |
|                                                    |                             |            |
|                                                    |                             |            |
| Chap. I, Sec. 2.1-2.7                              | System z Assembler Language | © IBM 2015 |

| Chapter II. System z                                                                                                                                                                                                         | 1   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| This chapter's three sections introduce the main features of System z processors:                                                                                                                                            |     |
| <ul> <li>Section 3 describes key processor structures: the Central Processing<br/>Unit (CPU), memory organization and addressing, general purpose<br/>registers, the Program Status Word (PSW), and other topics.</li> </ul> | I   |
| • Section 4 discusses the instruction cycle, basic machine instruction types and lengths, exceptions and interruptions and their effects on the instruction cycle.                                                           | he  |
| <ul> <li>Section 5 covers address calculation, the "addressing halfword",<br/>Effective Addresses, indexing, addressing problems, and virtual<br/>memory.</li> </ul>                                                         |     |
|                                                                                                                                                                                                                              |     |
|                                                                                                                                                                                                                              |     |
| Chap. II, Sec. 3-5 System z Assembler Language © IBM 2                                                                                                                                                                       | 015 |



|     | name | •      | ps w | vith a | addro | esse | s div | /ISIDI | e by | the  | grou | ib le | ngth | hav  | e sp  | ecia |     |
|-----|------|--------|------|--------|-------|------|-------|--------|------|------|------|-------|------|------|-------|------|-----|
| 8DF | 8E0  | 8E1    | 8E2  | 8E3    | 8E4   | 8E5  | 8E6   | 8E7    | 8E8  | 8E9  | 8EA  | 8EB   | 8EC  | 8ED  | 8EE   | 8EF  | 8F0 |
|     |      |        |      |        |       |      |       |        | ļ    |      |      |       |      |      |       |      |     |
| 1   | Truc | tions  |      |        |       |      |       | gie    | byte | s, g | rou  | os a  | s sh | iowr | i, or | stri | ng  |
|     |      | of (al | mos  | n) a   | ,     |      |       |        |      |      |      |       |      |      |       |      |     |
|     |      | of (al | mos  | n) a   |       |      |       |        |      |      |      |       |      |      |       |      |     |



| -       | Used for flo |         |              | riginally 4:<br>some instructions u                    | se only the left half |
|---------|--------------|---------|--------------|--------------------------------------------------------|-----------------------|
|         |              | 64 BITS |              | ▶                                                      |                       |
| ſ       |              | F0      |              |                                                        |                       |
| ŀ       |              | F2      |              |                                                        |                       |
|         |              | F4      |              |                                                        |                       |
| ſ       |              | F6      |              | 1                                                      |                       |
| _       | 0            |         |              | 63                                                     |                       |
| Pr<br>- | Key compo    | `       | ction Length | ally a 128-bit qua<br>Code (ILC), Condit<br>dress (IA) | ,                     |

| Basic Instruction Cycle                                                                                                                                                                                                   | 6         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| • Easiest to visualize in three steps:                                                                                                                                                                                    |           |
|                                                                                                                                                                                                                           |           |
| <ol> <li>Fetch: bring instruction from memory, determine its type and lengt         <ul> <li>Add its length to PSW's Instruction Address (IA) to form address of "Next<br/>Sequential Instruction"</li> </ul> </li> </ol> |           |
| 2. Decode: determine validity of instruction; access operands                                                                                                                                                             |           |
| <ol><li>Execute: perform the operation; update registers and/or memory a required</li></ol>                                                                                                                               | S         |
| • Possible problems, interruptions (more at slides 9-10)                                                                                                                                                                  |           |
| <ul> <li>Fetch: invalid instruction address</li> </ul>                                                                                                                                                                    |           |
| <ul> <li>Decode: invalid or privileged instruction</li> </ul>                                                                                                                                                             |           |
| <ul> <li>Execution: many possibilities!</li> </ul>                                                                                                                                                                        |           |
|                                                                                                                                                                                                                           |           |
| Chap. II, Sec. 4.1 System z Assembler Language                                                                                                                                                                            | ©IBM 2015 |



| 11xxxxxx 6-byte instructions such as SS-type                                                                      |      |
|-------------------------------------------------------------------------------------------------------------------|------|
| Instruction Length Code (ILC) set to the number of halfwords in instruction (1,2,3)                               | the  |
| ILC<br>(decimal)         ILC (binary)         Instruction types         Opcode bits<br>0-1         Instruction le | ngth |
| 0 B' 00' Not availab                                                                                              | le   |
| 1 B'01' RR B'00' One halfwo                                                                                       | rd   |
| 2 B'10' RX B'01' Two halfwor                                                                                      | rds  |
| 2 B'10' RS, SI B'10' Two halfwor                                                                                  | rds  |
| 3 B'11' SS B'11' Three halfwo                                                                                     | ords |



| Inter   | ruptions                                                                                                         | 10         |
|---------|------------------------------------------------------------------------------------------------------------------|------------|
| • Th    | e CPU saves the current ("old") PSW, loads a new PSW                                                             |            |
|         | Supervisor saves status information, processes the condition                                                     |            |
|         | Supervisor can return to interrupted program by loading old PSW                                                  |            |
| • Sc    | ome "popular" Program Interruption Codes (IC):                                                                   |            |
|         | =1 Invalid Operation Code.                                                                                       |            |
|         | <ul> <li>4 Access, Protection: program has referred to an area of<br/>to which access is not allowed.</li> </ul> | memory     |
| IC      | =6 Specification Error: can be caused by many conditions.                                                        |            |
|         | =7 Data Exception: invalid packed decimal data, or by floa conditions described in Chapter IX.                   | ting-point |
| IC      | =8 Fixed-Point Overflow: fixed-point binary result too large                                                     |            |
|         | =9 Fixed-Point Divide Exception: quotient would be too big<br>divisor is zero.                                   |            |
| IC      | <b>= A</b> Decimal Overflow: packed decimal result too large.                                                    |            |
| IC      | <b>B</b> Decimal Divide: packed decimal quotient too large, or is zero.                                          | a divisor  |
| IC      | <b>=C</b> Hexadecimal floating-point exponent overflow: result to                                                | o large.   |
| IC      | <b>= D</b> Hexadecimal floating-point exponent underflow: result                                                 | too small. |
| Chen II | Sec. 4.5-4.6 System z Assembler Language                                                                         | © IBM 2015 |



| In  | dexi      | ng and V                                        | irtual            | Add              | ress              | es                                                                  |                       | 12   |
|-----|-----------|-------------------------------------------------|-------------------|------------------|-------------------|---------------------------------------------------------------------|-----------------------|------|
| •   | RX        | type instru                                     | uction            | s cor            | ntain a           | an <i>index register</i> s                                          | pecification digit x: |      |
|     |           | opcode                                          | r                 | x                | b                 | displacement                                                        |                       |      |
|     | - 1       | ndexed Effe                                     | ctive             | Addre            | ss cal            | culation adds two mo                                                | re steps:             |      |
|     |           |                                                 | •                 |                  |                   | zero, add c(Rx); ig<br>, do nothing                                 | nore carries          |      |
|     |           | Example: RX<br>c(R11) = X'                      |                   |                  |                   |                                                                     | ) = X' FEDCBA98', and |      |
|     |           | Step 1:<br>Step 2a:<br>Step 3a: <u>+</u><br>(1) | C73E90<br>FEDCBA  | AF<br>98         | index             | from R11)                                                           | carry ignored         |      |
| •   | -  <br>-  | DAT transla                                     | tes ap<br>iting S | plicat<br>Systen | ion ad<br>1 bette | Address Translatio<br>dresses into "real" a<br>er manage "actual" m | ddresses              |      |
| Cha | ap. II, S | Sec. 5.3,5.6                                    |                   |                  | System            | z Assembler Language                                                | ©IBM                  | 2015 |

|   | is chapter describes fundamental concepts of Assembler Language ogramming.                                                                                                                                                     |
|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | Section 6 provides an overview of assembling, linking and loading for execution; conventions for preparing Assembler Language programs; and some helpful macro instructions that perform simple I/O and conversion operations. |
| • | Section 7 discusses key concepts relating to symbols and "variables".                                                                                                                                                          |
| • | Section 8 investigates the elements of expression evaluation, and the basic Assembler Language operand formats used by instructions.                                                                                           |
| • | Section 9 introduces typical instructions and how to write Assembler Language statements for them.                                                                                                                             |
| • | Section 10 shows how the Assembler calculates displacements and assigns base register values in Addressing Halfwords, and introduces the important USING and DROP assembler instructions.                                      |
|   |                                                                                                                                                                                                                                |

| As  | ssembler Language                                                                                                                                                                                            | 2    |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| •   | The Assembler helps you prepare instructions for execution on System z                                                                                                                                       |      |
| •   | Gives you maximum control over selection and sequencing of specifi instructions                                                                                                                              | с    |
| •   | Assembler Language itself is much simpler than other programming languages                                                                                                                                   |      |
| •   | Main difficulties are                                                                                                                                                                                        |      |
|     | <ul> <li>Learning an appropriate set of machine instructions for your applications</li> <li>Learning all the auxiliary tools and programs needed to build and use<br/>Assembler Language programs</li> </ul> |      |
|     |                                                                                                                                                                                                              |      |
|     |                                                                                                                                                                                                              |      |
| Cha | p. III, Sec. 6 System z Assembler Language ©IBM                                                                                                                                                              | 2015 |

| •   | Generally done in three stages:                                                                                                                                                                                                       |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | <b>1. Assembly;</b> The <b>Assembler</b> translates the statements of your <i>source program</i> into machine language instructions and data ("object code" in the form of an <i>object module</i> for eventual execution by the CPU. |
|     | <b>2. Linking:</b> The <b>Linker</b> combines your object module with any others required for satisfactory execution. The resulting <i>load module</i> is saved.                                                                      |
|     | <b>3. Program Loading:</b> The <b>Program Loader</b> reads your load module into memory and then gives CPU control to your instructions starting at the <i>entry point</i> .                                                          |
|     | Your program then executes your instructions: reading, writing, and generating data                                                                                                                                                   |
|     |                                                                                                                                                                                                                                       |
|     |                                                                                                                                                                                                                                       |
| Cha | p. III, Sec. 6.1 System z Assembler Language ©IBM 201                                                                                                                                                                                 |









| <ul> <li>Six macro instr</li> </ul> | uctions are used extensively throughout the | e text:     |
|-------------------------------------|---------------------------------------------|-------------|
| PRINTOUT                            |                                             |             |
| Display conte                       | ents of registers and named areas of memo   | ory.        |
| READCARD<br>Read an 80-c            | character record into memory.               |             |
| PRINTLIN<br>Send a string           | g of characters to a printer.               |             |
| DUMPOUT<br>Display conte            | ents of memory in hexadecimal and charact   | er formats. |
| CONVERTI<br>Convert chara           | acters to a 32- or 64-bit binary integer.   |             |
| CONVERTO<br>Convert a 32            | - or 64-bit binary integer to characters.   |             |
| Equivalent facil                    | lities may be available at your location.   |             |





# **EBCDIC Character Representation**

#### · Every character is represented by a number Char Char Hex Char Char Hex Hex Hex Blank 40 4B 81 b 82 a 83 d 84 85 f 86 с e g 87 h 88 i 89 j 91 1 93 95 k 92 94 m n 96 97 98 99 r 0 р q A2 t A3 u A4 ٧ Α5 s A6 Α7 A8 z Α9 w х у А C1 В C2 С C 3 D C4 Е C5 F C6 G C7 Н C8 Ι C 9 J D1 К D2 L D3 D5 D7 М D4 Ν 0 D6 Р D9 D8 R E2 E3 Q S Т E4 ۷ E 5 E6 E7 U W Х E9 F0 F1 Y E8 Ζ 0 1 2 F2 3 F3 4 F4 5 F5 6 F6 7 F7 8 F8 9 F9 Chap. III, Sec. 7.2 System z Assembler Language © IBM 2015

11

Notes







| Assi | gning Va                | lues to Sym          | bols                                                          | 15                        |
|------|-------------------------|----------------------|---------------------------------------------------------------|---------------------------|
| • Va | alues are               | assigned to s        | ymbols in two ways:                                           |                           |
| 1    |                         |                      | ally take the current value of the I<br>th of generated data) | ocation Counter           |
|      | MyProg1<br>Start        | Start 0<br>BASR 15,0 | Set assumed origin location O<br>Value of symbol "Start" is O |                           |
| 2    | . Sometim<br>stateme    |                      | es are assigned by the programme                              | er using an EQU           |
|      | symbol                  | EQU self-def         | fining term The most common for                               | m                         |
|      | ABS425<br>Char_A        | EQU 425<br>EQU C' A' | ABS425 has value 42<br>Char_A has value X'                    | -                         |
| 3    | . The leng<br>attribute |                      | ated data is usually assigned as th                           | ne symbol's <i>length</i> |
|      |                         |                      |                                                               |                           |
|      |                         |                      |                                                               |                           |
|      |                         |                      |                                                               |                           |

| Sy  | mbols and Variables                                                                                                                               | 16 |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|----|
| •   | Symbols in high-level languages (usually called "variables") have<br>execution-time values<br>X <- 22./7. ; /* Set X to an approximation to pi */ |    |
| •   | Symbols in Assembler Language are used only at assembly time; the have <b>no</b> execution-time value (are NOT "variables")                       | у  |
|     | <ul> <li>Used as names of places in a program that may contain execution-time values</li> </ul>                                                   |    |
|     | - Symbol values simply help to organize the program                                                                                               |    |
|     |                                                                                                                                                   |    |
|     |                                                                                                                                                   |    |
|     |                                                                                                                                                   |    |
|     |                                                                                                                                                   |    |
|     |                                                                                                                                                   |    |
| Cha | ap. III, Sec. 7.7 System z Assembler Language ©IBM 2                                                                                              | 01 |



| lerms                                                      | 18        |
|------------------------------------------------------------|-----------|
| • A basic expression element is a <i>term</i>              |           |
| <ul> <li>A self-defining term (always absolute)</li> </ul> |           |
| - A symbol (absolute or relocatable)                       |           |
| - A Location Counter reference * (always relocatable)      |           |
| - A Literal (always relocatable)                           |           |
| - A symbol attribute reference (always absolute)           |           |
| • Length (L'symbol)                                        |           |
| • Integer (I'symbol)                                       |           |
| • Scale (S'symbol)                                         |           |
|                                                            |           |
|                                                            |           |
|                                                            |           |
|                                                            |           |
| Chap. III, Sec. 8.1 System z Assembler Language            | ©IBM 2015 |





| Evalua       | ting Assembly-Time Expressions                                                                                                 | 21        |
|--------------|--------------------------------------------------------------------------------------------------------------------------------|-----------|
| 7. Div       | ision discards any remainder                                                                                                   |           |
| •            | Division by zero is allowed; result is zero (!)                                                                                |           |
| 8. Ev        | aluation result is a 32-bit two's complement value                                                                             |           |
|              | locatability attribute of expression determined from relocata terms:                                                           | ıbility   |
| a.           | Pairs of terms with same attribute and opposite signs have no effe<br>"cancel"); if all are paired, the expression is absolute | ct (they  |
| b.           | One remaining unpaired term sets the attribute of the expression;<br>+ means simply relocatable, - means complexly relocatable |           |
| с.           | More than one unpaired term means the expression is complexly relocatable (a rare occurrence)                                  |           |
|              |                                                                                                                                |           |
|              |                                                                                                                                |           |
|              |                                                                                                                                |           |
|              |                                                                                                                                |           |
| Chap. III, S | Sec. 8.3 System z Assembler Language                                                                                           | ©IBM 2015 |

| 10 | ,                         | re "expr" = e>                         | , ,                                        |       |
|----|---------------------------|----------------------------------------|--------------------------------------------|-------|
|    | expr                      | expr <sub>1</sub> (expr <sub>2</sub> ) | $expr_1(expr_2, expr_3)$                   |       |
|    | 7<br>8*N+4<br>(91)        | A(B)                                   | 22(22,22)<br>(A)((B),(C))<br>(91)(,15)     |       |
| -  | In the sec<br>multiplicat |                                        | orms, adjacent parentheses do <i>not</i> i | imply |
| -  | In the third              | d form, expr <sub>2</sub> ca           | n be omitted if it is zero:                |       |
|    | expr                      | $r_1(,expr_3)$ [T                      | he comma is still required!]               |       |
|    |                           |                                        |                                            |       |



| Ор    | Mnem          | e some commonly used<br>Instruction | Ор                 | Mnem                 | Instruction                        |
|-------|---------------|-------------------------------------|--------------------|----------------------|------------------------------------|
| 05    | BALR          | Branch And Link                     | 06                 | BCTR                 | Branch On Count                    |
| 07    | BCR           | Branch On Condition                 | 0D                 | BASR                 | Branch And Save                    |
| 10    | LPR           | Load Positive                       | 11                 | LNR                  | Load Negative                      |
| 12    | LTR           | Load And Test                       | 13                 | LCR                  | Load Complement                    |
| 14    | NR            | AND                                 | 15                 | CLR                  | Compare Logical                    |
| 16    | OR            | OR                                  | 17                 | XR                   | Exclusive OR                       |
| 18    | LR            | Load                                | 19                 | CR                   | Compare                            |
| 1 A   | AR            | Add                                 | 1 B                | SR                   | Subtract                           |
| 1C    | MR            | Multiply                            | 1D                 | DR                   | Divide                             |
| 1E    | ALR           | Add Logical                         | 1F                 | SLR                  | Subtract Logical                   |
| ٦     | Гурісаl о     | perand field described as           | s R <sub>1</sub> , | R <sub>2</sub> — ope | rands of "expr <sub>1</sub> " form |
| Chap. | III, Sec. 9.1 | System z Asse                       | embler             | Language             | ©IE                                |

| Writing RR-Type Instructions                                                                                                        | 25     |
|-------------------------------------------------------------------------------------------------------------------------------------|--------|
| Assembler must generate machine language form of the instruction                                                                    | :      |
| OPCODE R <sub>1</sub> R <sub>2</sub>                                                                                                |        |
| <ul> <li>R<sub>1</sub> and R<sub>2</sub> designate first and second operand registers, not genera<br/>registers 1 and 2!</li> </ul> |        |
| • Since LR opcode is X'18':                                                                                                         |        |
| LR 7,3 assembles to X'1873'                                                                                                         |        |
| <ul> <li>Operands can be written as any expression with value</li> <li>0 ≤ value ≤ 15</li> </ul>                                    |        |
| LR 3*4-5,1+1+1 also assembles to X'1873'                                                                                            |        |
| - Assembly-time operands are expressions with value "7" and "3"                                                                     |        |
| - Execution-time operands are contents of general registers GR7 and GR3                                                             |        |
|                                                                                                                                     |        |
|                                                                                                                                     |        |
| Chap. III, Sec. 9.2 System z Assembler Language ©IB                                                                                 | A 2015 |

|        |                                   | e some commonly used                                                                                                                                                                         | הא-ני            | pe msu                |                      |
|--------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------|----------------------|
| Dp     | Mnem                              | Instruction                                                                                                                                                                                  | Ор               | Mnem                  | Instruction          |
| 42     | STC                               | Store Character                                                                                                                                                                              | 43               | IC                    | Insert Character     |
| 44     | EX                                | Execute                                                                                                                                                                                      | 45               | BAL                   | Branch And Link      |
| 46     | вст                               | Branch On Count                                                                                                                                                                              | 47               | BC                    | Branch On Condition  |
| 4D     | BAS                               | Branch And Save                                                                                                                                                                              | 50               | ST                    | Store                |
| 54     | Ν                                 | AND                                                                                                                                                                                          | 55               | CL                    | Compare Logical      |
| 56     | 0                                 | OR                                                                                                                                                                                           | 57               | Х                     | Exclusive OR         |
| 58     | L                                 | Load                                                                                                                                                                                         | 59               | С                     | Compare              |
| δA     | А                                 | Add                                                                                                                                                                                          | 5B               | S                     | Subtract             |
| 5C     | М                                 | Multiply                                                                                                                                                                                     | 5D               | D                     | Divide               |
| δE     | AL                                | Add Logical                                                                                                                                                                                  | 5F               | SL                    | Subtract Logical     |
| S<br>( | Second o<br>"expr <sub>1</sub> (e | uction first operand field<br>operand field described a<br>xpr <sub>2</sub> )" form), as D <sub>2</sub> (X <sub>2</sub> ,B <sub>2</sub> )<br>expr <sub>1</sub> ((,expr <sub>3</sub> )" form) | s S <sub>2</sub> | ("expr <sub>1</sub> " | form), as $S_2(X_2)$ |

| w   | /riting RX-Type Instru                                                                                                                 | ctions                                                                          | 27         |
|-----|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|------------|
| •   | ·                                                                                                                                      | rate machine language form of the ins                                           | struction: |
| •   | First operand designa<br>Second operand usua<br>- B <sub>2</sub> , D <sub>2</sub> , and X <sub>2</sub> compor<br>address (as described | lly designates a memory reference<br>ents used at execution time to calculate m | emory      |
| •   | Since L opcode is $X'5$                                                                                                                |                                                                                 |            |
|     | 58 1 9                                                                                                                                 | · · ·                                                                           |            |
|     | L 1,200(,12                                                                                                                            | ) will generate                                                                 |            |
|     | 58 1 0                                                                                                                                 | 0C8                                                                             |            |
| Cha | ap. III, Sec. 9.4                                                                                                                      | System z Assembler Language                                                     | © IBM 2015 |

| Explicit a                 | nd Implied Addre                                                            | esses                                                           |                                         | 28 |
|----------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------|-----------------------------------------|----|
|                            | ys to create an ac                                                          | •                                                               | •                                       |    |
| •                          | licit: you specify the<br>ou provide the values ir                          | •                                                               | isplacement                             |    |
| - Y                        | licit: The Assembler<br>ou specify an operand o<br>ddress resolution (desci | of the form $S_2$ or $S_2(X_2)$                                 | • •                                     | -  |
| <ul> <li>Exampl</li> </ul> | es of explicit addr                                                         | esses:                                                          |                                         |    |
|                            | 8 IC 0,11                                                                   | $28(10,7)$ $D_2=1128$ $28(0,7)$ $D_2=1128$ $28(7,0)$ $D_2=1128$ | 3, X <sub>2</sub> =0, B <sub>2</sub> =7 |    |
| Genera                     | I forms of RX-inst                                                          | ruction second op                                               | erands:                                 |    |
|                            |                                                                             | Explicit Address                                                | Implied Address                         |    |
|                            | Not Indexed                                                                 | D <sub>2</sub> (,B <sub>2</sub> )                               | S <sub>2</sub>                          |    |
|                            | Indexed                                                                     | $D_2(X_2, B_2)$                                                 | S <sub>2</sub> (X <sub>2</sub> )        |    |
| Chap. III, Sec. 9          |                                                                             | ystem z Assembler Langua                                        |                                         |    |

|    | Inese             | are s | some typical RS- and SI-t    | ype   | Instru | ctions | 5:                           |
|----|-------------------|-------|------------------------------|-------|--------|--------|------------------------------|
| Ор | Mnem <sup>•</sup> | Гуре  | Instruction                  | Ор    | Mnem   | Туре   | Instruction                  |
| 90 | STM               | RS    | Store Multiple               | 91    | ТМ     | SI     | Test Under Mask              |
| 92 | MVI               | SI    | Move Immediate               | 94    | NI     | SI     | AND Immediate                |
| 95 | CLI               | SI    | Compare Logical<br>Immediate | 96    | 01     | SI     | OR Immediate                 |
| 97 | XI                | SI    | Exclusive OR Immediate       | 98    | LM     | RS     | Load Multiple                |
| 88 | SRL               | RS    | Shift Right Single Logical   | 89    | SLL    | RS     | Shift Left Single<br>Logical |
| 8A | SRA               | RS    | Shift Right Single           | 8B    | SLA    | RS     | Shift Left Single            |
| 8C | SRDL              | RS    | Shift Right Double Logical   | 8D    | SLDL   | RS     | Shift Left Double<br>Logical |
| 8E | SRDA              | RS    | Shift Right Double           | 8F    | SLDA   | RS     | Shift Left Double            |
| _  | Manu              |       | to write their energed fir   | اطما  |        |        |                              |
| •  | Many              | ways  | to write their operand fie   | elds! |        |        |                              |

| _ | riting RS | 71                                   |                                                  |                            | -                                                                                                                                               |   |
|---|-----------|--------------------------------------|--------------------------------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|---|
| • | RS-type   | instru                               | uctions h                                        | nave tv                    | wo operand forms:                                                                                                                               |   |
|   | - "RS-1"  | form,                                | , one reg                                        | ister: F                   | $R_1, D_2(B_2)$ or $R_1, S_2$                                                                                                                   |   |
|   | - "RS-2"  | form                                 | , two regi                                       | sters:                     | $R_1, R_3, D_2(B_2)$ or $R_1, R_3, S_2$                                                                                                         |   |
| • | Assembl   | er mu                                | ust gene                                         | rate m                     | nachine language form of the instruction:                                                                                                       |   |
| ſ | opcode    | R1                                   | R3                                               | B2                         | D2                                                                                                                                              |   |
| , | R, opera  | nd de                                | esignate                                         | s a ge                     | neral register; R3 operand can sometime                                                                                                         | s |
| • | be omitte | ed; D                                | <sub>2</sub> (B <sub>2</sub> ) ope               | erand o                    | can be a memory reference or a number                                                                                                           | s |
| • | - ·       | ed; D<br>s of F<br>SRA<br>SLDL<br>LM | 2(B2) ope<br>RS-type<br>11,2<br>6,N<br>14,12,12( | erand o<br>instruc<br>(13) | can be a memory reference or a number                                                                                                           | s |
| • | be omitte | ed; D<br>s of F<br>SRA<br>SLDL<br>LM | 2(B2) ope<br>RS-type<br>11,2<br>6,N<br>14,12,12( | erand o<br>instruc<br>(13) | can be a memory reference or a number<br>ctions:<br>Explicit address (RS-1 form)<br>Implied address (RS-1 form)<br>Explicit address (RS-2 form) | s |

|     | ting SI-Ty                              | •                        |                         | guage form of the                        | 3<br>instruction: |
|-----|-----------------------------------------|--------------------------|-------------------------|------------------------------------------|-------------------|
| r   | DPCODE I                                | TT-                      | D <sub>2</sub>          | 33- · · · · · · · · · · · · · · · · ·    |                   |
| • C | D <sub>1</sub> (B <sub>1</sub> ) (first | ) operand                | designates an ad        | dress-specification                      |                   |
| s s | Second $(I_2)$                          | operand i                | s an <i>immediate</i> o | perand                                   |                   |
| • @ | General for                             | ms of SI-i               | nstruction operan       | ds:                                      |                   |
|     |                                         |                          | Explicit Address        | Implied Address                          |                   |
|     |                                         | SI                       | $D_1(B_1),I_2$          | S <sub>1</sub> ,I <sub>2</sub>           |                   |
| • E | Examples o                              | of SI-type               | instructions            |                                          |                   |
|     | MVI                                     | [ 0(6),C'*<br>[ Buffer,C |                         | D <sub>1</sub> (B <sub>1</sub> ) address |                   |
|     | 02.                                     |                          |                         | 1                                        |                   |
|     |                                         |                          |                         |                                          |                   |
|     |                                         |                          | System z Assembler      |                                          |                   |

| D5     CLC     1     Compare Logical     D6     OC     1     OR       D7     XC     1     Exclusive OR     DC     TR     1     Translate |    |
|------------------------------------------------------------------------------------------------------------------------------------------|----|
| D5     CLC     1     Compare Logical     D6     OC     1     OR       D7     XC     1     Exclusive OR     DC     TR     1     Translate |    |
| D7 XC 1 Exclusive OR DC TR 1 Translate                                                                                                   |    |
|                                                                                                                                          |    |
| E0 SBP 2 Shift And Bound E1 MVO 2 Move With Offs                                                                                         |    |
|                                                                                                                                          | et |
| F2 PACK 2 Pack F3 UNPK 2 Unpack                                                                                                          |    |
| F8 ZAP 2 Zero And Add F9 CP 2 Compare                                                                                                    |    |
| FA AP 2 Add FB SP 2 Subtract                                                                                                             |    |
| FC MP 2 Multiply FD DP 2 Divide                                                                                                          |    |

| The    | Assemt          | oler gene                     | erate          | s two fo          | orms                            | of SS-t                        | ype machi                                      | ne instruc           | ction:           |
|--------|-----------------|-------------------------------|----------------|-------------------|---------------------------------|--------------------------------|------------------------------------------------|----------------------|------------------|
| OPCODE | L               | 1 <sup>B</sup> 1              |                | D <sub>1</sub>    | B <sub>2</sub>                  | D <sub>2</sub>                 | ONE LE                                         | NGTH FIELD ("S       | S-1")            |
| OPCODE | L <sub>1</sub>  | L <sub>2</sub> B <sub>1</sub> |                | D1                | B2                              | D <sub>2</sub>                 | TWO LE                                         | NGTH FIELDS ("       | SS-2")           |
| • Addr | esses a         | a <i>nd</i> leng              | ths c          | an both           | ı be s                          | specifie                       | d explicitly                                   | or implic            | citly.           |
|        | S               | S-1 Form                      |                | Explici           | it Add                          | resses                         | Implied Ad                                     | Idresses             |                  |
|        | Exp             | licit Leng                    | th             | D <sub>1</sub> (N | 1,B1),D                         | <sub>2</sub> (B <sub>2</sub> ) | S <sub>1</sub> (N <sub>1</sub>                 | ),S <sub>2</sub>     |                  |
|        | Imp             | lied Leng                     | th             | D <sub>1</sub> (, | B <sub>1</sub> ),D <sub>2</sub> | (B <sub>2</sub> )              | S <sub>1</sub> ,5                              | S <sub>2</sub>       |                  |
|        |                 | ples of S                     | SS-1           | form in           | struct                          | ions:                          | subtracts o<br>h and address                   |                      | n L <sub>1</sub> |
|        | CLC<br>TR<br>XC | Name (24                      | ),Rec<br>15),7 | Name E<br>(12) 1  | Explici<br>Implied              | it lengtl<br>1 length          | h, implied ac<br>, explicit ac<br>and addresse | ldresses<br>Idresses |                  |

| or i | mplied addresses             | ions, either or both op<br>or lengths<br>e of the possible operand |                                            | plicit |
|------|------------------------------|--------------------------------------------------------------------|--------------------------------------------|--------|
|      | SS-2 Form                    | Explicit Addresses                                                 | Implied Addresses                          |        |
|      | Explicit Lengths             | $D_1(N_1,B_1),D_2(N_2,B_2)$                                        | $S_1(N_1), S_2(N_2)$                       |        |
|      | Implied Lengths              | $D_1(,B_1),D_2(,B_2)$                                              | S <sub>1</sub> ,S <sub>2</sub>             |        |
|      | ZAP Sum(14),0<br>AP Total(15 | ) Num(12) Implied lengt                                            | s explicit addresses                       |        |
|      |                              |                                                                    | ns, explicit addresses<br>ns and addresses |        |





|              | i be io                                       | aded                                 | into me                                         | emory at address X'5000'                                                                                                                                                                     |
|--------------|-----------------------------------------------|--------------------------------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5000         |                                               | START                                | X'5000'                                         | STARTING LOCATION                                                                                                                                                                            |
| 5000         |                                               | BASR                                 | 6,0                                             | ESTABLISH BASE ADDRESS                                                                                                                                                                       |
| 5002<br>5006 | BEGIN                                         | A                                    |                                                 | LOAD CONTENTS OF N INTO GR2<br>ADD CONTENTS OF ONE                                                                                                                                           |
| 5000<br>500A |                                               | ST                                   | 2,0NE<br>2.N                                    | STORE CONTENTS OF GR2 INTO N                                                                                                                                                                 |
| 3004         | TWEN                                          |                                      |                                                 | ITIONAL BYTES OF INSTRUCTIONS, DATA, ETC                                                                                                                                                     |
| 5024         | N                                             | DC                                   | F'8'                                            | DEFINE CONSTANT WORD INTEGER 8                                                                                                                                                               |
| 5028         | ONE                                           | DC                                   | F'1'                                            | DEFINE CONSTANT WORD INTEGER 1                                                                                                                                                               |
| -            | The ler                                       | igth of                              | f each st                                       | tatement is added to its starting location (on the left)                                                                                                                                     |
| At           | <i>execu</i><br>Since t                       | <i>tion</i> t<br>he L i              | ime, aft<br>nstructio                           | tatement is added to its starting location (on the left)<br>ter the BASR is executed, $c(R6)=X'00005002'$<br>on wants to refer to the word at X'5024', its displacement<br>4'-X'5002'=X'022' |
| At<br>-      | <i>execu</i><br>Since t<br>from X'<br>So if w | tion t<br>he L i<br>5002 i<br>e crea | ime, aff<br>nstructio<br>is X'5024<br>ate an ac | ter the BASR is executed, $c(R6)=X'00005002'$<br>on wants to refer to the word at X'5024', its displacement                                                                                  |

| Compu                        | uting Displace                                   | ements (continued)                                                                                                                               | 38            |
|------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| • Sup                        | pose this fragn                                  | nent is to be loaded into memory at ad                                                                                                           | dress X'84E8' |
| 84E8<br>84EA<br>84EE<br>84F2 | BASR 6,0<br>BEGIN L 2,N<br>A 2,0NI<br>ST 2,N     | ESTABLISH BASE ADDRESS<br>LOAD CONTENTS OF N INTO GR2<br>E ADD CONTENTS OF ONE<br>STORE CONTENTS OF GR2 INTO N                                   |               |
| 850C<br>8510                 | — TWENTY-TWO (X'16')<br>N DC F'8'<br>ONE DC F'1' | ADDITIONAL BYTES OF INSTRUCTIONS, DATA, ETC<br>WORD INTEGER 8<br>WORD INTEGER 1                                                                  |               |
| - S                          | since the L instru                               | after the BASR is executed, c(R6)=X'C<br>ction wants to refer to the word at X'850C',<br>350C'-X'84EA'=X'022'                                    |               |
| k                            | now that when th                                 | n addressing halfword X'6022' for the L inst<br>ne L is executed it will still refer to the corre<br>dressing halfwords yields this object code: |               |
| ADDRESS<br>84E8              | ASSEMBLED CONTEN                                 | <u>NTS</u>                                                                                                                                       |               |
| 84EA<br>84EE<br>84F2         | 58206022<br>5A206026<br>50206022                 |                                                                                                                                                  |               |
| 850C<br>8510                 | 00000008                                         |                                                                                                                                                  |               |
| 0010                         |                                                  |                                                                                                                                                  |               |

| Explicit B                               | Base an              | d Displa                                      | acement                                                                                                              | 39            |
|------------------------------------------|----------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------|---------------|
|                                          |                      |                                               | pesn't matter where the program i<br>d displacement explicitly:                                                      | s loaded, so  |
| LOCATION<br>0000<br>0002<br>0006<br>000A | <u>NAME</u><br>BEGIN | OPERATION<br>BASR<br>L<br>A<br>ST<br>22 BYTES | <u>OPERAND</u><br>6,0<br>2,X'022'(0,6)<br>2,X'022'(0,6)<br>2,X'022'(0,6)                                             |               |
| 0024<br>0028                             | N<br>ONE             | DC                                            | F'8'<br>F'1'                                                                                                         |               |
| · ·                                      | 0 1                  |                                               | nts can be hard work! So we help<br>symbols:                                                                         | the Assembler |
| LOCATION                                 | NAME                 | OPERATION                                     | OPERAND                                                                                                              |               |
| 0000<br>0002<br>0006<br>000A             | BEGIN                | BASR<br>L<br>A<br>ST<br>THE USUAL 2           | 6,0<br>2,N-BEGIN(0,6) (N-BEGIN = X'022')<br>2,N-BEGIN(0,6) (ONE-BEGIN = X'026')<br>2,N-BEGIN(0,6) (N-BEGIN = X'022') |               |
| 0024<br>0028                             | N<br>ONE             | DC<br>DC                                      | F'8'<br>F'1'                                                                                                         |               |
| <ul> <li>The As registe</li> </ul>       |                      | calcula                                       | tes displacements for us; we assig                                                                                   | gned the base |
| Chap. III, Sec. 1                        | 10.3                 |                                               | System z Assembler Language                                                                                          | ©IBM 2015     |

| The USING A                                                                   | ssembler Ins                                                                            | struction and Implied Addresses                                                                                                                 | 40        |  |  |  |  |
|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--|--|--|--|
| USI                                                                           | ING BEGIN,6                                                                             | two items: the symbol <b>BEGIN</b> and reg<br>Assume R6 will hold address of BEGIN                                                              | ister 6:  |  |  |  |  |
| <ul> <li>The Assembler uses this to assign displacements and bases</li> </ul> |                                                                                         |                                                                                                                                                 |           |  |  |  |  |
| • We now ca                                                                   | • We now can write the program with <i>implied</i> addresses:                           |                                                                                                                                                 |           |  |  |  |  |
| USI<br>BEGIN L<br>A<br>ST<br>* 22<br>N DC<br>ONE DC                           | SR 6,0<br>ING BEGIN,6<br>2,N<br>2,ONE<br>2,N<br>bytes<br>F'8'<br>F'1'<br>Assembler does | GR6 will hold execution address of BEGIN<br>Tell Assembler C(GR6)=address of BEGIN<br>Load c(N) into GR2<br>Add c(ONE) to GR2<br>STore sum at N |           |  |  |  |  |
| Chap. III, Sec. 10.4                                                          | S                                                                                       | ystem z Assembler Language                                                                                                                      | ©IBM 2015 |  |  |  |  |



| Location                                                                                                  |                                           | Statem                                                                           |                                                          | _ 111511100                                                                                   | tion named <b>BEGIN</b> :                                                                         |
|-----------------------------------------------------------------------------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| 0000                                                                                                      | 0D60                                      | Statem                                                                           | BASR<br>USING                                            | 6,0<br>BEGIN,6                                                                                |                                                                                                   |
| 0002<br>0006<br>000A                                                                                      | 58 <u>6</u> 06022<br>5A206026<br>50206022 | BEGIN                                                                            | L<br>A<br>St                                             |                                                                                               | ←Wrong register! (6, not 2)                                                                       |
| 0024<br>0028                                                                                              | 00000008<br>00000001                      | N<br>ONE                                                                         | DC<br>DC                                                 | <b>F'</b> 8′<br><b>F'</b> 1′                                                                  |                                                                                                   |
| <ul> <li>S</li> <li>Whe</li> <li>Whe</li> <li>Whe</li> <li>X'00</li> <li>Wor:</li> <li>a model</li> </ul> | 005028'!)                                 | d into mem<br>is fetched<br>is execute<br>is execute<br>to store int<br>xception | nory star<br>, c(GR6<br>ed, c(GF<br>ed, its E<br>to memo | ting at add<br>) = X'0000<br>(6) = X'000<br>(ffective Add<br>(ffective Add)<br>(ffective Add) | dress X'5000'<br>5002'<br>)00008'<br>dress is X'0000002E' (not<br>ess X'0000002A', probably causi |

| Calculating Displacements: Assembly Process, Pass 1 43                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>The Assembler scans the program twice; the first time ("Pass 1"): <ul> <li>Each statement is read</li> <li>Lengths of instructions, data, and reserved areas are determined, locations are assigned</li> <li>Symbols whose positions are known are given location values</li> <li>Some symbols may appear as operands before having a value</li> <li>No object code is generated in Pass 1</li> </ul> </li> <li>At END statement, all symbols and values should be known ("defined") <ul> <li>If not, various diagnostic messages are created</li> </ul> </li> </ul> |
| Chap. III, Sec. 10.7 System z Assembler Language © IBM 2015                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Calculating Displacements: Assembly Process, Pass 2                                                                                  | 44         |
|--------------------------------------------------------------------------------------------------------------------------------------|------------|
| • Values of expressions can be calculated from known symbol value                                                                    | es         |
| • USING statement data is entered in the USING Table. For example                                                                    | <b>e</b> : |
| BASEREG         BASE_LOCATION         RA           6         00000002         01                                                     |            |
| <ul> <li>For instructions with implied addresses:</li> <li>displacement = (implied_address value) - (base_location value)</li> </ul> |            |
| <ul> <li>Relocatability Attribute (RA) of an implied address expression must match F<br/>a USING Table entry</li> </ul>              | RA of      |
| • If successful, the Assembler has <i>resolved</i> the implied address.<br>If not, the implied address is <i>not addressable</i>     |            |
| • The Assembler does at assembly time the reverse of what the CP does at execution time:                                             | U          |
| Assembly: displacement = (operand_location) - (base_location)<br>Execution: (operand address) = displacement + (base address)        |            |
| Chap. III, Sec. 10.8 System z Assembler Language ©I                                                                                  | BM 2015    |

| Multipl                           | e US                 | ING T                    | able En                     | tries                      |                                                                                                                                                             | 45        |
|-----------------------------------|----------------------|--------------------------|-----------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| • Sup                             | pose                 | there i                  | s more                      | than one                   | USING statement:                                                                                                                                            |           |
|                                   | ation                | Stateme                  |                             |                            |                                                                                                                                                             |           |
| 0                                 | 000                  |                          | BASR<br>USING               | 6,0<br>*,6                 | Original USING statement                                                                                                                                    |           |
|                                   | 002<br>006           | BEGIN                    | L<br>USING<br>A<br>as befor | 2,N<br>*,7<br>2,ONE        | Added USING statement                                                                                                                                       |           |
| • The                             | r                    | T                        | le now lo                   | ooks like                  | this:                                                                                                                                                       |           |
|                                   | BASEREG              | BASE_LOC                 | ATION   RA                  |                            |                                                                                                                                                             |           |
|                                   | 6                    | 00000                    | 002 01                      |                            |                                                                                                                                                             |           |
|                                   | 7                    | 00000                    | 006 01                      |                            |                                                                                                                                                             |           |
| <ul><li>Wit</li><li>Wit</li></ul> | th regis<br>th regis | ter 6: X'(<br>ter 7: X'( | 00000028'<br>00000028'      | -X'00000002<br>-X'00000000 | two addressing halfwords are pos<br>2' = X'026' with addressing halfword<br>5' = X'022' with addressing halfword<br>a with the <i>smallest</i> displacement | X'6026'   |
| Chap. III, S                      | ec. 10.9             |                          |                             | System z Ass               | embler Language                                                                                                                                             | ©IBM 2015 |

| The DROP          | Ass     | embler Ir     | nstr     | uction                                        | 46        |
|-------------------|---------|---------------|----------|-----------------------------------------------|-----------|
|                   |         | SING Tabl     | <u> </u> | ntries, use the <b>DROP</b> statement         |           |
|                   |         | register      |          |                                               |           |
| - In the          |         | ous example   | <u> </u> | if we write                                   |           |
| - 111 (116        | •       | ROP 6         | 65,      | ii we wiite                                   |           |
| - then th         |         | ING Table I   | look     | s like this:                                  |           |
| [                 | BASEREG | BASE_LOCATION | RA       |                                               |           |
| -                 |         | EMPTY         |          |                                               |           |
| ŀ                 | 7       | 00000006      | 01       |                                               |           |
| entries a         |         |               | wr<br>RA | itten with <i>no</i> operand, all USING Table |           |
| -                 |         | EMPTY         | <br>     |                                               |           |
| -                 |         | EMPTY         |          |                                               |           |
| L                 | I       |               | L        | 1                                             |           |
| hap. III, Sec. 10 | .10     |               | Sys      | tem z Assembler Language                      | ©IBM 2015 |



| Resolu | utions  | s with Reg                                                                       | gister Zero                                                                                                             | 48             |
|--------|---------|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|----------------|
| • The  | Asse    | mbler has                                                                        | an implied USING Table entry for register                                                                               | 0:             |
|        | BASEREG | BASE_LOCATION                                                                    | RA                                                                                                                      |                |
|        | 0       | 00000000                                                                         | 00 (ABSOLUTE EXPRESSIONS HAVE RA = 00)                                                                                  |                |
|        |         | ETC.                                                                             |                                                                                                                         |                |
|        | emble   | · · ·                                                                            | absolute and (b) between 0 and 4095 in va<br>live it to an addressing halfword with base                                |                |
|        |         | LA 7,100<br>LA 7,4000                                                            | · · · · · · · · · · · · · · · · · · ·                                                                                   |                |
| • You  | I       | LA 7,4000                                                                        |                                                                                                                         | ) FAO'         |
| • You  | can s   | LA 7,4000                                                                        | 4000 = X'FAO', so addressing halfword = X'(<br>absolute base_location in a USING stateme<br>Base address = 400 = X'190' | ) FAO'         |
| - T    | can s   | LA 7,4000<br>specify an<br>LA 9,400<br>JSING 400,9<br>LA 3,1000<br>solutions are | 4000 = X'FAO', so addressing halfword = X'(<br>absolute base_location in a USING stateme<br>Base address = 400 = X'190' | ) FAO'<br>ent: |



| Chapter IV: Defining Constants and Storage Areas                                                                                                                                                              | 1  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| <ul> <li>Section 11 describes the Assembler's basic data definition instruction,<br/>DC ("Define Constant").</li> </ul>                                                                                       | ,  |
| • Section 12 discusses the most often-used data types, introduces the powerful constant-referencing mechanism provided by literals, and the LTORG instruction to control their position in your program.      | e  |
| <ul> <li>Section 13 demonstrates methods for defining and describing data<br/>areas in ways that simplify data manipulation problems, including the<br/>very useful DS, EQU, and ORG instructions.</li> </ul> |    |
| Chap. IV, Sec. 11-13 System z Assembler Language © IBM 20                                                                                                                                                     | 15 |





| DC Instruction Statements and Operands 4                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>DC statements can use all statement fields; "DC" and "operand(s)" are<br/>required</li> <li><a href="mailto:name"><a href="mailto:scale">name</a>&gt; </a></li> <li>DC  </li> <li><a href="mailto:remarks">remarks</a></li> </ul>                                                                                                                                                            |
| <ul> <li>Each operand may have up to 4 parts, in this order: <ol> <li>Duplication factor (optional; defaults to 1)</li> <li>Type (1 or 2 letters; required)</li> <li>Zero to several modifiers (optional)</li> <li>Nominal value in external representation, enclosed in delimiters (required) <ul> <li>Delimiters are apostrophes or parentheses, depending on type</li> </ul> </li> </ol></li></ul> |
| Chap. IV, Sec. 11.2 System z Assembler Language ©IBM 2015                                                                                                                                                                                                                                                                                                                                             |



| 71 10115 | jth modi | fier specifie          | es a constant's exact length (within limits)                                                     |
|----------|----------|------------------------|--------------------------------------------------------------------------------------------------|
|          |          |                        | llowed by a nonzero decimal integer or<br>osolute expression:                                    |
|          | Ln       | or                     | L(expr)                                                                                          |
| Examp    | oles:    |                        |                                                                                                  |
| A<br>B   |          | FL3'8'<br>FL(2*4–5)'8' | Generates X'000008' at current location<br>Generates X'000008' at current location               |
| C<br>D   |          | F'8'<br>FL4'8'         | Generates X'00000008' at next word boundary<br>Generates X'0000008' at current location          |
|          | ols A, B | - 0                    | en values of the LC where the constants are iven the LC value <i>after</i> bytes are skipped for |
|          | ated; sy | mbol <b>C</b> is gi    |                                                                                                  |
| gener    | ated; sy | mbol <b>C</b> is gi    |                                                                                                  |

| Duplication Factors and Multiple Operands                                                                                                       | 7         |
|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| <ul> <li>You can generate copies of a constant in several ways         <ul> <li>Multiple operands</li> <li>DC F'8', F'8'</li> </ul> </li> </ul> | s:        |
| - Multiple statements:                                                                                                                          |           |
| DC F'8'<br>DC F'8'<br>DC F'8'                                                                                                                   |           |
| - Duplication factors:                                                                                                                          |           |
| DC 3F'8'                                                                                                                                        |           |
| • Duplication factors can be used on each operand:                                                                                              |           |
| DC 2F'8',2F'29',F'71',3F'2' 8 word constants                                                                                                    |           |
|                                                                                                                                                 |           |
|                                                                                                                                                 |           |
|                                                                                                                                                 |           |
| Chap. IV, Sec. 11.5 System z Assembler Language                                                                                                 | ©1BM 2015 |

| <ul> <li>Almo<br/>comn</li> </ul> |                    | onstant types ac                  | cept multiple nominal values, separated b |
|-----------------------------------|--------------------|-----------------------------------|-------------------------------------------|
|                                   | DC                 | F'1,2,3,4,5'                      | Five word constants                       |
|                                   | DC                 | X'A,B,C,D,7'                      | Five one-byte constants                   |
|                                   | DC                 | <b>B</b> '001,010,011'            | Three one-byte constants                  |
| Many                              | consta             | nt types accept                   | embedded spaces for readability:          |
|                                   | DC                 | <b>F</b> '1 000 000 000'          | Easier than counting adjacent zeros       |
|                                   | DC                 | <b>X</b> '1 234 567 89 <b>A</b> ' | Five-byte constant                        |
|                                   | acter co<br>ominal |                                   | exception: a comma or a space is part of  |
|                                   | DC                 | <b>C</b> '1,2,3,4,5'              | One nine-byte constant                    |
|                                   | DC                 | <b>C</b> '1 2 3 4 5'              | <u>One</u> nine-byte constant             |
|                                   |                    |                                   |                                           |
|                                   |                    |                                   |                                           |

| Le  | ength Att       | ribut          | tes                            |                                                                                                        | 9    |
|-----|-----------------|----------------|--------------------------------|--------------------------------------------------------------------------------------------------------|------|
| •   | – Assigr        | ned by         |                                | Attribute (LA)<br>Assembler (most usually)<br>uctions is the length of the instruction                 |      |
|     | LOAD<br>BEGIN   | LR             | 7,3<br>2,N                     | LA of LOAD = 2<br>LA of BEGIN = 4                                                                      |      |
| •   |                 |                | •                              | tatements is the length of the <i>first</i> g duplication factors                                      |      |
|     | List            | DC<br>DC<br>DC | XL7' ABC'<br>3F'8'<br>F'1,2,3' | LA of Implied = 4<br>LA of Explicit = 7<br>LA of Multiple = 4<br>LA of List = 4<br>' LA of OddOnes = 1 |      |
| •   | For almo        | ost al         | I EQU stateme                  | nts, the Assembler assigns LA 1:                                                                       |      |
|     | R7              | Equ            | 7                              | LA of R7 = 1                                                                                           |      |
| Cha | ap. IV, Sec. 11 | 7              | Svete                          | m z Assembler Language ©IBM                                                                            | 2015 |

| D   | ecimal Expor                   | nents                                        |                                                                                                       | 10        |
|-----|--------------------------------|----------------------------------------------|-------------------------------------------------------------------------------------------------------|-----------|
| •   | - A Decimal<br>- Write "En"    | Exponent can simpli                          | e many trailing zeros<br>fy writing such constants<br>onzero) digits of the nominal value,<br>d zeros | where "n" |
|     |                                | F'1000000000'<br>F'1 000 000 000'<br>F'1 E9' |                                                                                                       |           |
| •   | You can eve                    | n write constants                            | with negative exponent values                                                                         | "n"       |
|     | HundredA DC<br>HundredB DC     | F'1E2'<br>F'1000E–1'                         | Generates X'00000064'<br>Generates X'00000064'                                                        |           |
| •   | Exponent mo                    | difiers apply to a                           | II nominal values in the operand                                                                      |           |
|     |                                |                                              | Constants for 100, 200, 300, 400<br>Constants for 100, 2000, 30, 400                                  |           |
| •   | Decimal expo<br>floating-point |                                              | ent modifiers are often used in                                                                       |           |
| Cha | ap. IV, Sec. 11.8              | System z                                     | Assembler Language                                                                                    | ©IBM 2015 |





| <u>A-</u> | Type ar             | nd Y-                             | Type Addre                                                      | ss Constants                                                                                                                   | 13     |
|-----------|---------------------|-----------------------------------|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--------|
| •         | – A-typ             | e defa                            | ults to word le                                                 | " "adcon") is useful in many contexts.<br>angth (explicit lengths 1, 2, 3, 4 bytes);<br>d length (explicit lengths 1, 2 bytes) |        |
|           | 21                  |                                   |                                                                 | e an absolute or relocatable expression:                                                                                       |        |
|           | R7<br>Expr1<br>Here | Equ<br>DC<br>DC<br>DC<br>DC<br>DC | 7<br>A(C'A'+48)<br>A(R7)<br>A(Expr1)<br>AL1(*-Expr1)<br>A(*+64) |                                                                                                                                |        |
| •         | Y-type<br>express   |                                   | ants are rare                                                   | ely used now, and only for absolute                                                                                            |        |
|           | Expr1               | DC<br>DC                          | Y(C'A'+48)<br>Y(R7)                                             | Generates $\textbf{X}'00\textbf{F1}',$ halfword aligned Generates $\textbf{X}'0007',$ halfword aligned                         |        |
|           | – Early             | (and                              | very small) ma                                                  | achines used relocatable 16-bit address constan                                                                                | its    |
| •         | The abi             | lity to                           | generate co                                                     | onstants from expressions is very powerfu                                                                                      | I      |
| Cha       | ıp. IV, Sec. 1      | 2.2-3                             | S                                                               | ystem z Assembler Language ©IBI                                                                                                | M 2015 |



|       | bace allocated for a constant i<br>modifier                        | s defined either by default or by a |
|-------|--------------------------------------------------------------------|-------------------------------------|
|       | constant is too small for the s<br>constant is too large for the s |                                     |
| The A | ssembler's actions in such ca                                      | ses depends on the constant type    |
| Туре  | Too Small                                                          | Too Large                           |
| F,H   | Pad with sign bits on left                                         | Truncate on left; error message     |
| A,Y   | Pad with sign bits on left                                         | Truncate on left; error message     |
| С     | Pad with spaces on right                                           | Truncate on right                   |
| В     | Pad with zero bits on left                                         | Truncate on left                    |
| Х     | Pad with zero digits on left                                       | Truncate on left                    |
|       |                                                                    |                                     |





| enhand<br>• Consta                  | cemen<br>ints (n           | ts have be<br>umeric, ad                                | dress-valued, cha                                        | nany Assembler<br>aracter) were extend<br>length, alignment                                                        | ed        |
|-------------------------------------|----------------------------|---------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|-----------|
|                                     | DC<br>DC                   | FD'1 E15'<br>Ad (C' ABC')                               | X'00038D7EA4C680(<br>X'0000000000C1C2(                   |                                                                                                                    |           |
| A type<br>U type<br>E type<br>if th | e exte<br>e exte<br>e exte | nsion conve<br>nsion conve<br>nsion gene<br>sembler's T | erts EBCDIC nom<br>erts EBCDIC nom<br>rates the original | ree representations<br>inal value to ASCII<br>inal value to Unicode<br>EBCDIC nominal va<br>n specifies an arbitra | lue, even |
|                                     | DC                         | C' ABC'<br>Ce' ABC'                                     | X' C1C2C3'<br>X' C1C2C3'                                 | EBCDIC (TRANSLATE-able<br>EBCDIC always                                                                            | 、         |

| Da | ta Storage Definition 19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •  | <ul> <li>Section 13 shows ways to define and organize data and work areas</li> <li>The DS ("Define Storage") instruction is similar to DC, but generates no object code</li> <li>The EQU ("Equate") instruction lets you assign values to symbols, or define similarities of one symbol to another</li> <li>The ORG ("Set Origin") instruction lets you adjust the position of the Location Counter</li> <li>With combinations of these instructions, you can define data structures that greatly simplify many programming tasks</li> </ul> |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| St  | orage A        | reas     | : The DS /    | Assembler Instruction                                                          | 20         |
|-----|----------------|----------|---------------|--------------------------------------------------------------------------------|------------|
| •   |                |          |               | C, except that (a) no object code is gene required in operands                 | rated,     |
|     |                | DS<br>DS | F<br>F'8′     | Both statements allocate 4 bytes of<br>uninitialized space on a word boundary  |            |
| •   | Multiple       | ope      | rands and     | values are allowed                                                             |            |
|     |                | DS<br>DS |               | ,C'ABC' Allocates 9 bytes, word aligned<br>Allocates 8 bytes, halfword aligned |            |
| •   | As with        | DC,      | gaps can a    | ppear due to boundary alignment                                                |            |
|     |                | DS<br>DS | F,X<br>F      | Allocate 5 bytes, word aligned<br>Skip 3 bytes for word alignment              |            |
| •   | Length         | Attrib   | outes of na   | mes are derived from first operand                                             |            |
|     | Area1<br>Area2 | DS<br>DS | 80C<br>CL80   | Allocate 80 bytes; LA of Area1 = 1<br>Allocate 80 bytes; LA of Area2 = 80      |            |
|     | - Both s       | staten   | nents allocat | e 80 bytes, unaligned                                                          |            |
|     |                |          |               |                                                                                |            |
| Cha | p. IV, Sec. 13 | 3 1      |               | System z Assembler Language                                                    | © IBM 2015 |



| The EQU Assembler Instruction         2                                                                                                                                                           | 2  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| <ul> <li>The basic form of EQU is</li> <li>symbol EQU expression</li> </ul>                                                                                                                       |    |
| <ul> <li>"symbol" receives the value, relocatability, and length of "expression"</li> <li>If we write</li> </ul>                                                                                  |    |
| A DC F'8'<br>B EQU A                                                                                                                                                                              |    |
| - Then B will have the same value, relocatability, and length attributes as A                                                                                                                     |    |
| • Assigning an absolute expression is very useful. For example:                                                                                                                                   |    |
| NItems EQU 75 Number of table items (Note: not F'75')<br>Count DC A(NItems) Constant with number of table items<br>Before DS (NItems)F Space for "NItems" words<br>After DS (NItems)F (Not "75F") |    |
| <ul> <li>If a change must be made to the size of the tables, only the EQU statement<br/>needs updating before re-assembly</li> </ul>                                                              |    |
| Chap. IV, Sec. 13.3 System z Assembler Language © IBM 20                                                                                                                                          | 15 |

| The EQU Asse                                              | mbler Instructio                                | on, Extended Syntax                                                                       | 23                 |
|-----------------------------------------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------|--------------------|
|                                                           | are used for cor                                | ts up to 5 operands<br>nditional assembly and macro<br>[,program-attribute,assembler-attr | ,                  |
| - value oper                                              | and: its value, reloc                           | atability, and length are assigne                                                         | d to <b>symbol</b> |
| length is a<br>value                                      | ssigned to <b>symbol</b> ,                      | overriding any previous length a                                                          | ssigned from       |
|                                                           | igned to <b>symbol</b> . If<br>be U ("Unknown") | no <b>type</b> operand is present, the                                                    | Assembler          |
|                                                           | ,                                               | ed with just the first two ope<br>mber example to use extend                              |                    |
| PhoneNum DS<br>AreaCode Equ<br>Prefix Equ<br>Local_No Equ | AreaCode+3,3,C'C'                               | Overlay Prefix                                                                            |                    |
| Chap. IV, Sec. 13.4                                       | System                                          | z Assembler Language                                                                      | ©IBM 2015          |



Notes

| Pa | arameter                               | izatio | on                                           |                                                                                                                                            | 25         |
|----|----------------------------------------|--------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------------|
| •  | constant                               | s, da  | ta areas, fie                                | small number of values to define and<br>eld lengths, offsets, etc.<br>neterization were shown on previous slides                           |            |
| •  | ,                                      |        | •                                            | modify, and write 80-byte records                                                                                                          |            |
|    | RecLen<br>InRec<br>WorkRec<br>OutRec   | DS     | 80<br>CL(RecLen)<br>CL(Reclen)<br>CL(RecLen) |                                                                                                                                            |            |
| •  |                                        |        | •                                            | anged, only the EQU statement needs upda<br>cords must be maintained in storage                                                            | ting       |
|    | NRecs<br>RecNum<br>StorRecs<br>LastRec | DS     |                                              | Number of records in storage<br>Constant with number of records allowed<br>RecLen) Space for all but one records<br>Last record in storage |            |
|    | - Chang                                | ing th | e number of                                  | records and the allocated space is a simple                                                                                                | e update   |
| •  |                                        |        |                                              | es <i>many</i> aspects of programming!<br>dability and understandability                                                                   |            |
| 0  | p. IV, Sec. 13                         | c      | 0                                            | system z Assembler Language                                                                                                                | © IBM 2015 |

| Consta                            | nts   | Depe     | ending on the Location                                          | Counter                  | 26         |
|-----------------------------------|-------|----------|-----------------------------------------------------------------|--------------------------|------------|
| <ul> <li>Addi<br/>prog</li> </ul> |       |          | tants usually refer to loc                                      | ations internal (or exte | rnal) to a |
| • They                            | / cai | n also   | be used to generate tak                                         | oles of constants        |            |
| - E:                              | xamp  | ole: tab | ole of byte integers from 0 to                                  | o 10:                    |            |
| Int                               | [b]   | DC<br>or | <b>FL1</b> '0,1,2,3,4,5,6,7,8,9,10'                             | Generates 0,1,9,10       |            |
| Int                               | [b]   | DC       | 11AL1(*-IntTbl)                                                 | Generates 0,1,9,10       |            |
|                                   |       |          | with a duplication factor a<br>e is <i>re-evaluated</i> as each |                          |            |
| - E:                              | kamp  | le: tab  | ole of byte integers from 10                                    | to 0:                    |            |
| Int                               | [b]2  | DC<br>or |                                                                 | Generates 10,9,1,0       |            |
| Int                               | [b12  | DC       | 11AL1(IntTb12-*+10)                                             | Generates 10,9,1,0       |            |
| <ul> <li>Very</li> </ul>          | cor   | nplex    | tables can be created u                                         | sing such techniques     |            |
| <ul> <li>Exer</li> </ul>          | cise  | : Whi    | ch IntTbls are easier to                                        | expand?                  |            |
|                                   |       |          |                                                                 |                          |            |

| xer | cise Soluti                                     | ons     |                                                                                                  | 27           |
|-----|-------------------------------------------------|---------|--------------------------------------------------------------------------------------------------|--------------|
| S   | lide 24                                         |         |                                                                                                  |              |
| -   |                                                 |         | s already at a doubleword boundary: then the offs<br>LC over existing object code or data areas. | et -2        |
| S   | lide 26                                         |         |                                                                                                  |              |
| -   |                                                 |         | 1-type constants only need to modify the duplicat alue as in the FL1-type constants.             | ion factor,  |
|     | <ul> <li>But for the<br/>duplication</li> </ul> |         | ble using $\ensuremath{\text{IntTbl2}}$ , you'll need to change the $+10$ to one .               | less than th |
|     | • A better w                                    | ay:     |                                                                                                  |              |
|     | NumInt2<br>IntTb12                              | •       | 11 Number of generated values<br>(NumInt2)AL1(IntTb12-*+NumInt2-1)                               |              |
|     | – Now, or                                       | nly the | EQU statement needs changing                                                                     |              |
|     |                                                 |         |                                                                                                  |              |
|     |                                                 |         |                                                                                                  |              |
|     |                                                 |         |                                                                                                  |              |
|     |                                                 |         |                                                                                                  |              |
|     |                                                 |         |                                                                                                  |              |



| General Register Data Transmission 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>This section describes instructions that move operands among general registers, and between general registers and memory</li> <li>Data operands can be 1, 2, 4, or 8 bytes long <ul> <li>For some instructions, operands can be 0-4 bytes long</li> </ul> </li> <li>Register operands can be 32 or 64 bits wide <ul> <li>For some instructions, operands can be 1-4 bytes long</li> </ul> </li> <li>Some instructions will sign-extend the high-order bit of a source operand to fit the length of the target register</li> <li>Some instructions can test the value of an operand, or complement its value</li> </ul> |
| Chap. V, Sec. 14 System z Assembler Language © IBM 2015                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Load and Store Instructions 3                                                                           |
|---------------------------------------------------------------------------------------------------------|
| The Load (L) and Store (ST) instructions move data from memory to a GR (L) and from a GR to memory (ST) |
| Both are RX-type instructions                                                                           |
| - The memory address is an indexed Effective Address                                                    |
| • Neither requires word alignment of the memory address                                                 |
| - But it's advisable for many reasons (performance, access exceptions,)                                 |
| <ul> <li>Only the right half of the GR (bits 32-63) is involved; bits 0-31 are<br/>ignored</li> </ul>   |
| • Examples:                                                                                             |
| L 7,-F'-97' c(GR7) replaced by X'FFFFF9F'<br>ST 7,Num c(NUM) replaced by c(GR7), GR7 unchanged          |
|                                                                                                         |
| Chap. V, Sec. 14.1 System z Assembler Language © IBM 2015                                               |

| <ul> <li>Rather than write         <ul> <li>L 1,A</li> <li>ST 1,B</li> <li>Z,A+4</li> <li>and</li> <li>ST 2,B+4</li> <li>ST 3,B+8</li> </ul> </li> <li>you can write         <ul> <li>LM 1,3,A</li> <li>and</li> <li>ST 1,3,B</li> </ul> </li> <li>The instruction format is         <ul> <li>LM (or STM) R<sub>1</sub>,R<sub>3</sub>,D<sub>2</sub>(B<sub>2</sub>) (explicit address)</li> <li>LM (or STM) R<sub>1</sub>,R<sub>3</sub>,S<sub>2</sub> (implied address)</li> </ul> </li> <li>The register contents are transmitted between GRs and successive words in memory, starting with the R<sub>1</sub> register and ending with the F register             <ul> <li>If R<sub>3</sub> is smaller than R<sub>1</sub> then GRs R<sub>1</sub>-15 are transmitted followed by GRs 0-</li> </ul> </li> </ul> |         | • •               |             | • • • •      |        | Store Multiple ( <b>STM</b> ) instructions | let                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------------|-------------|--------------|--------|--------------------------------------------|--------------------|
| L 2,A+4 and ST 2,B+4<br>L 3,A+8 ST 3,B+8<br>you can write<br>LM 1,3,A and STM 1,3,B<br>• The instruction format is<br>LM (or STM) R <sub>1</sub> ,R <sub>3</sub> ,D <sub>2</sub> (B <sub>2</sub> ) (explicit address)<br>LM (or STM) R <sub>1</sub> ,R <sub>3</sub> ,S <sub>2</sub> (implied address)<br>• The register contents are transmitted between GRs and successive<br>words in memory, starting with the R <sub>1</sub> register and ending with the F<br>register                                                                                                                                                                                                                                                                                                                                   | Rathe   | er th             | an write    |              |        |                                            |                    |
| <ul> <li>LM 1,3,A and STM 1,3,B</li> <li>The instruction format is         <ul> <li>LM (or STM) R<sub>1</sub>,R<sub>3</sub>,D<sub>2</sub>(B<sub>2</sub>) (explicit address)</li> <li>LM (or STM) R<sub>1</sub>,R<sub>3</sub>,S<sub>2</sub> (implied address)</li> </ul> </li> <li>The register contents are transmitted between GRs and successive words in memory, starting with the R<sub>1</sub> register and ending with the F register</li> </ul>                                                                                                                                                                                                                                                                                                                                                        |         | L                 | 2,A+4       | and          | ST     | 2,B+4                                      |                    |
| <ul> <li>The instruction format is         <ul> <li>LM (or STM) R<sub>1</sub>, R<sub>3</sub>, D<sub>2</sub>(B<sub>2</sub>) (explicit address)<br/>LM (or STM) R<sub>1</sub>, R<sub>3</sub>, S<sub>2</sub> (implied address)</li> </ul> </li> <li>The register contents are transmitted between GRs and successive words in memory, starting with the R<sub>1</sub> register and ending with the F register</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                         | you can | write             | e           |              |        |                                            |                    |
| <ul> <li>LM (or STM) R<sub>1</sub>, R<sub>3</sub>, D<sub>2</sub>(B<sub>2</sub>) (explicit address)<br/>LM (or STM) R<sub>1</sub>, R<sub>3</sub>, S<sub>2</sub> (implied address)</li> <li>The register contents are transmitted between GRs and successive words in memory, starting with the R<sub>1</sub> register and ending with the F register</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                |         | LM                | 1,3,A       | and          | STM    | 1,3,B                                      |                    |
| <ul> <li>LM (or STM) R<sub>1</sub>, R<sub>3</sub>, S<sub>2</sub> (implied address)</li> <li>The register contents are transmitted between GRs and successive words in memory, starting with the R<sub>1</sub> register and ending with the F register</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | • The i | nstru             | uction form | nat is       |        |                                            |                    |
| words in memory, starting with the ${\rm R}_{\rm 1}$ register and ending with the F register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                   |             |              |        |                                            |                    |
| – If ${\sf R}_3$ is smaller than ${\sf R}_1$ then GRs ${\sf R}_115$ are transmitted followed by GRs 0-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | words   | sin               |             |              |        |                                            |                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | – If F  | R <sub>3</sub> is | smaller tha | n $R_1$ then | GRs R  | -15 are transmitted followed by GR         | s 0-R <sub>3</sub> |
| <ul> <li>These instructions are often used for "status preservation"</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | • These | e ins             | tructions   | are ofter    | n used | for "status preservation"                  |                    |







| CXICII   |                   |                                                                                               | operands need n   | ot diffor |
|----------|-------------------|-----------------------------------------------------------------------------------------------|-------------------|-----------|
|          | Mnemonic          |                                                                                               | CC Values         |           |
|          | LR                | $c(GRR_1) \leftarrow c(GRR_2)$                                                                | Unchanged         |           |
|          | LTR               | $c(GR R_1) \leftarrow c(GR R_2)$                                                              | 0,1,2             |           |
|          | LCR               | c(GR R <sub>1</sub> ) ← −c(GR R <sub>2</sub> )                                                | 0,1,2,3           |           |
|          | LPR               | c(GR R <sub>1</sub> ) ←  c(GR R <sub>2</sub> )                                                | 0,2,3             |           |
|          | LNR               | c(GR R <sub>1</sub> ) ← - c(GR R <sub>2</sub> )                                               | 0,1               |           |
| CC<br>CC | = 1<br>= 2<br>= 0 | Result is zero<br>Result is negative, < 0<br>Result is positive, > 0<br>Result has overflowed |                   |           |
| Exam     | LR 0,             |                                                                                               | R1), CC unchanged |           |
|          |                   |                                                                                               | tot I'l'          |           |
|          | LTR 1,<br>LCR 2,  |                                                                                               |                   |           |



|      | nnemonic. (\ | are similar to the 32-bit<br>We sometimes use "GR" f<br>gisters.) The CC settings | or 32-bit register | s, and |
|------|--------------|-----------------------------------------------------------------------------------|--------------------|--------|
|      | Mnemonic     | Action                                                                            | CC Values          |        |
|      | LGR          | c(GG R <sub>1</sub> ) ← c(GG R <sub>2</sub> )                                     | Not changed        |        |
|      | LTGR         | c(GG R <sub>1</sub> ) ← c(GG R <sub>2</sub> )                                     | 0,1,2              |        |
|      | LCGR         | c(GG R <sub>1</sub> ) ← −c(GG R <sub>2</sub> )                                    | 0,1,2,3            |        |
|      | LPGR         | $c(GG R_1) \leftarrow  c(GG R_2) $                                                | 0,2,3              |        |
|      | LNGR         | c(GG R <sub>1</sub> ) ← - c(GG R <sub>2</sub> )                                   | 0,1                |        |
| Exam | ipies.       |                                                                                   |                    |        |



| <b>4</b> | sign-extended                                   |             | gg r <sub>1</sub> |
|----------|-------------------------------------------------|-------------|-------------------|
| 0        | ·                                               | 63          |                   |
|          | 32-bit second operand s                         |             | GR R <sub>2</sub> |
|          | 0                                               | 31          | 1                 |
| Mnemonic | Action                                          | CC Values   |                   |
| LGF      | c(GG R <sub>1</sub> ) ← c(Word in memory)       | Not changed |                   |
| LGFR     | $c(GG R_1) \leftarrow c(GR R_2)$                | Not changed |                   |
| LTGFR    | $c(GG R_1) \leftarrow c(GR R_2)$                | 0,1,2       |                   |
| LCGFR    | $c(GG R_1) \leftarrow -c(GR R_2)$               | 0,1,2       |                   |
| LPGFR    | c(GG R <sub>1</sub> ) ←  c(GR R <sub>2</sub> )  | 0,2         |                   |
| LNGFR    | c(GG R <sub>1</sub> ) ← - c(GR R <sub>2</sub> ) | 0,1         |                   |
| Example  | FR 0,1 IS EQUIVALENT TO LGFR 0,1<br>LGCR 0,0    | <b>I</b> *  |                   |





| Testing the Condition Code: Conditional Branching                                                                                                                                                                                                                                                                                                          | 15        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| <ul> <li>Many instructions set the value of the PSW's 2-bit Condition System Flags II IC C Pro-<br/>Flags II IC C Pro-<br/>Flags II IC C Pro-<br/>Flags II II C Pro-<br/>Flags II II C Pro-<br/>Flags II II Pro-<br/>Flags II II Pro-<br/>Flags III III III Pro-<br/>Flags IIII IIII IIIIIIIII Pro-<br/>Flags IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII</li></ul> |           |
| Chap. V, Sec. 15 System z Assembler Language                                                                                                                                                                                                                                                                                                               | ©IBM 2015 |





| Exa   | amples o     | of Co | nditional                   | Branch Instructions                                   | 18            |
|-------|--------------|-------|-----------------------------|-------------------------------------------------------|---------------|
| 1.    | Branch       | to XX | if the CC                   | s zero.                                               |               |
|       |              | BC    | 8,XX                        | $M_1 = B'1000'$                                       |               |
| 2.    | Branch       | to XX | if the CC i                 | s not 0.                                              |               |
|       |              | BC    | 7,XX                        | $M_1 = B'0111'$                                       |               |
| 3.    | Always       | brand | ch to the in                | struction whose address is contain                    | ed in GR14.   |
|       |              | BCR   | 15,14                       | M <sub>1</sub> = <b>B</b> '1111'                      |               |
|       | or           | BC    | 15,0(0,14)                  | M <sub>1</sub> = B'1111'                              |               |
|       |              |       | ask bits are<br>uncondition | 1, the CC value must match a 1-bit in th<br>al branch | ne mask; this |
| 4.    | Branch       | to XX | if the CC i                 | s 1 or 3.                                             |               |
|       |              | BC    | 5,XX                        | M <sub>1</sub> = <b>B</b> '0101'                      |               |
|       |              |       |                             |                                                       |               |
|       |              |       |                             |                                                       |               |
| Chap. | V, Sec. 15.3 |       | S                           | ystem z Assembler Language                            | ©IBM 2015     |





| RX Mnemonic | BB Mnemonic | Mask | Meaning                           |
|-------------|-------------|------|-----------------------------------|
| В           | BR          | 15   | Unconditional Branch              |
| BNO         | BNOR        | 14   | Branch if Not Ones or No Overflow |
| BNH         | BNHR        | 13   | Branch if Not High                |
| BNP         | BNPR        | 13   | Branch if Not Plus                |
| BNL         | BNLR        | 11   | Branch if Not Low                 |
| BNM         | BNMR        | 11   | Branch if Not Minus or Not Mixed  |
| BE          | BER         | 8    | Branch if Equal                   |
| BZ          | BZR         | 8    | Branch if Zero(s)                 |
| BNE         | BNER        | 7    | Branch if Not Equal               |
| BNZ         | BNZR        | 7    | Branch if Not Zero                |
| BL          | BLR         | 4    | Branch if Low                     |
| BM          | BMR         | 4    | Branch if Minus, or if Mixed      |
| вн          | BHR         | 2    | Branch if High                    |
| BP          | BPR         | 2    | Branch if Plus                    |
| во          | BOR         | 1    | Branch if Ones, or if Overflow    |
| NOP         | NOPR        | 0    | No Operation                      |

| • | This section describes instructions for 2's complement addition, subtraction, and comparison of many operand types                                                                        |
|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | - Between general registers                                                                                                                                                               |
|   | - Between general registers and memory                                                                                                                                                    |
|   | <ul> <li>Arithmetic and logical operations</li> </ul>                                                                                                                                     |
|   | - Halfword, word, and doubleword operands                                                                                                                                                 |
|   | - Mixed-length operands                                                                                                                                                                   |
|   | <ul> <li>If a source operand in a register or in memory is used as in an instruction whose<br/>target register is longer than the operand, the operand is extended internally:</li> </ul> |
|   | <ul> <li>arithmetic operands are sign-extended</li> <li>logical operands are extended with zeros.</li> </ul>                                                                              |
|   | <ul> <li>Add with carry, subtract with borrow</li> </ul>                                                                                                                                  |
| • | Considerable symmetry among related instruction groups                                                                                                                                    |
|   |                                                                                                                                                                                           |
|   |                                                                                                                                                                                           |

| Mnem       | Function                   | Mnem       | Function                                                             |
|------------|----------------------------|------------|----------------------------------------------------------------------|
| AH         | Add halfword from memory   | SH         | Subtract halfword from memory                                        |
| Α          | Add word from memory       | S          | Subtract word from memory                                            |
| AR         | Add word from $c(GR R_2)$  | SR         | Subtract word from c(GR R <sub>2</sub> )                             |
| Mnem<br>AG | Add doubleword from memory | Mnem<br>SG | Subtract doubleword from memory                                      |
|            |                            |            | Subtract doubleword from memory Subtract doubleword from $c(GG R_2)$ |

| peration                                                    | or instructions with 32- or 64                   | CC Setting and Meaning                                                                                                             |
|-------------------------------------------------------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| $c(GR R_1) = c(GR)$ $c(GR R_1) = c(GR)$ $c(GG R_1) = c(GG)$ | $R_1) \pm c(word in memory)$                     | 0: Result is zero; no overflow<br>1: Result is < zero; no overflow<br>2: Result is > zero; no overflow<br>3: Result has overflowed |
| L<br>A                                                      | 1,=F'2147483647' 231-1<br>1,=F'1'                | CC=3 (overflow)                                                                                                                    |
| L<br>S                                                      | 2,=F'2147483647' 231-1<br>2,=F'1'                | CC=2 (positive)                                                                                                                    |
| L<br>S                                                      | <b>3,=F'-2147483648'</b> -231<br><b>3,=F'</b> 1' | CC=3 (overflow)                                                                                                                    |
| LG<br>AGR                                                   | 4,=X'7000000 0000000'<br>4,4                     | CC=3 (overflow)                                                                                                                    |
| LG<br>SG                                                    | 5,=X'5000000 0000000'<br>5,=X'6000000 0000000'   | CC=1 (negative)                                                                                                                    |
|                                                             |                                                  |                                                                                                                                    |



| rithm                                                                                                                                                                                                                                                | Il arithmetic produces bitwise<br>etic operation; only the CC se<br>tructions with 32- and 64-bit o | ttings a | re                                | •                                                                                                                   |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|----------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------|--|
| Mnem                                                                                                                                                                                                                                                 | Function                                                                                            | Mnem     | Fur                               | nction                                                                                                              |  |
| AL                                                                                                                                                                                                                                                   | Add word from memory SL St                                                                          |          |                                   | otract word from memory                                                                                             |  |
| ALR                                                                                                                                                                                                                                                  | R Add word from c(GR R <sub>2</sub> ) SLR Subtract word from c(GR R <sub>2</sub> )                  |          |                                   | otract word from c(GR R <sub>2</sub> )                                                                              |  |
| ALG                                                                                                                                                                                                                                                  | Add doubleword from memory                                                                          | SLG      | Subtract doubleword from memory   |                                                                                                                     |  |
| ALGR                                                                                                                                                                                                                                                 | Add doubleword from c(GG R <sub>2</sub> )                                                           | SLGR     | Subtract doubleword from c(GG R2) |                                                                                                                     |  |
|                                                                                                                                                                                                                                                      | e CC settings:                                                                                      |          |                                   | CC Setting and Meaning                                                                                              |  |
| $\begin{array}{l} \hline \textbf{Operation} \\ \hline c(GR R_1) = c(GR R_1) \pm c(GR R_2) \\ c(GR R_1) = c(GR R_1) \pm c(word in memory) \\ c(GG R_1) = c(GG R_1) \pm c(GG R_2) \\ c(GG R_1) = c(GG R_1) \pm c(doubleword in memory) \\ \end{array}$ |                                                                                                     |          |                                   | 0: Zero result, no carry (Note)<br>1: Nonzero result, no carry<br>2: Zero result, carry<br>3: Nonzero result, carry |  |
| (                                                                                                                                                                                                                                                    | CC0 cannot occur for logical subtraction                                                            | • /      |                                   | · ·                                                                                                                 |  |

## Add With Carry, Subtract With Borrow

| Mnem  | Function  |         |                           |                                                                                                     | Mnem                                                 | Function                                       |  |
|-------|-----------|---------|---------------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------|--|
| ALC   | Add word  | from m  | emory                     |                                                                                                     | SLB                                                  | Subtract word from memory                      |  |
| ACLR  | Add word  | from c( | GR R <sub>2</sub> )       |                                                                                                     | SLBR                                                 | Subtract word from c(GR R <sub>2</sub> )       |  |
| ALCG  | Add doubl | eword f | rom memory                |                                                                                                     | SLBG                                                 | Subtract doubleword from memory                |  |
| ALCGR | Add doubl | eword f | rom c(GG R <sub>2</sub> ) |                                                                                                     | SLBGR                                                | Subtract doubleword from c(GG R <sub>2</sub> ) |  |
|       |           | AL      | 0,1,A<br>1,B+4            | Load A in register pair<br>Logically add low-order part of B<br>Add high-order part of B with carry |                                                      |                                                |  |
|       |           | ALC     | 0,B                       | Add hi                                                                                              | gh–orde                                              | r part of B with carry                         |  |
|       |           |         |                           | Add hi<br>Store<br>Get fi<br>Logica<br>Subtra                                                       | gh-orden<br>the dou<br>rst ope<br>lly sub<br>ct high | r part of B with carry<br>ble-length sum       |  |

27

Notes

|       | With sign bits for arithmetic instruct<br>With zero bits for logical instruction |       |                                                  |
|-------|----------------------------------------------------------------------------------|-------|--------------------------------------------------|
| For   | these instructions, the first op                                                 | erand | is in 64-bit register GG ${ m R}_{_1}$           |
| Mnem  | Function                                                                         | Mnem  | Function                                         |
| AGF   | Add word from memory                                                             | SGF   | Subtract word from memory                        |
| AGFR  | Add word from c(GR R <sub>2</sub> )                                              | SGFR  | Subtract word from c(GR R <sub>2</sub> )         |
| CGF   | Compare to word from memory                                                      | CGFR  | Compare to word from c(GR R <sub>2</sub> )       |
| ALGF  | Logical add word from memory                                                     | SLGF  | Logical subtract word from memory                |
| ALGFR | Logical add word from c(GR R <sub>2</sub> )                                      | SLGFR | Logical subtract word from c(GR R <sub>2</sub> ) |
| The   | ese instructions can simplify pr                                                 | ogram | s with mixed-length operands                     |

| Mnemonic  | Function                                                                 |  |  |  |  |
|-----------|--------------------------------------------------------------------------|--|--|--|--|
| CL        | Logical compare c(GR R <sub>1</sub> ) to word from memory                |  |  |  |  |
| CLR       | Logical compare c(GR R <sub>1</sub> ) to word from c(GR R <sub>2</sub> ) |  |  |  |  |
| CLG       | Logical compare c(GG R <sub>1</sub> ) to doubleword from memory          |  |  |  |  |
| CLGR      | Logical compare $c(GG R_1)$ to doubleword from $c(GG R_2)$               |  |  |  |  |
| CLGF      | Logical compare $c(GG R_1)$ to zero-extended word from memory            |  |  |  |  |
| CLGFR     | Logical compare $c(GG R_2)$ to zero-extended word from $c(GR R_2)$       |  |  |  |  |
| CLM, CLMY | Logical compare bytes from low half of c(GG $R_1$ ) to bytes in memory   |  |  |  |  |
| CLMH      | Logical compare bytes from high half of $c(GG R_1)$ to bytes in memory   |  |  |  |  |
| The CC    | settings are the same as for other logical comparisons                   |  |  |  |  |



| SLL     Shift left logical     SRL     Shift right logical       RLL     Rotate loft logical |   |
|----------------------------------------------------------------------------------------------|---|
|                                                                                              |   |
|                                                                                              |   |
| SLA Shift left arithmetic SRA Shift right arithmetic                                         |   |
| SLDL         Shift left double logical         SRDL         Shift right double logical       |   |
| SLDA         Shift left double arithmetic         SRDA         Shift right double arithmetic |   |
| Mnem Action Mnem Action                                                                      |   |
| SLLG Shift left logical SRLG Shift right logical                                             |   |
|                                                                                              |   |
| RLLG Rotate loft logical                                                                     |   |
|                                                                                              | - |
|                                                                                              |   |
| RLLG Rotate loft logical                                                                     |   |

| Unit Shifts                                                                                                                                                                   | 32        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| • Assume an <b>n</b> -bit register looks like this:                                                                                                                           |           |
| A     B     C     D                                                                                                                                                           |           |
| A unit shift moves bits left or right by one position                                                                                                                         |           |
| Logical shifts:                                                                                                                                                               |           |
| $0 \rightarrow 0   A   B   C \rightarrow V   W   X   Y \rightarrow RIGHT LOGICAL$                                                                                             |           |
| Z BIT BUCKET                                                                                                                                                                  |           |
| ↓     B     C     D     E     ↓     X     Y     Z     0     ↓     0     LEFT LOGICAL       ↓     A     BIT BUCKET     BIT BUCKET     BIT BUCKET     BIT BUCKET     BIT BUCKET |           |
| - The Condition Code is unchanged                                                                                                                                             |           |
| Chap. V, Sec. 17.1 System z Assembler Language                                                                                                                                | ©IBM 2015 |









| Rotating Shifts                                                                                                                                              | 37                                               |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| A Rotating shift looks like this (compare slide 32)                                                                                                          |                                                  |
| • Like SLLG and SRLG, RLL and RLLG have three operands: $\rm R_{1},$ L 0,=A(X'56789ABC') Load initial data into GR0 RLL 1,0,10 Rotate 10 bits, result in GR1 | R <sub>3</sub> ,D <sub>2</sub> (B <sub>2</sub> ) |
| - Then c(GR1) = X'E26AF159'                                                                                                                                  |                                                  |
| LG 0,=AD(X'56789ABCDEF01234') Initialize GG0<br>RLLG 1,0,10 Rotate 10 bits, result in GG1                                                                    |                                                  |
| - Then c(GG1) = X'E26AF37BC048D159'                                                                                                                          |                                                  |
| • None of the rotating-shift instructions changes the CC                                                                                                     |                                                  |
| Chap. V, Sec. 17.5 System z Assembler Language                                                                                                               | ©IBM 2015                                        |

|     | alculated                         | 511           | it Amounts                     |                                                                                                 | 38         |
|-----|-----------------------------------|---------------|--------------------------------|-------------------------------------------------------------------------------------------------|------------|
| •   | Some sł                           | nift a        | mounts must l                  | be determined at execution time                                                                 |            |
| •   | Solution                          | : put         | the shift amo                  | unt in the $B_2$ register                                                                       |            |
|     |                                   | L<br>L<br>SLL | 9,ShiftAmt<br>0,Data<br>0,0(9) | Shift amount calculated previously<br>Get data to be shifted<br>Shift left by calculated amount |            |
|     | <ul> <li>Remend the sh</li> </ul> |               |                                | der 6 bits of the Effective Address are                                                         | used for   |
| •   | Example                           | : cal         | culate 2 <sup>N</sup> , whe    | $re 0 \leq N < 31$                                                                              |            |
|     |                                   | L<br>L<br>SLL | 1,N<br>0,=F'1'<br>0,0(1)       | Get small integer N<br>Put a 1-bit at right end of GRO (20)<br>Leave 2N in GRO                  |            |
|     | - Exerci                          | se: W         | hat will happen                | if $N \ge 31$ ?                                                                                 |            |
|     |                                   |               |                                |                                                                                                 |            |
|     |                                   |               |                                |                                                                                                 |            |
|     |                                   |               |                                |                                                                                                 |            |
| Cha | ap. V, Sec. 17.                   | 6             | Syst                           | iem z Assembler Language                                                                        | © IBM 2015 |

| Bit-Length Constants                                                                                    | 39          |
|---------------------------------------------------------------------------------------------------------|-------------|
| An extended form of length modifier lets you specify lengths in period (.) after the modifier ${\bm L}$ | bits: put a |
| DC FL3'8' and DC FL.24'8' are equivalent<br>(byte length) (bit length)                                  |             |
| <ul> <li>A nominal value can be any length (subject to normal trunc<br/>padding rules)</li> </ul>       | ation and   |
| DC FL.12'2047',FL.8'64',XL.4'D' generates X'7FF40D'                                                     |             |
| <ul> <li>Incomplete bytes are padded with zero bits:</li> </ul>                                         |             |
| DC FL.12'2047' generates X'7FF0'                                                                        |             |
| Bit-length constants are useful for tightly packed data                                                 |             |
|                                                                                                         |             |
| Chap. V, Sec. 17.7 System z Assembler Language                                                          | © IBM 2015  |

| Bi  | nary Multiplication and Division                                                                                                                | 40   |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------|------|
| •   | Multiplication notation:                                                                                                                        |      |
|     | MultiplicandFirst operand×MultiplierSecond operandProductSingle or double-length result                                                         |      |
|     | - Products can be as long as the sum of the operand lengths: 456 $\times$ 567 = 258552, or as short as the longer operand: 456 $\times$ 2 = 912 |      |
| •   | Multiplying single-length operands usually requires a double-length register pair                                                               |      |
| •   | Division notation:                                                                                                                              |      |
|     | QuotientDivisorDividendDividendDividend = first operandDivisor = second operandRemainder                                                        |      |
| •   | Division by a single-length divisor usually requires a double-length dividend, producing single-length quotient and remainder                   |      |
| •   | Multiply and divide instructions do not change the CC                                                                                           |      |
| Cha | ap. V, Sec. 18 System z Assembler Language ©IBM                                                                                                 | 2015 |



|            | en multiplying small values, you can use a single registe                                            |                  |                                   |                                        |  |  |  |
|------------|------------------------------------------------------------------------------------------------------|------------------|-----------------------------------|----------------------------------------|--|--|--|
| Mnem       |                                                                                                      |                  | Minem                             | Instruction                            |  |  |  |
| MH         | Multiply Halfword (32                                                                                | ←32×16)          |                                   |                                        |  |  |  |
| MS,<br>MSY | Multiply Single (32←3                                                                                | 32×32)           | MSR                               | Multiply Single Register<br>(32-32×32) |  |  |  |
| MSG        | Multiply Single (64←6                                                                                | 64×64)           | MSGR                              | Multiply Single Register<br>(64←64×64) |  |  |  |
| MSGF       | Multiply Single (64←6                                                                                | 64×32)           | MSGFR                             | Multiply Single Register<br>(64←64×32) |  |  |  |
| Exa        | MH 5,=H'100'<br>LH 1,N<br>MSR 1,1<br>LG 1,=FD'12345678'<br>MSG 1,=FD'12345678'<br>LG 1,=FD'12345678' | C(GG1) = 289589  | N <sup>2</sup><br>78<br>963907942 |                                        |  |  |  |
|            | L 5,=F'23456789'                                                                                     | C(GR5) = 2345678 | 39 (32 BITS!)                     |                                        |  |  |  |

|            | Instruction Mnem Instruction       |                    |             |                                                              |  |  |  |  |
|------------|------------------------------------|--------------------|-------------|--------------------------------------------------------------|--|--|--|--|
| Mnem       | Instruction                        |                    | Mnem        | Instruction                                                  |  |  |  |  |
| ML         | Multiply Log                       | ical (32+32←32×32) | MLR         | Multiply Logical Register<br>(32+32←32×32)                   |  |  |  |  |
| Mnem       | Instruction                        |                    | Mnem        | Mnem Instruction                                             |  |  |  |  |
|            |                                    | roducts of two 64- |             | Inem Instruction                                             |  |  |  |  |
| MLG        |                                    | ical (64+64←64×64) | MLGR        | Multiply Logical Register<br>(64+64←64×64)                   |  |  |  |  |
|            | I                                  |                    |             |                                                              |  |  |  |  |
| • Exa<br>* | amples:<br>Logical mul<br>L<br>MLR | 1,=F'-1'           | c(GR1) = X' | ) = 18446744065119617025<br>FFFFFFF<br>= X'FFFFFFE 00000001' |  |  |  |  |

| Di | vision Instructions 44                                                                                                                              |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| •  | Dividing a 2n-digit dividend by an n-digit divisor may not produce an n-digit quotient:                                                             |
|    | 987*867 = 855729; 855729/123 = 6957, remainder 18                                                                                                   |
| •  | If the attempted quotient is too big for a register, or a divisor is zero. a Fixed Point Divide Interruption always occurs (it can't be masked off) |
| •  | All binary division instructions require an even-odd register pair                                                                                  |
|    | - Dividends occupy either an even-odd pair or an odd register                                                                                       |
| •  | Quotient and remainder of a successful division:                                                                                                    |
|    | R <sub>1</sub> R <sub>1</sub> +1<br>Remainder Quotient                                                                                              |
|    |                                                                                                                                                     |
|    |                                                                                                                                                     |
|    |                                                                                                                                                     |
| _  | up. V. Sec. 18.5 System z Assembler Language ©IBM 2019                                                                                              |





| Mnem | ese instructions consider all op | Mnem     | 3                                                 |  |
|------|----------------------------------|----------|---------------------------------------------------|--|
| DL   | Divide Logical (32,32←32+32÷32)  | DLR      | Divide Logical Register<br>(32,32-32+32+32)       |  |
| DLG  | Divide Logical (64,64←64+64÷64)  | DLGR     | Divide Logical Register<br>(64,64←64+64÷64)       |  |
|      |                                  | GR1 to X | <b>K</b> ′00000000′                               |  |
| *    | DL 0,= $F'-1'$ Divi              |          | cally by X'FFFFFFFF'<br>1 remainder = X'FFFFFFFE' |  |
|      | DL 0,= $F'-1'$ Divi              | ient and | d remainder = X'FFFFFFFE'                         |  |

|          | Product length<br>(bits) |          | 32        | 32+32     |               | 64          | 64+64       |
|----------|--------------------------|----------|-----------|-----------|---------------|-------------|-------------|
| Function | Operand 1 length         |          | 32        | 32        | 64            |             | 64          |
|          | Operand 2 length         | 16       | 32        | 32        | 32            | 64          | 64          |
| A        | rithmetic ×              | МН       | MS<br>MSR | M<br>MR   | MSGF<br>MSGFR | MSG<br>MSGR |             |
|          | Logical ×                |          |           | ML<br>MLR |               |             | MLG<br>MLGR |
|          | Dividend lengt           | h (bits) | 32+32     |           | 64            |             | 64+64       |
| Function | Divisor len              | gth      |           | 32        |               | 64          |             |
| Tunction | Quotient & ren<br>length | nainder  | 32        | 64        |               | 64          | 64          |
|          | Arithmetic ÷             |          | D<br>DR   |           | DSG<br>DSGI   | ٢           |             |
|          | Logical ÷                |          | DL DSGF   |           |               |             | DLG<br>DLGR |

|     | usive OR<br>n operate:                  |       | ,       | tween | corr | espo  | nding  | pairs | of bit | s:   |      |  |
|-----|-----------------------------------------|-------|---------|-------|------|-------|--------|-------|--------|------|------|--|
|     | AND                                     | 0     | 1       |       | OR   | 0     | 1      |       | XOR    | 0    | 1    |  |
|     | 0                                       | 0     | 0       |       | 0    | 0     | 1      |       | 0      | 0    | 1    |  |
|     | 1                                       | 0     | 1       |       | 1    | 1     | 1      |       | 1      | 1    | 0    |  |
| The | eighboring<br>instructio<br>rs (later!) | ns he | ere ope | erate | only | on re | gister | s;    | trings | of b | ytes |  |

| Ins   | linuctions                                | WILLI 32-DI      | t operands:      |      |                            |  |  |
|-------|-------------------------------------------|------------------|------------------|------|----------------------------|--|--|
| Mnem  | Instructio                                | n                |                  | Mnem | Instruction                |  |  |
| N, NY | AND (32)                                  |                  |                  | NR   | AND Register (32)          |  |  |
| 0, 0Y | OR (32)                                   |                  |                  | OR   | OR Register (32)           |  |  |
| X, XY | Exclusive C                               | DR (32)          |                  | XR   | Exclusive OR Register (32) |  |  |
| OG    | OR (64)                                   |                  |                  | OGR  | OR Register (64)           |  |  |
| Mnem  | Instructio                                | n                |                  | Mnem | Instruction                |  |  |
| NG    | AND (64)                                  |                  |                  | NGR  | AND Register (64)          |  |  |
| XG    | Exclusive C                               | P (64)           |                  | XGR  | Exclusive OR Register (64) |  |  |
|       |                                           |                  |                  |      |                            |  |  |
|       | ch instruc                                | ction sets t     | he Condition     | Code | :                          |  |  |
| Ead   | Each instruction sets the Condition Code: |                  |                  |      |                            |  |  |
| Ead   |                                           | Operation        | CC setting       |      |                            |  |  |
| Ead   |                                           | Operation<br>AND | 0: all result bi |      |                            |  |  |

| Consider each operation, using identical operands: |                |                        |               |                  |               |        |            |     |
|----------------------------------------------------|----------------|------------------------|---------------|------------------|---------------|--------|------------|-----|
| Operation                                          | ANI            | <u>)</u>               | <u>0</u>      | R                | <u>xo</u>     | R      |            |     |
| Instruction                                        | NR             | 4,9                    | OR            | 4,9              | XR            | 4,9    |            |     |
| c(GR4)                                             | <b>X'</b> 0123 | 4567'                  | <b>X'</b> 012 | 34567'           | <b>X'</b> 012 | 34567' |            |     |
| c(GR9)<br>Result                                   |                | <b>6521</b> ′<br>4521′ |               | 96521′<br>B6567′ |               |        |            |     |
| Result                                             | A 0121         | -521                   |               | 00307            | A LUO         | 12070  |            |     |
| o see in mo<br>ourth hexade<br><u>AND</u>          |                |                        |               |                  |               |        | d, examine | the |
| 3 0011                                             | -              | 0011                   | -             | 0011             |               |        |            |     |
| <u>9 1001</u><br>1 0001                            | <u>9</u><br>B  | 1001<br>1011           |               | 1001<br>1010     |               |        |            |     |
| 1 0001                                             | Б              | 1011                   | ~             | 1010             |               |        |            |     |
|                                                    |                |                        |               |                  |               |        |            |     |
|                                                    |                |                        |               |                  |               |        |            |     |

| nteresting L               | Jses    | of Logical       | Instructions            |                                            | 5       |
|----------------------------|---------|------------------|-------------------------|--------------------------------------------|---------|
| 1. Exchange                | e the   | e contents of    | two registers:          |                                            |         |
| 0                          | XR      | 1,2              | 0                       |                                            |         |
|                            |         | 2,1              |                         |                                            |         |
|                            | XR      | 1,2              |                         |                                            |         |
| 2. Turn off                | the I   | rightmost 1-b    | it of a positive numb   | er X:                                      |         |
| Y = X                      | AND (   | X—1)             |                         |                                            |         |
| • Exampl                   | e:      |                  |                         |                                            |         |
|                            | L       | <b>0,=F</b> ′6′  | X in GRO                | <b>X</b> ′00000006′                        |         |
|                            | LR      | 1,0              | Copy X to GR1           |                                            |         |
|                            | S<br>NR | 1,=F'1'          | (X-1)                   | <b>X'</b> 00000005'<br><b>X'</b> 00000004' |         |
|                            |         | 1,0              | (X-1) AND X             | <b>X</b> 00000004                          |         |
| 3. Isolate th              |         | 5                | of a word               |                                            |         |
| Y = X                      | AND (   | —X)              |                         |                                            |         |
| <ul> <li>Exampl</li> </ul> | e:      |                  |                         |                                            |         |
|                            | L       | <b>0,=F'</b> 12' | X in GRO                | X'0000000C'                                |         |
|                            | LCR     | 1,0              | Copy -X to GR1          | X'FFFFFF4'                                 |         |
|                            | NR      | 1,0              | X AND (-X)              | <b>X</b> ′00000004′                        |         |
|                            |         |                  |                         |                                            |         |
| hap. V, Sec. 19.6          |         | Syst             | em z Assembler Language | ©                                          | IBM 201 |

| Chapter VI: Addressing, Immediate Operands, and Loops 1                                                                                                              |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| This chapter describes three useful and important topics:                                                                                                            |
| • Section 20 discusses ways the CPU can generate Effective Addresses, and how those addresses depend on the current addressing mode                                  |
| • Section 21 introduces instructions with <i>immediate</i> operands, where one of the operands of the instruction is contained in the instruction itself             |
| <ul> <li>Section 22 reviews instructions that help you manage loops: iterative<br/>execution of a block of instructions that perform some repeated action</li> </ul> |
|                                                                                                                                                                      |
|                                                                                                                                                                      |
| Chap. V, Sec. 20-22 System z Assembler Language © IBM 2015                                                                                                           |

| Se | ction 20: Address Generation and Addressing Modes                                                                                            |
|----|----------------------------------------------------------------------------------------------------------------------------------------------|
| •  | System z supports three types of address generation:                                                                                         |
|    | <ol> <li>base-displacement with unsigned 12-bit displacements</li> <li>This was described in Section 5</li> </ol>                            |
|    | <ol> <li>base-displacement with signed 20-bit displacements</li> <li>relative-immediate.</li> </ol>                                          |
| •  | and three addressing <i>modes</i> , which define the number of rightmost bits of an Effective Address that are actually used for addressing: |
|    | At any given moment, only one of 24-, 31-, or 64-bit modes is active                                                                         |
|    |                                                                                                                                              |
|    |                                                                                                                                              |
|    |                                                                                                                                              |
|    |                                                                                                                                              |



| Address Generation: Relative-Immediate Operands                                      | 4         |
|--------------------------------------------------------------------------------------|-----------|
| • Relative-immediate instructions have two basic formats:                            |           |
| OPCODE R1 OP R12                                                                     |           |
| OPCODE R1 OP R12                                                                     |           |
| • Address generation involves signed offsets:                                        |           |
| RI2<br>OPCODE, REGS SBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB                             |           |
| C SHIFT LEFT 1 BIT                                                                   |           |
| SIGN-EXTENDED + SBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB                                 |           |
| ADD TO<br>ADDRESS OF THE INSTRUCTION ITSELF (NOT THE PSW'S IA!)                      |           |
| EFFECTIVE ADDRESS                                                                    |           |
| - Addressing range is $\pm64\text{KB}$ (16-bit offset) or $\pm4\text{GB}$ (32-bit of | ffset)    |
| Chap. VI, Sec. 20.1.3 System z Assembler Language                                    | ©IBM 2015 |





| AMode24AMode31AMode64AModeLA<br>LAYEffective Address in<br>bits 40-63;<br>zero in bits 32-39;<br>bits 0-31 unchanged.Effective Address in<br>bits 33-63;<br>zero in bit 32;<br>bits 0-31 unchanged.Effective Address in<br>bits 0-31 unchanged.Effective Address in<br>bits 0-31 unchanged. | Function                      | Instruction | Re          | esult in R <sub>1</sub> general regis | ter        |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------|-------------|---------------------------------------|------------|
| AY Effective Address in bits 33-63; zero in bits 32-39; bits 0-31 unchanged. Effective Address in bits 0-63. Effective Address in bits 0-63.                                                                                                                                                |                               | Instruction | AMode = 24  | AMode = 31                            | AMode = 64 |
| LARL bits 0-31 unchanged. bits 0-31 unchanged.                                                                                                                                                                                                                                              | Load<br>Address<br>(based)    |             | bits 40-63; | bits 33-63;                           |            |
|                                                                                                                                                                                                                                                                                             | Load<br>Address<br>(relative) | LARL        |             |                                       | bits 0-63. |
|                                                                                                                                                                                                                                                                                             |                               |             |             |                                       |            |
|                                                                                                                                                                                                                                                                                             |                               |             |             |                                       |            |

| "Imme    | ediate" opera                  | ands are | part of           | the inst  | ruction itself                   |    |
|----------|--------------------------------|----------|-------------------|-----------|----------------------------------|----|
|          | ype was desc<br>he other opera |          |                   | ? (more a | bout them in Section 23          | 3) |
|          | RIL-types in                   |          |                   | erand     |                                  |    |
| RI       | PCODE R1 OP                    | 12       |                   |           |                                  |    |
| RIL      | PCODE   R1   OP                |          | 12                |           |                                  |    |
| Some     | instructions                   | affect a | n entire          | register  | , some only parts:               |    |
| <b>←</b> | HIGH HALF<br>GH HIGH HIGH      | LOW LO   | LOW HA<br>DW HIGH | LF        |                                  |    |
|          | нн н                           |          | LH                | LL        | 64-BIT R <sub>1</sub><br>GENERAL |    |
| 0        | 15 16                          | 31 32    | 47 48             | 63        | ⊣ REGISTER<br>3                  |    |
| - H =    | High Half; <b>H</b>            | L = High | Half's Lo         | w Half, e | tc.                              |    |



| Mnem  | Instruction                                   | Mnem  | Instruction                                  |
|-------|-----------------------------------------------|-------|----------------------------------------------|
| LHI   | Load Halfword Immediate (32←16)               | LGHI  | Load Halfword Immediate (64←16)              |
| LGFI  | Load Immediate (64←32)                        |       |                                              |
| LLIHF | Load Logical Immediate<br>(high) (64←32)      | LLILF | Load Logical Immediate<br>(low) (64←32)      |
|       |                                               |       |                                              |
| LIHH  | Load Logical Immediate<br>(high high) (64←16) | LLIHL | Load Logical Immediate<br>(high low) (64←16) |
|       |                                               |       | Lood Looical Immediate                       |
| LILH  | Load Logical Immediate<br>(Iow high) (64←16)  | LLILL | Load Logical Immediate<br>(low low) (64←16)  |

| Mnem                       | Instruction                                                                         | Mnem                          | Instruction                                                                                                         |  |  |  |
|----------------------------|-------------------------------------------------------------------------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------|--|--|--|
| AHI                        | Add Halfword Immediate (32←16)                                                      | AGHI                          | Add Halfword Immediate (64←16)                                                                                      |  |  |  |
| AFI                        | Add Immediate (32)                                                                  | AGFI                          | Add Immediate (64←32)                                                                                               |  |  |  |
| ALFI                       | Add Logical Immediate (32)                                                          | ALGFI                         | Add Logical Immediate (64←32)                                                                                       |  |  |  |
| SLFI                       | Subtract Logical Immediate (32) SLGFI Subtract Logical Immediate (64-32)            |                               |                                                                                                                     |  |  |  |
|                            | thmetic and logical compare in<br>Instruction<br>Compare Halfword Immediate (32-16) | nstructio<br>Мпет<br>сані     | DNS:<br>Instruction<br>Compare Halfword Immediate (64←16)                                                           |  |  |  |
| Mnem                       | Instruction<br>Compare Halfword Immediate (32←16)                                   | Mnem                          | Instruction<br>Compare Halfword Immediate (64←16)                                                                   |  |  |  |
| Mnem<br>CHI                | Instruction                                                                         | Mnem<br>CGHI                  | Instruction                                                                                                         |  |  |  |
| Mnem<br>CHI<br>CFI<br>CLFI | Instruction<br>Compare Halfword Immediate (32←16)<br>Compare Immediate (32)         | Mnem<br>CGHI<br>CGFI<br>CLGFI | Instruction<br>Compare Halfword Immediate (64←16)<br>Compare Immediate (64←32)<br>Compare Logical Immediate (64←32) |  |  |  |

| Inem | Instruction                       | Mnem | Instruction                      |
|------|-----------------------------------|------|----------------------------------|
| NIHF | AND Immediate (high) (64←32)      | NILF | AND Immediate (low) (64←32)      |
| NIHH | AND Immediate (high high) (64←16) | NIHL | AND Immediate (high low) (64←16) |
| NILH | AND Immediate (low high) (64←16)  | NILL | AND Immediate (low low) (64←16)  |
| OIHF | OR Immediate (high) (64←32)       | OILF | OR Immediate (Iow) (64←32)       |
| нніс | OR Immediate (high high) (64←16)  | OIHL | OR Immediate (high low) (64←16)  |
| DILH | OR Immediate (low high) (64←16)   | OILL | OR Immediate (low low) (64←16)   |
| XIHF | XOR Immediate (high) (64←32)      | XILF | XOR Immediate (low) (64←32)      |
|      |                                   |      |                                  |

|                         | Operand 1 | 32      | ? bits       | 64      | 64 bits        |  |
|-------------------------|-----------|---------|--------------|---------|----------------|--|
| Operation               | Operand 2 | 16 bits | 32 bits      | 16 bits | 32 bits        |  |
| Arithmetic Add/Subtract |           | AHI     | AFI          | AGHI    | AGFI           |  |
| Logical Add/Subtract    |           |         | ALFI<br>SLFI |         | ALGFI<br>SLGFI |  |
| Arithmetic              | c Compare | CHI     | CFI          | CGHI    | CGFI           |  |
| Logical                 | Compare   |         | CLFI         |         | CLGFI          |  |
| Mul                     | tiply     | MHI     |              | MGHI    |                |  |



| Branch Relative on Condition Instructions 15                                                                                               |
|--------------------------------------------------------------------------------------------------------------------------------------------|
| • The BRC and BRCL instructions have these formats:                                                                                        |
| A7 M1 4 RI2                                                                                                                                |
| - The branch target can be as far away as $-65536$ and $+65534$ bytes                                                                      |
| CO M1 4 RI2                                                                                                                                |
| <ul> <li>The branch target can be more than 4 billion bytes away from the branch<br/>instruction, in either direction</li> </ul>           |
| This means the offset of the branch target can be more than 4 billion bytes away from the RIL-type instruction, in either direction        |
| <ul> <li>The greatest advantage of these branch instructions is that no base<br/>register is needed for addressing instructions</li> </ul> |
| • Their extended mnemonics are described on slide 16                                                                                       |
| Chap. VI, Sec. 22.1 System z Assembler Language ©IBM 2015                                                                                  |

| forb<br>- To | ased bra<br>distingui | anch instru<br>sh them fror | ctions to<br>m based br | "BRC" an<br>anches, di | dding the same suffixes as<br>d "BRCL"<br>fferent prefixes are sometimes<br>g"). For example: |
|--------------|-----------------------|-----------------------------|-------------------------|------------------------|-----------------------------------------------------------------------------------------------|
| RI Mnem      | ionic                 | RIL Mner                    | nonic                   | Mask                   | Meaning                                                                                       |
| BRC          | JC                    | BRCL                        | JLC                     | Μ1                     | Conditional Branch                                                                            |
| BRU          | J                     | BRUL                        | JLU                     | 15                     | Unconditional Branch                                                                          |
| BRNO         | JNO                   | BRNOL                       | JLNO                    | 14                     | Branch if No Overflow                                                                         |
| BRNH         | JNH                   | BRNHL                       | JLNH                    | 13                     | Branch if Not High                                                                            |
| BRNP         | JNP                   | BRNPL                       | JLNP                    | 13                     | Branch if Not Plus                                                                            |
| BRNL         | JNL                   | BRNLL                       | JLNL                    | 11                     | Branch if Not Low                                                                             |
| BRNM         | JNM                   | BRNML                       | JLNM                    | 11                     | Branch if Not Minus                                                                           |
| BRE          | JE                    | BREL                        | JLE                     | 8                      | Branch if Equal                                                                               |
| :            | :                     | :                           | :                       | :                      |                                                                                               |
| BRP          | JP                    | BRPL                        | JLP                     | 2                      | Branch if Plus                                                                                |
| BRO          | 10                    | BROL                        | JLO                     | 1                      | Branch if Overflow                                                                            |



| Branc        | h on Cou                                  | Int Instructio                          | ns                         |                        |                                                                                                      | 18 |
|--------------|-------------------------------------------|-----------------------------------------|----------------------------|------------------------|------------------------------------------------------------------------------------------------------|----|
| Cou          | Int-contro                                | lled loops are                          | easily m                   | anage                  | d with these instructions                                                                            |    |
| Mnem         | Instruction                               | l                                       |                            | Mnem                   | Instruction                                                                                          |    |
| вст          | Branch on                                 | Count (32)                              |                            | BCTR                   | Branch on Count Register (32)                                                                        |    |
| BCTG         | Branch on                                 | Count (64)                              | E                          | BCTGR                  | Branch on Count Register (64)                                                                        |    |
| BRCT,<br>JCT | Branch Rel                                | ative on Count (32                      | 2)                         | BRCTG,<br>JCTG         | Branch Relative on Count (64)                                                                        |    |
| 3.           | If the resu<br>instruction<br>If the resu | lt is zero, do no<br>It is zero, brano  | ot branch;<br>ch to the in | fall thro<br>nstructic | ro, do nothing more<br>ugh to the next sequential<br>on at the Effective Address<br>n reverse order) |    |
| Rep          | XR<br>LA<br>Deat AR<br>BCT<br>ST          | 0,0<br>1,10<br>0,1<br>1,Repeat<br>0,Sum | Number<br>Add a<br>Reduce  | value to<br>counter    | the sum<br>ues to add<br>o the sum<br>r by 1, repeat if nonzero<br>ult for display                   |    |
|              |                                           |                                         |                            |                        | are ren arepray                                                                                      |    |





| For | all the | "Brand | ch on Index" i                                      | nstructions:                                                                                                                |
|-----|---------|--------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
|     | 1 ·     |        |                                                     | e increment is in $R_{\rm 3}$ , and the comparan ler bit forced to 1)                                                       |
| Exa | mples   |        |                                                     |                                                                                                                             |
| 1.  | Add the | numbe  | rs in a table wit                                   | h a two-instruction loop                                                                                                    |
|     | Add     | Α      | 0,0<br>1,1<br>2,3,=F'4,36'<br>0,Table(1)<br>1,2,Add | Add an integer from the table                                                                                               |
|     | Table   | <br>DC | <b>F</b> '1,2,3,4,5,6,7                             | ,8,9,10'                                                                                                                    |
| 2.  | Another | way to | do the same, a                                      | dding successive index values                                                                                               |
|     | Add     | AR     | 2,3,=F'1,10'                                        | Clear sum to zero<br>Initialize "index" to 1<br>Initialize increment and comparand<br>Add "index" to sum<br>Repeat 10 times |

| amples Us         | sing B                                    | ХН                             |                                                                                                                                                                 | 2 |
|-------------------|-------------------------------------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Examples          |                                           |                                | g from "bottom to top"<br>ith a two-instruction loop                                                                                                            |   |
| Add               | SR<br>LHI<br>A<br>BXH                     | 3,=F'-4'<br>0,Table(1)         | Clear sum to zero<br>Initialize index to 36 (last element)<br>Identical increment and comparand<br>Add an element of the table<br>Decrease index, compare to -4 |   |
| Table             | DC                                        | <b>F'</b> 3,1,4,1,5,9,         | 2,6,5,89'                                                                                                                                                       |   |
| 2. Calcula        | te a tab                                  | le of cubes of                 | the first 10 integers                                                                                                                                           |   |
| Mult              | LA<br>LA<br>LHI<br>MR<br>MR<br>ST<br>BCTR | 1,7<br>0,7<br>0,7<br>1,Cube(4) | Initial value of N is 10<br>Initial index = 36<br>Increment and comparand are -4<br>N<br>N squared<br>N cubed<br>Store in table<br>Decrease N by 1              |   |
|                   | BXH                                       | 4,5,Mult                       | Count down and loop                                                                                                                                             |   |
| ap. VI, Sec. 22.8 |                                           |                                | Assembler Language ©IBM                                                                                                                                         |   |

| Specialized Us            | ses c      | of BXLE and B         | КН                                                      | 23        |
|---------------------------|------------|-----------------------|---------------------------------------------------------|-----------|
| • BXH and BX              | LE c       | an do some inte       | resting things. Three examples:                         |           |
| 1. Branch to              | XXX        | if c(GR4) is $\leq$ 0 |                                                         |           |
|                           | XR<br>BXLE | 9,9<br>4,9,XXX        | Set GR9 to zero<br>Branch to XXX if c(GR4) is <= O      |           |
| and!                      |            |                       |                                                         |           |
|                           | XR<br>BXH  | 9,9<br>4,9,YYY        | Set GR9 to zero<br>Branch to YYY if c(GR4) is > O       |           |
| 2. If c(GR2)              | > 0, I     | oranch to XXX afte    | r adding 1 to c(GR2)                                    |           |
|                           | LHI<br>BXH | 7,1<br>2,7,XXX        | Initialize GR7 to +1<br>Increment c(GR2), branch to XXX |           |
| 3. If c(GR4)<br>doesn't o |            |                       | (GR5) by 1 and branch to ZZZ if the                     | e sum     |
|                           | BXH        | 5,4,ZZZ               |                                                         |           |
|                           |            |                       |                                                         |           |
|                           |            |                       |                                                         |           |
| Chap. VI, Sec. 22.9       |            | System z Ass          | embler Language 🧯                                       | ©IBM 2015 |

| hese instructions are describe | d in Section 22: |                      |
|--------------------------------|------------------|----------------------|
| Operation                      | Relative-Imme    | diate Operand Length |
| Operation                      | 16 bits          | 32 bits              |
| Branch on Condition (Relative) | BCR              | BCRL                 |
| On exettion                    | Regi             | ster Length          |
| Operation                      | 32 bits          | 64 bits              |
| Branch on Count (Register)     | BCTR             | BCTGR                |
| Branch on Count (Indexed)      | BCT              | BCTG                 |
| Branch on Count (Relative)     | BRCT             | BRCTG                |
| Branch on Index                | BXH<br>BXLE      | BXHG<br>BXLEG        |
| Branch on Index (Relative)     | BRXH<br>BRXLE    | BRXHG<br>BRXLG       |
|                                |                  |                      |





| nd 1 OR I <sub>2</sub> Yes               | Operand 1 ← I <sub>2</sub><br>Operand 1 ← Oper<br>Operand 1 ← Oper | MVI, MVIY<br>NI, NIY |                               | Move            |  |  |
|------------------------------------------|--------------------------------------------------------------------|----------------------|-------------------------------|-----------------|--|--|
| $\frac{1}{10R} \frac{1}{12} \frac{1}{2}$ |                                                                    |                      |                               | Move            |  |  |
| 2                                        | Operand 1 - Oper                                                   | INI, INI I           |                               | AND             |  |  |
| d 1 XOR I2 Yes                           | operanu I 🖣 oper                                                   | OI, OIY              |                               | OR              |  |  |
|                                          | Operand 1 🔶 Oper                                                   | XI, XIY              |                               | XOR             |  |  |
| to I <sub>2</sub> Yes                    | Operand 1 Compare                                                  | CLI, CLIY            |                               | Compare         |  |  |
| Operand 1 Yes                            | TM, TMY Test Selected Bits of Operand 1                            |                      |                               | Test Under Mask |  |  |
| nats.                                    |                                                                    |                      |                               | opcode          |  |  |
|                                          | _                                                                  |                      |                               |                 |  |  |
|                                          | DH opcode                                                          | DL                   | I <sub>2</sub> B <sub>1</sub> | opcode          |  |  |
|                                          |                                                                    |                      |                               |                 |  |  |
| nats                                     | SI- and SIY-type fo                                                |                      |                               |                 |  |  |

| Mnem | Instructio                  | 'n                           |  | Mnem | Instruction                                                                        |  |  |
|------|-----------------------------|------------------------------|--|------|------------------------------------------------------------------------------------|--|--|
| MVI  | Move Imm                    | rediate                      |  | MVIY | Move Immediate                                                                     |  |  |
|      | mples:<br>MVI<br>MVI<br>MVI | MVI X,O Set<br>MVI X,255 Set |  |      | the byte at X to all O-bits<br>the byte at X to all 1-bits<br>re EBCDIC blank at X |  |  |
|      | MVI<br>MVI                  | FlagByte,0<br>CrrgCtrl,C'1'  |  |      | bits to zero<br>age control for new page                                           |  |  |
|      |                             |                              |  |      |                                                                                    |  |  |

| Mnem       | Instr | uction                     |                                          |                                | Mnem                                                                            | Instruction                                                                         |  |  |
|------------|-------|----------------------------|------------------------------------------|--------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--|--|
| NI         | AND   | Immedia                    | ate                                      |                                | NIY                                                                             | AND Immediate                                                                       |  |  |
| 01         | OR Ir | nmediat                    | е                                        |                                | OIY                                                                             | OR Immediate                                                                        |  |  |
| XI         | XOR   | Immedia                    | ate                                      |                                | XIY                                                                             | XOR Immediate                                                                       |  |  |
|            | Ī     | AN                         | -                                        | 0: all result                  | bits are zer                                                                    | 0                                                                                   |  |  |
|            |       | AN<br>O<br>XC              | R                                        | 0: all result<br>1: result bit |                                                                                 | -                                                                                   |  |  |
| (a)        |       | 0                          | R<br>)R<br>X,0                           |                                | Same as 'N                                                                      | -                                                                                   |  |  |
| (a)<br>(b) |       | NI                         | X,0<br>X,255                             | 1: result bit                  | s are not all<br>Same as 'N<br>Sets bit 6<br>Same as 'N                         | zero<br>IVI X,0' except CC set to 0                                                 |  |  |
| (b)<br>(c) | owerA | NI<br>NI<br>OI<br>OI<br>OI | X,0<br>X,8'1<br>X,255<br>X,8'00<br>Lower | 1: result bit                  | Same as 'M<br>Sets bit 6<br>Same as 'M<br>Sets bit 6<br>Sets bit 6<br>c(LowerA) | Zero<br>MVI X,0' except CC set to 0<br>5 at X to 0<br>MVI X,255' except CC set to 1 |  |  |

| Mnem | Instruction  |          |              |          | Mnem     | Instruction                                |
|------|--------------|----------|--------------|----------|----------|--------------------------------------------|
| CLI  | Compare Im   | mediate  |              |          | CLIY     | Compare Immediate                          |
| The  | e first oper | rand is  | compa        | red logi | cally t  | o the second, to set the CC:               |
|      |              | С        | с            | I        | ndicatio | on                                         |
|      |              |          | )            | Op       | erand 1  | = 12                                       |
|      |              |          | I            | Op       | erand 1  | < 1 <sub>2</sub>                           |
|      |              | :        | 2            | Op       | erand 1  | > I <sub>2</sub>                           |
| Not  | e: The firs  | •        |              | •        |          | emory at the Effective Address             |
|      | CLI          | =C'A', 1 | (′ C1′       | = 00     | 0: c     | $(0perand 1) = I_2$<br>$(0perand 1) = I_2$ |
|      | CLI          |          |              |          |          | (Operand 1) = $I_2$<br>(Operand 1) = $I_2$ |
|      |              |          |              |          |          | (Operand 1) < $I_2$                        |
|      | CLI          | =C' A'.2 | 50           | CC =     | 1: c     | $(0 \text{ perand } 1) < I_{\circ}$        |
|      | CLI          | =C' X',  | C′X′−1       | CC =     | 2: c     | (Operand 1) > $I_2$                        |
|      | T I D        | =X'1'    | <b>(</b> '0' | CC =     | 2: c     | (Operand 1) > $I_2$                        |

| Mnem | Instruction   |                                             | Mnem                                                              | Mnem Instruction                               |   |  |  |
|------|---------------|---------------------------------------------|-------------------------------------------------------------------|------------------------------------------------|---|--|--|
| ТΜ   | Test Under    | Mask                                        | TMY                                                               | TMY Test Under Mask                            |   |  |  |
|      | of the fire   | st operand will                             | 2 .                                                               | ndicate which correspo<br>e CC shows the resul | - |  |  |
|      | CC Indication |                                             |                                                                   |                                                |   |  |  |
|      | 0             | Bits examined are all zero, or mask is zero |                                                                   |                                                |   |  |  |
|      | 1             | Bits examined are mixed zero and one        |                                                                   |                                                |   |  |  |
|      | 3             | Bits examined are                           | are all one                                                       |                                                |   |  |  |
|      | ТМ<br>ЈО      | Num,X'80'<br>Minus                          | Test leftmost bit of a number<br>Branch if a 1-bit, it's negative |                                                |   |  |  |
|      | ТМ            | Num+L'Num—1,1                               | Test rightmo                                                      | ost bit of a number                            |   |  |  |
|      | JZ            | Even                                        | Branch if lo                                                      | ow-order bit is zero                           |   |  |  |
|      | ТМ            | BB,255                                      | Test all eight bits                                               |                                                |   |  |  |
|      |               |                                             |                                                                   |                                                |   |  |  |

| Bit | t Data                                              |                   |                                           |                                                                                                                                                                       | 8        |
|-----|-----------------------------------------------------|-------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| •   |                                                     |                   | <i>name</i> bit-data it<br>techniques:    | ems than to use bit numbers or b                                                                                                                                      | it masks |
|     |                                                     | 01                | Person_X,128                              | Person has retired [Poor method]                                                                                                                                      |          |
|     | or                                                  | 01                | Person_X,Bit1                             | Person has retired [Poor method]                                                                                                                                      |          |
|     | Better te                                           | chni              | que: name each                            | flag bit separately                                                                                                                                                   |          |
|     | Retired<br>FullTime<br>PartTime<br>Exempt<br>Hourly | Equ<br>Equ<br>Equ | X'40'<br>X'20'<br>X'10'<br>X'08'<br>X'04' | Retired status flag bit<br>Full time worker status flag bit<br>Part time worker status flag bit<br>Exempt employee status flag bit<br>Hourly employee status flag bit |          |
|     |                                                     |                   | etc.                                      |                                                                                                                                                                       |          |
|     |                                                     | 01                | Person_X,Retired                          | Person has retired [Better Method]                                                                                                                                    |          |
| Cha | p. VII, Sec. 23                                     | .6                | System                                    | z Assembler Language                                                                                                                                                  | ©1BM 201 |

| Rememb        | ber: b    | it names ar                    | e numbe           | rs, not       | addre     | sses!                     |      |
|---------------|-----------|--------------------------------|-------------------|---------------|-----------|---------------------------|------|
| • Example     | ofa       | problem: De                    | efine a b         | it in eac     | h of t    | two bytes:                |      |
| Flag1<br>BitO | DS<br>Equ | <b>X</b><br>X'80'              |                   | Flag2<br>Bit1 | DS<br>Equ | <b>X</b><br><b>X</b> ′40′ |      |
| Normally      | y we      | would write                    | somethi           | ng like       |           |                           |      |
|               | 01        | Flag1,Bit0                     |                   |               | 01        | Flag2,Bit1                |      |
| • But we      | could     | accidentally                   | y write (v        | vithout       | assen     | nbler error!)             |      |
|               | 01        | Flag2,Bit0                     |                   |               | 01        | Flag1,Bit1                |      |
| • One way     | y to a    | ssociate sp                    | ecific bit        | s with t      | heir "    | owning" bytes:            |      |
|               | •         | *,X'20'<br>*,X'10'             | Assign a<br>For e |               | and le    | ength attribute           |      |
|               | DS        | X                              | Now defin         | ne the (u     | nnamed)   | owning byte               |      |
|               |           | oit using its<br>firmly attach |                   |               | •         | h attribute; then         | each |
|               | тм        | Fulltime,L′Fu                  | ulltime           | [Best!]       |           |                           |      |

|   | ruction M      | ounit     |                                         |                                                                   | 1(       |
|---|----------------|-----------|-----------------------------------------|-------------------------------------------------------------------|----------|
| Y | You may se     | e (or     | be tempted to v                         | write) self-modifying programs                                    |          |
|   | 1. Skip son    | ne stat   | ements after they                       | re executed once                                                  |          |
|   | NOP            | NOP<br>OI | SkipIt<br>NOP+1,X'FO'                   | Fall through first time here<br>Change NOP to unconditional brand | ch       |
|   | SkipIt         | DC        | OH                                      | Continue execution here                                           |          |
|   | 2. Alternati   | ng bet    | ween branching o                        | r not                                                             |          |
|   | Switch         | XI<br>BC  | -<br>Switch+1,X'FO'<br>15,SomeWhereElse | Alternate branch masks at 'Switch<br>Mask = 0, 15, 0, 15,         | ı′       |
| Т | his is a po    | or pr     | actice:                                 |                                                                   |          |
|   | 1. Serious     | negati    | ve impact on perfo                      | ormance                                                           |          |
|   | 2. The prog    | gram c    | an't be shared in                       | memory                                                            |          |
|   | 3. You may     | not b     | e debugging the p                       | rogram in the listing                                             |          |
| A | Advice: use    | a bit     | flag in a data a                        | rea                                                               |          |
|   | VII, Sec. 23.9 |           | System 7 Ass                            | embler Language                                                   | ©1BM 201 |

| 12-bit displacement20-bit displacement2Move ImmediateMVIMVIYIAND ImmediateNINIYIOR Immediate0I0IYI | Function     | Operand 1           |                     |                |  |
|----------------------------------------------------------------------------------------------------|--------------|---------------------|---------------------|----------------|--|
| AND Immediate     NI     NIY       OR Immediate     0I     0IY                                     | 1 direction  | 12-bit displacement | 20-bit displacement | 2              |  |
| OR Immediate OI OIY I                                                                              | ve Immediate | MVI                 | MVIY                | I <sub>2</sub> |  |
|                                                                                                    | D Immediate  | NI                  | NIY                 | l <sub>2</sub> |  |
| XOR Immediate XI XIY I                                                                             | lmmediate    | 01                  | OIY                 | I <sub>2</sub> |  |
|                                                                                                    | R Immediate  | XI                  | XIY                 | I <sub>2</sub> |  |
| Compare CLI CLIY I                                                                                 |              | CLI                 | CLIY                | I <sub>2</sub> |  |
| Test Under Mask TM TMY I                                                                           | t Under Mask | ТМ                  | ТМҮ                 | I <sub>2</sub> |  |



| wnem | Instruction                |        | Mnem           | Instruction                  |
|------|----------------------------|--------|----------------|------------------------------|
| MVC  | Move [Characters]          |        | MVCIN          | Move [Characters] Inverse    |
| NC   | AND [Characters]           |        | OC             | OR [Characters]              |
| XC   | XOR [Characters]           |        | CLC            | Compare Logical [Characters] |
| TR   | R Translate                |        | TRT            | Translate and Test           |
| TRTR | Translate and Test Reverse |        |                |                              |
|      |                            |        |                |                              |
| орсо | de <u>L</u> B <sub>1</sub> | $D_1$  | B <sub>2</sub> | D2                           |
|      | de <u>L</u> B <sub>1</sub> |        |                |                              |
|      |                            | uction |                |                              |





| Implied Lengths 1                                                                                                                                   |                                                                                    |                                                                            |              |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------|--|--|
| If you don't spe                                                                                                                                    | cify length <b>N</b> , the asser                                                   | nbler assigns an <i>im</i>                                                 | plied length |  |  |
|                                                                                                                                                     | Implied Leng                                                                       | th                                                                         |              |  |  |
|                                                                                                                                                     | \$1,\$2                                                                            |                                                                            |              |  |  |
|                                                                                                                                                     | D <sub>1</sub> (,B <sub>1</sub> ),S <sub>2</sub>                                   |                                                                            |              |  |  |
|                                                                                                                                                     | S <sub>1</sub> ,D <sub>2</sub> (B <sub>2</sub> )                                   |                                                                            |              |  |  |
|                                                                                                                                                     | D <sub>1</sub> (,B <sub>1</sub> ),D <sub>2</sub> (B                                | $D_1(,B_1),D_2(B_2)$                                                       |              |  |  |
| 1 0                                                                                                                                                 |                                                                                    | v many bytes are ir<br>s from BB to AA                                     | nvolved      |  |  |
| MVC AA<br>Summary of exp                                                                                                                            | A,BB Move L'AA byte                                                                | s from BB to AA                                                            |              |  |  |
| MVC AA<br>Summary of exp<br>First operand form                                                                                                      | BB Move L'AA byte<br>blicit/implied addresses<br>Address specification             | s from BB to AA<br>and lengths<br>Length Expression                        | Length used  |  |  |
| MVC AA<br>Summary of exp<br>First operand form<br>S <sub>1</sub>                                                                                    | A,BB Move L'AA byte<br>Dicit/implied addresses<br>Address specification<br>implied | s from BB to AA<br>and lengths<br>Length Expression<br>implied             | Length used  |  |  |
| MVC AA<br>Summary of exp<br>First operand form                                                                                                      | BB Move L'AA byte<br>blicit/implied addresses<br>Address specification             | s from BB to AA<br>and lengths<br>Length Expression                        | Length used  |  |  |
| MVC AA<br>Summary of exp<br>First operand form<br>S <sub>1</sub>                                                                                    | A,BB Move L'AA byte<br>Dicit/implied addresses<br>Address specification<br>implied | s from BB to AA<br>and lengths<br>Length Expression<br>implied             | Length used  |  |  |
| $\begin{array}{c} \text{MVC}  \text{AA}\\ \text{Summary of exp}\\ \hline \text{First operand form}\\ \hline S_1\\ \hline S_1(\text{N}) \end{array}$ | Address specification<br>implied<br>implied                                        | s from BB to AA<br>and lengths<br>Length Expression<br>implied<br>explicit | Length used  |  |  |



| Mnem | Instru            | ction      |                           | Mnem      | Instruction                                          |
|------|-------------------|------------|---------------------------|-----------|------------------------------------------------------|
| MVC  | Move              | [Chara     | acters]                   | MVCIN     | Move [Characters] Inverse                            |
|      | ese in:<br>amples |            | tions move 1-256 b<br>MVC | ytes (0 ≤ | ≤ L ≤ 255)                                           |
|      |                   | MVC<br>MVC | AA(23),BB Mo              | •         | s from BB to AA<br>tes from BB to AA                 |
|      |                   |            |                           |           | e blank to Line<br>anks to fill 121 bytes            |
|      |                   | MVC<br>MVC |                           |           | es left 2 positions<br>two bytes at Str by spaces    |
|      |                   |            |                           |           | s moved in reverse order to<br>of the rightmost byte |
|      |                   | MVCIN      | RevData,Data+L'Data-1     | Move re   | versed from Data to Revdata                          |
|      |                   | DC         | <b>C</b> '12345'          | Source    |                                                      |

|                      | tructions per                  | structions<br>form a logical operation between o<br>second operands, and set the CC:  | 19<br>corresponding |
|----------------------|--------------------------------|---------------------------------------------------------------------------------------|---------------------|
|                      | Operation                      | CC setting                                                                            | ]                   |
|                      | AND<br>OR<br>XOR               | <ul><li>0: all result bits are zero</li><li>1: result bits are not all zero</li></ul> |                     |
| N                    | nch to Zifth<br>IC W,W<br>IZ Z | e word at W is zero:<br>AND each byte to itself<br>Branch if all bytes are zero       |                     |
| (                    | toZifthe<br>W,W<br>ZZ          | word at W is zero:<br>OR each byte to itself<br>Branch if all bytes are zero          |                     |
| • XOR: set           | the at W to z                  | zero:                                                                                 |                     |
| >                    | C W,W                          | XOR each byte with itself                                                             |                     |
|                      |                                |                                                                                       |                     |
| Chap. VII, Sec. 24.7 |                                | System z Assembler Language                                                           | ©IBM 2015           |

| The CLC Ir         | nstructi                                | ion                                                             |                                                                                                              | 20                   |
|--------------------|-----------------------------------------|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|----------------------|
|                    |                                         |                                                                 | e strings as unsigned 8-bit int<br>e comparison                                                              | egers                |
|                    |                                         | СС                                                              | Indication                                                                                                   |                      |
|                    |                                         | 0                                                               | Operand 1 = Operand 2                                                                                        |                      |
|                    |                                         | 1                                                               | Operand 1 < Operand 2                                                                                        |                      |
|                    |                                         | 2                                                               | Operand 1 > Operand 2                                                                                        |                      |
| • Example:         | CLC LINI<br>JE ALLI<br>CLC =CL          | <b>120 byt</b><br>E(120),=CL12<br>BLANK<br>120' ',LINE<br>BLANK | BRANCH IF EQUAL                                                                                              | nch to AllBlank      |
|                    | le: Comp<br>or ABEqua                   |                                                                 | non-negative words at A and B, a<br>dingly                                                                   | and branch to AHigh, |
|                    | CLC A,B<br>JH AHI(<br>JL ALO)<br>J ABE( | SH I                                                            | COMPARE TWO NON-NEGATIVE INTEGERS<br>BRANCH IF C(A) < C(B)<br>BRANCH IF C(A) < C(B)<br>BRANCH IF C(A) = C(B) |                      |
| Chap. VII, Sec. 24 | .8                                      |                                                                 | System z Assembler Language                                                                                  | ©IBM 2015            |



|       | The value of an "argument" byte is the offset to a "function" byte                                         |
|-------|------------------------------------------------------------------------------------------------------------|
| _     |                                                                                                            |
|       | If the function byte is zero, continue. Otherwise:                                                         |
|       | 1. Put the function byte in the rightmost byte of GR1                                                      |
|       | 2. Put the address of the argument byte in GR2, and stop scanning                                          |
|       | 3. Set the Condition Code:                                                                                 |
| СС    | Meaning                                                                                                    |
| 0     | All accessed function bytes were zero.                                                                     |
| 1     | A nonzero function byte was accessed before the last argument byte was reached.                            |
| 2     | The nonzero function byte accessed corresponds to the last argument byte.                                  |
| • Exa | ample: scan the table at Data for numeric characters<br>TRT Data.NumTable Scan Data for numeric characters |

| Mnem                                                                                                                            | Instruction                                                                                                                              | Mnem     | Instruction               |  |
|---------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------------------|--|
| EX                                                                                                                              | Execute                                                                                                                                  | EXRL     | Execute Relative Long     |  |
| 1.                                                                                                                              | Save the ${\rm R}_{\rm 1}$ digit of the Execute in                                                                                       | structio | n                         |  |
| <ol><li>Put the instruction at the Effective Address in the Instruction Register<br/>place of the Execute instruction</li></ol> |                                                                                                                                          |          |                           |  |
|                                                                                                                                 | - The Instruction Address (IA) in the F                                                                                                  | PSW rem  | ains unchanged            |  |
| 3. If the instruction in IR is an Execute, cause a program interruption                                                         |                                                                                                                                          |          |                           |  |
| 4.                                                                                                                              | <ol> <li>If the R<sub>1</sub> digit is nonzero, OR the rightmost digit of GR R<sub>1</sub> into the second<br/>byte of the IR</li> </ol> |          |                           |  |
| 5.                                                                                                                              | Execute the instruction in the IR                                                                                                        |          |                           |  |
| Any                                                                                                                             | CC settings are due to the ex                                                                                                            | ecuted   | instruction               |  |
| The                                                                                                                             | R <sub>1</sub> digit is nonzero for almost                                                                                               | all use  | s of Execute instructions |  |

| The Exect                  | ute In         | structions (2         | )                                                                                                                     | 24        |
|----------------------------|----------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------|-----------|
|                            |                | 9 respectively<br>9,0 | ge to Line whose address and length<br>Reduce length N in GR9 by 1 (L=N-1)<br>Move the message text to Line           | are in    |
| MoveMsg                    | MVC            | -<br>Line(*-*),0(8)   | Move text at GR8 address to Line                                                                                      |           |
| betweer                    | n 0 an         |                       | Mask contains an integer whose value<br>s the mask digit of a BC instruction                                          | e lies    |
| NotMet                     | L<br>SLL<br>EX | -,                    | Get mask value<br>Position correctly for use as M <sub>1</sub><br>Execute the BC<br>Fall through if condition not met |           |
| BCInst<br>- Note<br>instru | that if        |                       | BC with mask of 0<br>dition is met, control will be taken from the                                                    | EX        |
| Chap. VII, Sec. 2          | 24.11          | Syst                  | em z Assembler Language                                                                                               | ©IBM 2015 |

| Function                   | Instruction  | Data is Processed              | CC Set            |
|----------------------------|--------------|--------------------------------|-------------------|
| Move                       | MVC<br>MVCIN | Left to right<br>Right to left | No                |
| AND                        | NC           | Left to right                  | Yes               |
| OR                         | 00           | Left to right                  | Yes               |
| XOR                        | 0C           | Left to right                  | Yes               |
| Compare                    | CLC          | Left to right                  | Yes               |
| Translate                  | TR           | Left to right                  | No                |
| Translate and Test         | TRT          | Left to right                  | Yes               |
| Translate and Test Reverse | TRTR         | Right to left                  | Yes               |
| Execute                    | EX<br>EXRL   | _                              | Depend<br>on targ |



| Mnem   | Instruction                                                                      | Mnem                                 | Instruction                                                    |
|--------|----------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------------------|
| MVCL   | Move Long                                                                        | CLCL                                 | Compare Logical Long                                           |
|        | MVCL R <sub>1</sub> , R <sub>2</sub> and                                         | CLCL R <sub>1</sub> , R <sub>2</sub> |                                                                |
|        | instructions use Meth<br>ster pairs                                              | od "A" when int                      | terrupted, and two even-odd                                    |
| – Tł   | ne even-numbered registe<br>ne odd-numbered register<br>ne operands may have dit | holds the true op                    | nd address<br>erand length (0-2 <sup>24</sup> -1 bytes)        |
| The    | high-order byte of R <sub>2</sub> +                                              | 1 holds a <i>pad</i> b               | yte                                                            |
| All fo | our registers may be u                                                           | pdated by the i                      | nstructions                                                    |
| Both   | instructions set the C                                                           | С                                    |                                                                |
|        |                                                                                  |                                      | ructuve overlap is possible:<br>er data has been moved into it |

| The N          | AVCL Instruction 28                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.<br>2.<br>3. | nceptually, MVCL works like this:<br>As each byte is moved addresses are incremented, lengths decremented<br>If both lengths=0 at the same time, set CC=0<br>If the target length $c(R_1+1)$ is 0 before the source length $c(R_2+1)$ , set CC=1<br>If the source length $c(R_2+1)$ is 0 before the target length $c(R_1+1)$ , use the<br>pad character as source data until the target length is 0; set CC=2 |
| сс             | Meaning                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0              | Operand 1 length = Operand 2 length                                                                                                                                                                                                                                                                                                                                                                           |
| 1              | Operand 1 length < Operand 2 length; part of Operand 2 not moved                                                                                                                                                                                                                                                                                                                                              |
| 2              | Operand 1 length > Operand 2 length; Operand 1 was padded                                                                                                                                                                                                                                                                                                                                                     |
| 3              | Destructive Overlap, no data movement                                                                                                                                                                                                                                                                                                                                                                         |
| Ex             | ample: Set 2400 bytes at Field to zerosLA0,FieldC(R_1) = Target addressLHI1,2400C(R_1+1) = Target lengthSR3,3C(R_2+1) = Source length = 0; pad = X'00'No source address is required if source length is zeroMVCL0,2Move X'00' pad bytes to target Field                                                                                                                                                       |
|                | , Sec. 25.1.1 System z Assembler Language ©IBM 201                                                                                                                                                                                                                                                                                                                                                            |

| <ul> <li>Concept</li> </ul> | ually,  | CLCL works like this:                                                                                   |            |
|-----------------------------|---------|---------------------------------------------------------------------------------------------------------|------------|
| 1. Com                      | pare p  | airs of bytes; decrement addresses, increment length                                                    | IS         |
| 2. If bo                    | th len  | gths=0 at the same time, set CC=0                                                                       |            |
|                             |         | ality is found, $\rm R_{1}$ and $\rm R_{2}$ contain the addresses of the CC=1 or CC=2                   | unequal    |
| 4. If eit                   | her lei | ngth is 0, compare bytes from the longer operand to t                                                   | he pad byt |
|                             | cc      | Meaning                                                                                                 |            |
|                             | 0       | Operand 1 = Operand 2, or both lengths 0                                                                |            |
|                             | 1       | First Operand low                                                                                       |            |
|                             | 2       | First Operand high                                                                                      |            |
|                             |         |                                                                                                         |            |
| <ul> <li>Example</li> </ul> | e: Brai | nch to <b>Cleared</b> if the 2400 bytes at <b>Field</b> are ze <b>0,Field</b> $c(R_1) = Target address$ | eros       |

| Mnem                       | n Instruction                                                              |                                                 |                                                   | Mnem                                                        | Instruction                                   |                                                                  |                               |  |
|----------------------------|----------------------------------------------------------------------------|-------------------------------------------------|---------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------|------------------------------------------------------------------|-------------------------------|--|
| MVCLE Move Long Extended   |                                                                            |                                                 |                                                   | CLCLE                                                       | Compare Logi                                  | cal Long Extende                                                 | d                             |  |
| MVC                        | LE and C                                                                   | LCLE                                            | gener                                             | alize MV0                                                   | CL and                                        | CLCL. Their                                                      | form:                         |  |
| opcod                      | e R <sub>1</sub>                                                           | R <sub>3</sub>                                  | B <sub>2</sub>                                    | DL                                                          | -2                                            | DH <sub>2</sub>                                                  | opcode                        |  |
| addr<br>- Th               | esses an<br>ne low-orde                                                    | d leng<br>er byte                               | ths de<br>of ope                                  | epend on<br>erand 2 is i                                    | address<br>the pad o                          | •                                                                | t an address!)                |  |
| addr<br>- Th<br>- Th<br>ac | esses an<br>ne low-orde<br>ne odd-nun<br>Idressing r                       | d leng<br>er byte<br>nbered<br>node) v          | ths de<br>of ope<br>registe<br>/s. 24-            | epend on<br>erand 2 is<br>ers hold 32<br>bit lengths        | address<br>the pad o<br>2- or 64-b            | sing mode<br>character ( <i>not</i><br>pit lengths (de           | t an address!)                |  |
| addr<br>- Th<br>- Th<br>ac | esses an<br>ne low-orde<br>ne odd-nun<br>Idressing r<br>embler La          | d leng<br>er byte<br>nbered<br>node) v<br>nguag | ths de<br>of ope<br>registe<br>/s. 24-l<br>le syn | epend on<br>erand 2 is<br>ers hold 32<br>bit lengths<br>tax | address<br>the pad o<br>2- or 64-b<br>for MVC | sing mode<br>character ( <i>not</i><br>bit lengths (de<br>L/CLCL | f an address!)<br>epending on |  |
| addr<br>- Th<br>- Th<br>ac | esses an<br>ne low-orde<br>ne odd-nun<br>Idressing r<br>embler La<br>mnemo | d leng<br>er byte<br>nbered<br>node) v          | ths de<br>of ope<br>registe<br>/s. 24-l<br>le syn | epend on<br>erand 2 is<br>ers hold 32<br>bit lengths<br>tax | address<br>the pad o<br>2- or 64-b<br>for MVC | sing mode<br>character ( <i>not</i><br>pit lengths (de           | f an address!)<br>epending on |  |

| The M          | IVCLE Instruction 31                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.<br>2.<br>3. | nceptually, MVCLE works like this:<br>As each byte is moved, increment addresses, decrement lengths<br>If both lengths=0 at the same time, set CC=0<br>If the target length $c(R_1+1)$ is 0 before the source length $c(R_3+1)$ , set CC=1<br>If the source length $c(R_3+1)$ is 0 before the target length $c(R_1+1)$ , use the<br>pad character as source data until the target length is 0; set CC=2 |
| СС             | Meaning                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0              | Operand 1 length = Operand 2 length                                                                                                                                                                                                                                                                                                                                                                     |
| 1              | Operand 1 length < Operand 2 length; part of operand 2 not moved                                                                                                                                                                                                                                                                                                                                        |
| 2              | Operand 1 length > Operand 2 length; operand 1 was padded                                                                                                                                                                                                                                                                                                                                               |
| 3              | CPU wants to rest; branch back to the MVCLE                                                                                                                                                                                                                                                                                                                                                             |
| • Ex           | ample: set 2400 bytes at Field to zerosLA0,Fieldc(R1) = Target addressLHI1,2400c(R1+1) = Target lengthSR3,3c(R3+1) = Source length = 0SR5,5c(R5) = Pad byte = X'00'No source address is required if source length is zero                                                                                                                                                                               |
|                | MVCLE 0.2.0(5) Move pad bytes to target Field                                                                                                                                                                                                                                                                                                                                                           |
| Chap. VI       | , Sec. 25.2.1 System z Assembler Language © IBM 2015                                                                                                                                                                                                                                                                                                                                                    |

| he C | LCLE Instruction                                                                                                                                                                                                                                                                      | 3 |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Со   | nceptually, CLCLE works like this:                                                                                                                                                                                                                                                    |   |
|      | Compare pairs of bytes; decrement addresses, increment lengths<br>If both lengths=0 at the same time, set CC=0                                                                                                                                                                        |   |
|      | At inequality, $\rm R_1$ and $\rm R_3$ address the unequal bytes; set CC=1 or CC=2 If a length is 0, compare bytes from the longer operand to the pad byte                                                                                                                            |   |
| сс   | Meaning                                                                                                                                                                                                                                                                               |   |
| 0    | Operand 1 = Operand 2, or both 0 length                                                                                                                                                                                                                                               |   |
| 1    | First operand low                                                                                                                                                                                                                                                                     |   |
| 2    | First operand high                                                                                                                                                                                                                                                                    |   |
| 3    | No inequality found thus far; operands are not exhausted                                                                                                                                                                                                                              |   |
| Exa  | umple: branch to <b>Cleared</b> if the 2400 bytes at <b>Field</b> are zeros<br>LA 0,Field c(R,) = Target address                                                                                                                                                                      |   |
| *    | LHI 1,2400 $c(R_1^++1) = Target length$<br>SR 3,3 $c(R_2+1) = Source length = 0$<br>SR 5,5 Set pad character to X'00'<br>No source address is required if source length is zero<br>CLCLE 0,2,0(5) Compare target Field bytes to X'00'<br>JE Cleared Branch if the Field was all zeros |   |

| - W                          | e sometimes use a bold-italic " <b>n</b> "                  | to repres              | sent a null byte          |
|------------------------------|-------------------------------------------------------------|------------------------|---------------------------|
| CStr                         | ing DC C'A C-string.', X'O'                                 | Generate               | s 'A C-string. <i>n</i> ' |
| hes                          | e four instructions simplify we                             | orking w               | ith C-strings:            |
| Mnem                         | Instruction                                                 | Mnem                   | Instruction               |
| MVST                         | Move String                                                 | CLST                   | Compare Logical String    |
| SRST                         | Search String                                               | TRE                    | Translate Extended        |
|                              | h has Assembler Language sy mnemonic <b>R</b> 1, <b>R</b> 2 |                        |                           |
| Each<br>of G<br>- Th<br>Each | 8 8 9                                                       | "test" ch<br>erruption |                           |

| R0 is zei<br>ne start d                                                                                                                           | roed; the test cha                                                                       | racter is placed in its rightmost byte                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                                                                                                                                   |                                                                                          | ST searches a string of bytes for a match of the test character GR0 is zeroed; the test character is placed in its rightmost byte The start of the string is placed in $R_2$<br>One byte past the end of the string is placed in $R_1$ (to limit the search) ndition Code settings: |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| leaning                                                                                                                                           |                                                                                          |                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| est charac                                                                                                                                        | ter found; R <sub>1</sub> points                                                         | to it                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| est charac                                                                                                                                        | ter not found before                                                                     | the byte addressed by R <sub>1</sub>                                                                                                                                                                                                                                                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| artial sea                                                                                                                                        | rch with no match; F                                                                     | R <sub>1</sub> unchanged, R <sub>2</sub> points to next byte to process                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| Jsually, SRST is faster searching for single characters than a CLI loop<br>RT<br>mple: Search a byte string at <b>Expr</b> for a left parenthesis |                                                                                          |                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| LHI                                                                                                                                               | 0,C'('                                                                                   | Test character                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|                                                                                                                                                   |                                                                                          |                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|                                                                                                                                                   |                                                                                          |                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|                                                                                                                                                   | Teaning<br>fest charact<br>artial sear<br>ually, SR<br>T<br>ple: Sear<br>LHI<br>LA<br>LA | leaning<br>feest character found; R <sub>1</sub> points<br>feest character not found before<br>fartial search with no match; F<br>ually, SRST is faster searc<br>T<br>ple: Search a byte strin<br>LHI 0,C'('<br>LA 4,Expr                                                           | Iteaning         iest character found; R1 points to it         iest character not found before the byte addressed by R1         iartial search with no match; R1 unchanged, R2 points to next byte to process         ually, SRST is faster searching for single characters than a CLI loop of T         ple: Search a byte string at Expr for a left parenthesis         LHI       0,C'('         Test character         LA       4,Expr         Start of string         LA       8,Expr+L'Expr |  |  |  |  |

| Move S               | String Ins                                                                                                                                                                                                                                               | struction                  |                                                                                                                                    | 35         |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------|--|
| 1. (<br>2. 1<br>3. 1 | ST moves a C-string, including the test character<br>GR0 is zeroed; the test character is placed in its rightmost byte<br>The target-string address is placed in $R_1$<br>The source-string address is placed in $R_2$<br>e Condition Code settings are: |                            |                                                                                                                                    |            |  |
| cc                   | Meaning                                                                                                                                                                                                                                                  |                            |                                                                                                                                    |            |  |
| 1                    | Entire sec                                                                                                                                                                                                                                               | ond operand m              | noved; R <sub>1</sub> points to end of first operand                                                                               |            |  |
| 3                    | Incomplet                                                                                                                                                                                                                                                | e move; R <sub>1</sub> and | d R <sub>2</sub> point to next bytes to process                                                                                    |            |  |
| • Exar               | nple: Mov<br>Xr<br>LA<br>LA<br>MVST                                                                                                                                                                                                                      | 0,0<br>7,There<br>1,Here   | g from <b>Here</b> to <b>There</b><br>Test character is a null byte<br>Target address<br>Source address<br>Move from Here to There | 2          |  |
| • For v<br>faste     | , ,                                                                                                                                                                                                                                                      | strings with               | n known lengths, MVCL or MV(                                                                                                       | CLE may be |  |
| Chap. VII, S         | 05 5                                                                                                                                                                                                                                                     | c                          | ystem z Assembler Language                                                                                                         | © IBM 201  |  |

| Co  | mparison stops when a                                                   | ngs terminated with the <i>same</i> stop charact<br>an inequality is detected, or the end of an                                                                                   | er   |
|-----|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| ope | erand is reached                                                        |                                                                                                                                                                                   |      |
| As  | shorter operand is alw                                                  | ays considered "low" compared to the lor                                                                                                                                          | iger |
| Co  | ndition Code settings:                                                  |                                                                                                                                                                                   |      |
| сс  | Meaning                                                                 |                                                                                                                                                                                   |      |
| 0   | Entire operands are equal;                                              | R <sub>1</sub> and R <sub>2</sub> unchanged                                                                                                                                       |      |
| 1   | First operand low; R <sub>1</sub> and                                   | R <sub>2</sub> point to last bytes processed                                                                                                                                      |      |
| 2   | First operand high; R <sub>1</sub> and                                  | R2 point to last bytes processed                                                                                                                                                  |      |
| 3   | Operands equal so far; R <sub>1</sub>                                   | and R <sub>2</sub> point to next bytes to process                                                                                                                                 |      |
| Exa | ample: Compare the C<br>SR 0,0<br>LA 3,Before<br>LA 6,After<br>CLST 3,6 | -strings at <b>Before</b> and <b>After</b><br>Compare null-terminated C-strings<br>Address of first operand string<br>Address of second operand string<br>Compare the two strings |      |
|     |                                                                         |                                                                                                                                                                                   |      |

| ΤF                   | RE is similar to TR, but more flexible:                                                                                         |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 1                    | . Translated string address is the ${\rm R}_1$ operand, translate table address is the ${\rm R}_2$ operand                      |
|                      | - The string length is in (odd register) ${\sf R}_1{+}1$                                                                        |
| 2                    | . GR0 is zeroed; the test character is placed in its rightmost byte                                                             |
|                      |                                                                                                                                 |
|                      | . TRE stops when (a) all bytes are translated, or (b) a source byte (which is <i>not</i> translated) matches the stop character |
| 3                    |                                                                                                                                 |
| 3                    | not translated) matches the stop character                                                                                      |
| 3<br>Co              | not translated) matches the stop character<br>ondition Code settings:                                                           |
| 3<br>Cc<br><b>cc</b> | not translated) matches the stop character<br>ondition Code settings:<br>Meaning                                                |

| om                    | pare Until Substring Equal Instruction (*) 38                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | JSE searches for common substrings of a specified length<br>e matching substrings must be at the <i>same</i> offset in both strings                                                                                                                                                                                                                                                                                                                        |
|                       | ABCDEFG' and 'QRSDEFT' — matching strings at offset 3: lengths 1, 2, or 3 ABC' and 'BCD**' — if pad='*', matching substring at offset 3: length 2                                                                                                                                                                                                                                                                                                          |
|                       | Operand addresses are in even-numbered registers $R_1$ and $R_2$ ; Operand                                                                                                                                                                                                                                                                                                                                                                                 |
| 2.<br>Co              | lengths are in corresponding odd-numbered registers $\dot{R}_1$ +1 and $\dot{R}_2$ +1<br>The rightmost bytes of GR0 and GR1 contain the desired substring length<br>and the padding byte, respectively<br>indition Code settings:                                                                                                                                                                                                                          |
| 2.<br>Co<br>cc        | lengths are in corresponding odd-numbered registers $\dot{R}_1$ +1 and $\dot{R}_2$ +1<br>The rightmost bytes of GR0 and GR1 contain the desired substring length<br>and the padding byte, respectively<br>indition Code settings:<br>Meaning                                                                                                                                                                                                               |
| 2.<br>Co              | lengths are in corresponding odd-numbered registers $\dot{R}_1$ +1 and $\dot{R}_2$ +1<br>The rightmost bytes of GR0 and GR1 contain the desired substring length<br>and the padding byte, respectively<br>indition Code settings:                                                                                                                                                                                                                          |
| 2.<br>Co<br>cc        | lengths are in corresponding odd-numbered registers $R_1$ +1 and $R_2$ +1<br>The rightmost bytes of GR0 and GR1 contain the desired substring length<br>and the padding byte, respectively<br>indition Code settings:<br>Meaning<br>Equal substrings found; $R_1$ , $R_2$ , and lengths updated; or, the substring length is 0, and                                                                                                                        |
| 2.<br>Cc<br><u>cc</u> | lengths are in corresponding odd-numbered registers $R_1$ +1 and $R_2$ +1<br>The rightmost bytes of GR0 and GR1 contain the desired substring length<br>and the padding byte, respectively<br>indition Code settings:<br>Meaning<br>Equal substrings found; $R_1$ , $R_2$ , and lengths updated; or, the substring length is 0, and<br>$R_1$ , $R_2$ are unchanged<br>Ended at longer operand, last bytes were equal (allows continuing search for further |

| Function  | Length control        | End-char control                                            |
|-----------|-----------------------|-------------------------------------------------------------|
| Move      | MVCL<br>MVCLE         | MVST                                                        |
| Compare   | CLCL<br>CLCLE<br>CUSE | CLST                                                        |
| Search    |                       | SRST                                                        |
| Translate |                       | TRE                                                         |
|           | ms scanning or movin  | gs: if the terminating null b<br>ng such strings may "proce |











| Ur  | nicode                                                                                                                                                                                                                                          | 45   |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| •   | <ul> <li>All Unicode characters can have any of 3 formats:</li> <li>UTF-8: an encoding is 1-4 bytes long</li> <li>UTF-16: most characters are 2 bytes long; some are 2 2-byte pairs</li> <li>UTF-32: all characters are 4 bytes long</li> </ul> |      |
| •   | Instructions can convert any encoding to any other                                                                                                                                                                                              |      |
| •   | UTF-16 is most widely used; notation is U+nnnn where "nnnn" is 4 he digits                                                                                                                                                                      | x    |
|     | <ul> <li>The encoding of U+nnnn is X'nnnn'</li> </ul>                                                                                                                                                                                           |      |
|     | <ul> <li>ASCII encodings have values from U+0000 to U+00FF</li> </ul>                                                                                                                                                                           |      |
|     | <ul> <li>Encodings U+0000 - U+FFFF are known as the "Basic Multilingual Plane"</li> </ul>                                                                                                                                                       |      |
| •   | Unicode constants are written with type extension U, and generate UTF-16 characters:                                                                                                                                                            |      |
|     | DC CU'Unicode ' Generates X'0055006E00690063 006F006400650020'                                                                                                                                                                                  |      |
|     |                                                                                                                                                                                                                                                 |      |
| Cha | p. VII, Sec. 26.5 System z Assembler Language ©IBM                                                                                                                                                                                              | 2015 |

| •••                    | String search, compare, and            | d move instruct | roups:<br>ions                                      |  |
|------------------------|----------------------------------------|-----------------|-----------------------------------------------------|--|
| Mnem                   | Instruction                            | Mnem            | Instruction                                         |  |
| SRSTU                  | Search String Unicode                  | CLCLU           | Compare Logical Long Unicode                        |  |
| MVCLU                  | Move Long Unicode                      |                 |                                                     |  |
|                        |                                        |                 |                                                     |  |
| Mnem<br>TROO           | Instruction<br>Translate One to One    | Mnem<br>TROT    | Instruction<br>Translate One to Two                 |  |
| TRTO                   | Translate Two to One                   | TRTT            | Translate Two to Two                                |  |
| 3.                     | Format conversion instructi            | ONS Mnem        | Instruction                                         |  |
| Mnem                   | Instruction                            |                 |                                                     |  |
| Mnem<br>CU12,<br>CUTFU | Instruction<br>Convert UTF-8 to UTF-16 | CU14            | Convert UTF-8 to UTF-32                             |  |
| CU12,                  |                                        | CU14<br>CU24    | Convert UTF-8 to UTF-32<br>Convert UTF-16 to UTF-32 |  |





| • So  | metin  | nes need to translate to, from, or among Unicode encodings                |
|-------|--------|---------------------------------------------------------------------------|
| • Fou | ur ins | structions:                                                               |
| TR    | 00:    | Translate One to One (like TR but much more flexible)                     |
| TR    | от:    | Convert single-byte data to double-byte (e.g. EBCDIC or ASC to Unicode)   |
| TR    | то:    | Convert couble-byte data to single-byte (e.g. Unicode to EBCDIC or ASCII) |
| TR    | TT:    | Convert among double-byte data formats to Unicode)                        |
| • All | four   | instructions have an optional $M_3$ operand TRxx $R_1, R_2[, M_3]$        |
| • Us  | es ar  | en't limited to character data!                                           |

|                | -16, and UTF-32<br>TF-8 format is complex; used only                                                                                     | for net  | vork transmission            |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------------|
|                | instructions for conversion am                                                                                                           |          |                              |
| Mnem           | Instruction                                                                                                                              | Mnem     | Instruction                  |
| CU12,<br>CUTFU | Convert UTF-8 to UTF-16                                                                                                                  | CU14     | Convert UTF-8 to UTF-32      |
| CU21,<br>CUUTF | Convert UTF-16 to UTF-8                                                                                                                  | CU24     | Convert UTF-16 to UTF-32     |
| CU41           | Convert UTF-32 to UTF-8                                                                                                                  | CU42     | Convert UTF-32 to UTF-16     |
| Ope            | rand formats:<br>CUxx R <sub>1</sub> ,R <sub>2</sub> [,M <sub>3</sub> ] For CU12, CU<br>CUxx R <sub>1</sub> ,R <sub>2</sub> For CU41, CU |          | CU24                         |
| – In           | itial implementations (CUTFU, CU                                                                                                         | UTF) dia | d no "well-formedness" tests |
|                | itial implementations (CUTFU, CU<br>M <sub>3</sub> =1, invalid operand data sets                                                         |          | d no "well-formedness" tests |

|                  | ch instruction uses an optional operand to create six "additional" tructions with a single opcode                |  |
|------------------|------------------------------------------------------------------------------------------------------------------|--|
| • Op             | erand format:                                                                                                    |  |
|                  | Mnemonic $R_1, R_2[, M_3]$ $M_3$ bits are B'AFLO'                                                                |  |
| • M <sub>3</sub> | mask bits:                                                                                                       |  |
| A                | 0: Argument characters are 1 byte<br>1: Argument characters are 2 bytes                                          |  |
| F                | 0: Function codes are 1 byte<br>1: Function codes are 2 bytes                                                    |  |
| L                | 0: Full range of argument and function codes allowed<br>1: Argument > 255 means function code assumed to be zero |  |
| • Ma             | sk bits provide greate flexibility                                                                               |  |
| -                | But not all 9 A-F-L combinations are meaningful                                                                  |  |

| Byte R       | eversal and Workstation Da      | ta          | 52                           |
|--------------|---------------------------------|-------------|------------------------------|
| • Supp       | oose a 32-bit integer X'123456  | 78′ star    | ts at address X'2400'.       |
|              | 12 34 56 78 IBM System          | z ("Big     | -Endian")                    |
| 24           | <b>↑</b>                        |             |                              |
| • On s       | ome processors (e.g. Intel) it' | s storec    | l like this:                 |
|              | 78 56 34 12 Some works          | tations (   | ("Little-Endian")            |
| 24           | <b>↑</b>                        |             |                              |
| Mnem         | Instruction                     | Mnem        | Instruction                  |
| LRV          | Load Reversed (32)              | LRVR        | Load Register Reversed (32)  |
| LRVG         | Load Reversed (64)              | LRVGR       | Load Register Reversed (64)  |
| LRVH         | Load Halfword Reversed (16)     | STRVH       | Store Halfword Reversed (16) |
| STRV         | Store Reversed (32)             | STRVG       | Store Reversed (64)          |
|              |                                 |             |                              |
| Chap. VII, S | Sec. 26.8 System z Asser        | mbler Langı | uage ©IBM 2015               |

| Chapter VIII: Zoned/Packed Decimal Data and Operations                                                                                                                                                                                    | 1         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| This chapter explores the the zoned and packed decimal represent<br>and operations on them                                                                                                                                                | tations   |
| • Section 27 describes the zoned and packed representations in a and instructions to convert between them                                                                                                                                 | detail,   |
| • Section 28 investigates the operations of packed decimal comp<br>addition and subtraction, multiplication, and division to prepare<br>instructions in Section 29                                                                        |           |
| <ul> <li>Section 29 discusses the instructions that test, move, compare,<br/>and do arithmetic operations on packed decimal operands</li> <li>Scaled arithmetic for values with fractional parts is discussed in Sec<br/>29.10</li> </ul> |           |
| <ul> <li>Section 30 examines techniques and instructions for converting<br/>binary, packed decimal, and character formats</li> </ul>                                                                                                      | among     |
|                                                                                                                                                                                                                                           |           |
|                                                                                                                                                                                                                                           |           |
| Chap. VIII, Sec. 27-30 System z Assembler Language                                                                                                                                                                                        | ©IBM 2015 |

|          | quite close to "normal" E<br>e examine the packed |                |                            |
|----------|---------------------------------------------------|----------------|----------------------------|
| Then w   | •                                                 |                | ing data between zoned and |
| Mnem     | Instruction                                       | Mnem           | Instruction                |
| MVN      | Move Numerics                                     | MVZ            | Move Zones                 |
| PACK     | Pack                                              | UNPK           | Unpack                     |
| PKA      | Pack ASCII                                        | UNPKA          | Unpack ASCII               |
| PKU      | Pack Unicode                                      | UNPKU          | Unpack Unicode             |
| – All th | nese instructions have SS                         | 5-1 or SS-2 fo | rmat                       |

| Zo  | oned Decimal Representation                                                                                                                 | 3          |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------|------------|
| •   | Notation used for bytes of any type:<br>left hex digit of a byte is the "zone" digit (Z);<br>the right hex digit is the "numeric" digit (n) |            |
|     | Z n Z n Z n Z n Z n Z n                                                                                                                     |            |
| •   | Two special move instructions, very much like MVC:                                                                                          |            |
|     | <ol> <li>MVN: moves only the numeric digits; source and target zone digits<br/>untouched</li> </ol>                                         | are        |
|     | <ol> <li>MVZ: moves only the zone digits; source and target numeric digits<br/>untouched</li> </ol>                                         | are        |
| •   | Internal representation of zoned decimal digits is                                                                                          |            |
|     | Z d Z d Z d Z d S d Z=zone digit, d=decimal digit,                                                                                          | S=sign cod |
| •   | Sign codes: (+) A, C, E, F; (-) B, D. (Preferred codes are C, D)                                                                            |            |
| Cha | ap. VIII, Sec. 27.1 System z Assembler Language                                                                                             | ©IBM 2015  |

| Zo  | oned De                          | cima     | I Constants                            |                                                        | 4         |
|-----|----------------------------------|----------|----------------------------------------|--------------------------------------------------------|-----------|
| •   | Defined                          | usin     | g constant ty                          | pe Z                                                   |           |
|     | ZCon1<br>ZCon2<br>ZCon3<br>ZCon4 |          | Z' –1'                                 | Generates X'C5C6F7F4D7'                                |           |
| •   | Only a                           | lengtl   | n modifier is                          | valid (no integer, scale, exponent)                    |           |
| •   | Decima                           | l poir   | nts in nomina                          | l values are ignored                                   |           |
|     | ZCon5<br>ZCon6                   | DC<br>DC | <b>Z</b> '1234.5'<br><b>Z</b> '1.2345' |                                                        |           |
|     |                                  |          | 0                                      | nteger and Scale attributes<br>mal point is up to you! |           |
| Cha | ap. VIII, Sec.                   | 27.2     | S                                      | ystem z Assembler Language                             | ©IBM 2015 |



| PCon1<br>PCon2<br>PCon3<br>PCon4 | DC<br>DC<br>DC | constant ty<br>P'12345'<br>P'-27,+62'<br>PL4'999'<br>PL2'12345' | Generates X'12345C'<br>Generates X'047D062C'<br>Generates X'0000999C' | (                        |
|----------------------------------|----------------|-----------------------------------------------------------------|-----------------------------------------------------------------------|--------------------------|
|                                  |                |                                                                 |                                                                       | (Truncated on left)      |
| Only a                           | Lengt          | h modifier i                                                    | s allowed                                                             |                          |
| Decima                           | poin           | ts in nomin                                                     | al values are ignore                                                  | d in generated constants |
| PCon5<br>PCon6                   | DC<br>DC       | <b>P'</b> 1234.5'<br><b>P'</b> 1.2345'                          |                                                                       |                          |
| - HLAS                           | M ass          | igns Integer                                                    | and Scale attributes:                                                 |                          |
| PCon<br>PCon                     |                | •                                                               | te = 4, Scale attribute<br>te = 1, Scale attribute                    |                          |
|                                  |                |                                                                 |                                                                       |                          |
|                                  |                |                                                                 |                                                                       |                          |

|                            | ave Assembler La<br>mnemonic D <sub>1</sub> (N <sub>1</sub> ,B <sub>1</sub> ) | 0 0 9                         |                 |   |  |  |
|----------------------------|-------------------------------------------------------------------------------|-------------------------------|-----------------|---|--|--|
| <ul> <li>Machin</li> </ul> | e instruction form                                                            | iat:                          |                 |   |  |  |
| opcode L <sub>1</sub>      |                                                                               | B <sub>2</sub> D <sub>2</sub> |                 |   |  |  |
|                            |                                                                               |                               |                 |   |  |  |
| • Each o                   | C C                                                                           | 0                             | Explicit Length | ] |  |  |
| • Each o                   | C C                                                                           | one of four forms:            | -<br>-          | ] |  |  |
| • Each o                   | perand can take o                                                             | one of four forms:            | Explicit Length | ] |  |  |





| ack ASCII:<br>ack Unicode:<br>npack ASCII:<br>npack Unicod | UNP      | PD<br>PKA AS | Target,ASCII_<br>Target,Unicod<br>CII_Target(N)<br>icode_Target( | le_Sour<br>,PDSou | rce(N)<br>urce |             |           |
|------------------------------------------------------------|----------|--------------|------------------------------------------------------------------|-------------------|----------------|-------------|-----------|
| The pack                                                   | ed decir | nal c        | perand is a                                                      | alway             | vs16 bytes     | ong (31 d   | igits)    |
| ASCII dec                                                  | imal dig | gits:        | X′30-39′;L                                                       | Jnico             | de decimal     | digits: X'( | 030-0039' |
| Instructio                                                 | n forma  | t for        | all four ins                                                     | truct             | ions:          |             |           |
|                                                            |          |              |                                                                  |                   |                |             |           |
| oncodo                                                     | •        | R1           | D1                                                               | <b>B</b> 2        | n2             |             |           |
| opcode                                                     | L        | B1           | D1                                                               | B2                | D2             |             |           |

| Printing Hexadecimal Values                                                                                                                                                              | 11        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| <ul> <li>It often helps to display data in hex</li> <li>Use UNPK and TR in these steps (we'll assume 4-byte data):</li> <li>1. Move source data to right half of a work area:</li> </ul> |           |
| WorkArea DS CL8,X  The extra byte is important!                                                                                                                                          |           |
| <ol> <li>Unpack one extra byte (at the right end):<br/>UNPK WorkArea(9),WorkArea+4(5) Extra byte is swapped</li> </ol>                                                                   |           |
| <ul> <li>3. Translate the "spread hex" to EBCDIC characters</li> <li>TR WorkArea,=C'0123456789ABCDEF'-C'0'</li> </ul>                                                                    |           |
| 4. 8 bytes at WorkArea are ready for display or print                                                                                                                                    |           |
|                                                                                                                                                                                          |           |
| Chap. VIII, Sec. 27.9 System z Assembler Language                                                                                                                                        | © IBM 201 |

| Section 28: Packed Decimal Arithmetic Overview                                                                                                                                 | 12        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| <ul> <li>Usually gives expected results <ul> <li>Operand size limitations for some operations</li> </ul> </li> <li>Notation corresponds to internal representations</li> </ul> |           |
| Packed: 12 34 56 7D written 1234567-                                                                                                                                           |           |
| Zoned: F1 F2 F3 C4 written 1234+                                                                                                                                               |           |
| • Zoned values <i>must</i> be converted to packed for arithmetic                                                                                                               |           |
|                                                                                                                                                                                |           |
| Chap. VIII, Sec. 28 System z Assembler Language                                                                                                                                | ©IBM 2015 |





| Performs an i<br>- Operands ex |    | h high-order zeros as needed |  |
|--------------------------------|----|------------------------------|--|
| 0+ treated as                  |    | 0                            |  |
| CC settings:                   |    |                              |  |
|                                | CC | Meaning                      |  |
|                                | 0  | Operand 1 = Operand 2        |  |
|                                | 1  | Operand 1 < Operand 2        |  |
|                                | 2  | Operand 1 > Operand 2        |  |
|                                |    |                              |  |
|                                |    |                              |  |
|                                |    |                              |  |
|                                |    |                              |  |
|                                |    |                              |  |
|                                |    |                              |  |

| Decimal Multiplication                                                                                                                                                                    | 16      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| <ul> <li>The product of N1-digit and N2-digit numbers is at most N1+N2 d<br/>long</li> </ul>                                                                                              | U       |
| <ul> <li>The first operand must have at least as many high-order bytes of<br/>as the number of bytes in the second operand</li> <li>So operand 1 must be longer than operand 2</li> </ul> | t zeros |
| - Operand 2 must be $\leq$ 8 bytes (15 digits) long                                                                                                                                       |         |
| <ul> <li>Signs are determined by the rules of algebra</li> </ul>                                                                                                                          |         |
| The Condition Code is unchanged                                                                                                                                                           |         |
| <ul> <li>Warning: packed decimal products depend on the order of the operands</li> </ul>                                                                                                  |         |
|                                                                                                                                                                                           |         |
|                                                                                                                                                                                           |         |
| Chap. VIII, Sec. 28.4 System z Assembler Language ©                                                                                                                                       | BM 201  |

| Decimal                                                                    | Division                                                                                                                                                                                                                                                                                                      | 17        |
|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| Before:                                                                    | dividend s After: quotient s remainder s                                                                                                                                                                                                                                                                      |           |
|                                                                            | divisor s divisor s                                                                                                                                                                                                                                                                                           |           |
| <ul> <li>It al</li> <li>Quotie</li> <li>Diviso</li> <li>Divisio</li> </ul> | emainder has the same bye length as the divisor<br>lways has the same sign as the dividend<br>ent sign is determined by the rules of algebra<br>or length must be (a) $\leq$ 8 bytes, (b) < dividend length<br>on by zero or quotient too large causes a Decimal Divid<br>tion with Interruption Code X'000B' | le        |
| - Firs                                                                     | t operand is unchanged                                                                                                                                                                                                                                                                                        |           |
| - Con                                                                      | ndition Code is unchanged; Decimal Overflow cannot occur                                                                                                                                                                                                                                                      |           |
| Chap. VIII, Se                                                             | c. 28.5 System z Assembler Language                                                                                                                                                                                                                                                                           | ©IBM 2015 |

| nem | Instructi       | ion    |        |         | Mnem | Ins               | ruction       |
|-----|-----------------|--------|--------|---------|------|-------------------|---------------|
| Р   | Add Dec         | imal   |        |         | SP   | Sub               | tract Decimal |
| P   | Multiply        | Decin  | nal    |         | DP   | Div               | de Decimal    |
| Р   | Compare Decimal |        |        | ZAP     | Zer  | o and Add Decimal |               |
| RP  | Shift and       | d Roui | nd Dec | imal    | MVO  | Mov               | e with Offset |
| onc | ode L1          | L2     | B1     | D1      | B2   | D2                |               |
| opc |                 | 12     | DI     | 10      | DZ   | 02                |               |
|     |                 |        |        |         |      |                   |               |
|     |                 |        |        | operand |      |                   |               |

| TP tes                                                                                                                                                       | ts the v         | alidity of it  |             |                  |                                   |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------|-------------|------------------|-----------------------------------|--|
| TP tests the validity of its operand. Assembler Language syntax:<br>$TP = D_1(N,B_1)$<br>Its machine instruction format differs from the other instructions: |                  |                |             |                  |                                   |  |
| орсо                                                                                                                                                         | de L             | //// B1        | D1          | ////// oj        | pcode                             |  |
| Valid A                                                                                                                                                      | Assemb           | ler Langua     |             | uction opera     | and formats:                      |  |
| F                                                                                                                                                            | Explicit Address |                |             | 1(N,B1)          | D <sub>1</sub> (,B <sub>1</sub> ) |  |
| ľ                                                                                                                                                            | Implie           | ed Address     |             | S(N)             | S                                 |  |
| Condit                                                                                                                                                       | ion Cod          | de settings:   |             |                  |                                   |  |
| Γ                                                                                                                                                            | сс               | Meaning        |             |                  |                                   |  |
| Γ                                                                                                                                                            | 0                | All digit code | s and the   | sign code are    | valid.                            |  |
|                                                                                                                                                              | 1                | The sign cod   | e is invali | d.               |                                   |  |
| Γ                                                                                                                                                            | 2                | At least one   | digit is in | valid.           |                                   |  |
|                                                                                                                                                              | 3                | The sign cod   | e and at I  | east one digit a | are invalid.                      |  |



| The lea | suit re  | places t                                             | he first operand                  |  |
|---------|----------|------------------------------------------------------|-----------------------------------|--|
| Assemb  | oler L   | anguage                                              | syntax:                           |  |
|         | AP       | $\boldsymbol{D}_1(\boldsymbol{N}_1,\boldsymbol{B}_1$ | ), $D_2(N_2,B_2)$ (Same for SP)   |  |
| Conditi | on Co    | de setti                                             | ngs:                              |  |
|         |          | сс                                                   | Indication                        |  |
|         |          | 0                                                    | Result is zero.                   |  |
|         |          | 1                                                    | Result is less than zero.         |  |
|         |          | 2                                                    | Result is greater than zero.      |  |
|         |          | 3                                                    | Decimal overflow.                 |  |
| Overflo |          |                                                      | if the first operand is too short |  |
|         | AP<br>AP | P123,P9<br>P9,P234                                   |                                   |  |
| P123    |          | <b>P'</b> +123'                                      |                                   |  |
| P234    | DC<br>DC | P'+234'<br>P'+9'                                     |                                   |  |

| Con   | Compare Decimal (CP) Instruction |                          |                                                   |           |  |  |  |  |
|-------|----------------------------------|--------------------------|---------------------------------------------------|-----------|--|--|--|--|
| -     | •                                | tions do                 | ed decimal operands<br>o not cause overflow<br>S: |           |  |  |  |  |
|       |                                  | CC                       | Indication                                        |           |  |  |  |  |
|       |                                  | 0                        | Operands are equal.                               |           |  |  |  |  |
|       |                                  | 1                        | First operand is low.                             |           |  |  |  |  |
|       |                                  | 2 First operand is high. |                                                   |           |  |  |  |  |
| • E   | CP =P                            | +3',= <b>P'</b> +        | -3' CC=2<br>-5' CC=1<br>-0' CC=0                  |           |  |  |  |  |
| Chap. | VIII, Sec. 29.4                  |                          | System z Assembler Language                       | ©IBM 2015 |  |  |  |  |

| Multiply                          | Decimal (MP) Instructi                                                                                                         | on                                   |                                                                        | 23   |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------------------------------------------|------|
| • Asser                           | nbler Language syntax:<br>MP D <sub>1</sub> (N <sub>1</sub> ,B <sub>1</sub> ),D <sub>2</sub> (N <sub>2</sub> ,B <sub>2</sub> ) |                                      |                                                                        |      |
| 2<br>1<br>• Impor<br>- The<br>ope |                                                                                                                                | > L <sub>2</sub><br>:<br>f high-orde | er zeros in the multiplicand (first<br>econd operand); a specification |      |
|                                   | 000 000 aaaa                                                                                                                   | aaaaaaaas                            | First operand (multiplicand)<br>Second operand (multiplier)            |      |
| Chap. VIII, Se                    | c. 29.5 System z                                                                                                               | Assembler La                         | nguage ©IBM                                                            | 2015 |



| SRP Instruction                                                                                                                                                                                                                       | 25   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| <ul> <li>SRP multiplies and divides by a power of 10, with optional quotient rounding</li> <li>Assembler Language syntax:<br/>SRP D<sub>1</sub>(N<sub>1</sub>, B<sub>1</sub>), D<sub>2</sub>(B<sub>2</sub>), I<sub>3</sub></li> </ul> |      |
| Machine instruction format:                                                                                                                                                                                                           |      |
| F0         L1         I3         B1         D1         B2         D2                                                                                                                                                                  |      |
| <ul> <li>Shift amount and direction determined by low-order 6 bits of second-operand Effective Address:</li> <li>B'100000' = -32 ≤ shift count ≤ +31 = B'011111'</li> <li>Examples:</li> </ul>                                        |      |
| SRP X,3,0 Multiply operand at X by 1000<br>SRP X,64-3,5 Divide operand at X by 1000, round last digit                                                                                                                                 |      |
| Possible overflow on left shifts                                                                                                                                                                                                      |      |
| Rounded results are slightly biased                                                                                                                                                                                                   |      |
| Chap. VIII, Sec. 29.7 System z Assembler Language © IBM                                                                                                                                                                               | 2015 |







| Mnem | Instruction                                                          | Mnem | Instruction                                    |
|------|----------------------------------------------------------------------|------|------------------------------------------------|
| CVB  | Convert to Binary (32)                                               | CVD  | Convert to Decimal (32)                        |
| CVBY | Convert to Binary (32)                                               | CVDY | Convert to Decimal (32)                        |
| CVBG | Convert to Binary (64)                                               | CVDG | Convert to Decimal (64)                        |
| ED   | Edit                                                                 | EDMK | Edit and Mark                                  |
| ED a | ry data is usually conve<br>and EDMK are powerful<br>ed to character | •    | acked decimal<br>le" instructions that convert |





| Editing Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                   | 32         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------|
| Ũ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | age syntax for ED and EDMK:<br>I,B,),D2(B2) or Pattern(N),PackData                                                                |            |
| Machine instructi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                   |            |
| opcode L B <sub>1</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | $D_1$ $B_2$ $D_2$                                                                                                                 |            |
| • The basic operation of the basic operation | ion of the instructions:<br>$  \rightarrow edit \rightarrow C C C C C C C C C C C a ED, EDMK EBCDIC characters replacing patter $ | C<br>n     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | the pattern (first operand), the instruction map<br>ed packed decimal data into EBCDIC character                                  |            |
| <ul> <li>The editing proc</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ess scans the pattern once, from left to right                                                                                    |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                   |            |
| Chap. VIII, Sec. 30.3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | System z Assembler Language                                                                                                       | © IBM 2015 |

| pro  | iting actions depend on which pattern character (PC) is being<br>ocessed, and<br>What happened previously, as determined by CPU's <i>Significance Inc</i><br>(SI)                                            |     |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| • Th | ere are five types of pattern characters (PCs):                                                                                                                                                              |     |
| 1.   | Fill Character (FC), may have any value; the first byte of the patter                                                                                                                                        | n   |
| 2.   | Digit Selector (DS), $X'20'$ (DS notated <b>d</b> )                                                                                                                                                          |     |
|      | <ul> <li>If a nonzero data digit has been processed previously, or the SI is 1, or th<br/>digit is nonzero, it is converted to EBCDIC and the SI is set to 1. Otherwis<br/>is replaced by the FC.</li> </ul> |     |
| 3.   | Digit Selector and Significance Start (SS), X'21' (SS notated s)                                                                                                                                             |     |
|      | <ul> <li>The SI is set to 1; if the current digit is nonzero, it is converted to EBCDIC<br/>Otherwise the SS is replaced by the FC.</li> </ul>                                                               | ;.  |
| 4.   | Field Separator (FS), $X'22'$ (FS notated <b>f</b> )                                                                                                                                                         |     |
|      | - The SI is reset to 0, and the FS is replaced by the FC.                                                                                                                                                    |     |
| 5.   | Message character having any other value; unchanged or replaced - Things like decimal points, currency signs, $\pm/-$ signs, and text like CREDI                                                             |     |
| • A  | pattern like X'402020204B202120' is represented by C' $\bullet$ ddd,ds                                                                                                                                       | sd' |

| •                                                   | Each edit step produces one of three results, in this priority:                                                                                                            |                                                                                           |                                                       |   |  |  |  |  |  |  |
|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-------------------------------------------------------|---|--|--|--|--|--|--|
|                                                     |                                                                                                                                                                            |                                                                                           | purce digit replaces a DS or SS in the pattern        |   |  |  |  |  |  |  |
|                                                     | If: the digit is nonzero, or the SI is ON                                                                                                                                  |                                                                                           |                                                       |   |  |  |  |  |  |  |
|                                                     | 2. The FC replaces the pattern character                                                                                                                                   |                                                                                           |                                                       |   |  |  |  |  |  |  |
|                                                     | <ul><li>If: the SI is OFF, or the pattern character is FS</li><li>3. The pattern character is unchanged<br/>If: the SI is ON, or the pattern character is the FC</li></ul> |                                                                                           |                                                       |   |  |  |  |  |  |  |
|                                                     |                                                                                                                                                                            |                                                                                           |                                                       |   |  |  |  |  |  |  |
|                                                     |                                                                                                                                                                            |                                                                                           |                                                       |   |  |  |  |  |  |  |
| •                                                   | SI settings:                                                                                                                                                               |                                                                                           |                                                       |   |  |  |  |  |  |  |
|                                                     | OFF: (1) at start, (2) after FS, (3) source byte has + code in digit                                                                                                       |                                                                                           |                                                       |   |  |  |  |  |  |  |
|                                                     | ON:                                                                                                                                                                        | if no + code in rightmost digit, then (1) SS and valid digit,<br>(2) DS and nonzero digit |                                                       |   |  |  |  |  |  |  |
| •                                                   | CC settings:                                                                                                                                                               |                                                                                           |                                                       |   |  |  |  |  |  |  |
|                                                     |                                                                                                                                                                            | cc                                                                                        | Meaning                                               | ] |  |  |  |  |  |  |
|                                                     |                                                                                                                                                                            | 0                                                                                         | All source digits 0, or no digit selectors in pattern |   |  |  |  |  |  |  |
|                                                     |                                                                                                                                                                            | 1                                                                                         | Nonzero source digits, and SI is ON (result < 0)      |   |  |  |  |  |  |  |
| 2 Nonzero source digits, and SI is OFF (result > 0) |                                                                                                                                                                            |                                                                                           |                                                       |   |  |  |  |  |  |  |

| 1. | A small                                       | num                                  | ber                                              |                                                                                                                                |     |  |  |  |
|----|-----------------------------------------------|--------------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|
|    |                                               | MVC PgNum,PgNPat<br>ED PgNum(4),PgNo |                                                  | Copy pattern to result area<br>Convert to characters                                                                           |     |  |  |  |
|    | PgNo<br>PgNum<br>PgNPat                       | DS                                   | PL2'7'<br>CL4<br>C' ',3X'20'                     | Page number 007+<br>Edited result = C'•••7'<br>Pattern = C' ddd'                                                               |     |  |  |  |
|    | A zero value converts to all blanks!          |                                      |                                                  |                                                                                                                                |     |  |  |  |
| 2. | 32-bit binary integer; note SS before last DS |                                      |                                                  |                                                                                                                                |     |  |  |  |
|    |                                               |                                      | LineX,Pat                                        | Get nonnegative binary number<br>Convert to packed decimal<br>Move pattern to print line<br>Start edit with high-order digits  |     |  |  |  |
|    | Num<br>WorkArea<br>Pat<br>LineX               |                                      | F'1234567890'<br>D<br>C' ',9X'20',X'2120<br>CL12 | Number to be printed<br>8-byte work area for CVD<br>' Pattern = C'•dddddddd <u>s</u> d'<br>Edited result here, C'••1234567890' |     |  |  |  |
|    |                                               |                                      | ts after 4 high-orde<br>lys at least one dig     | r zero digits; the SS ensures that a ze<br>it                                                                                  | ero |  |  |  |

| Inserting                               | com                               | mas in large inte                             | eger values (see Example 2 on slic                                                                                                                | de 35)     |
|-----------------------------------------|-----------------------------------|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------------|
|                                         | ED                                | LineX,WorkArea+2                              | Edit 11 decimal digits                                                                                                                            |            |
| Num                                     |                                   | F'1234567890'                                 |                                                                                                                                                   |            |
| WorkArea<br>Pat<br>LineX                | DC                                |                                               | $\textbf{X}'2120'$ $\textbf{C}' \bullet \textbf{ss}, \textbf{sss}, \textbf{sds}'$ $(\textbf{X}'6\textbf{B}'$ is a                                 | comma)     |
| Editing n                               | egat                              | ive values (like a                            | a credit on a charge-card bill)                                                                                                                   |            |
|                                         | MVC<br>ED                         | LinB,Pat2<br>LinB,Balance                     |                                                                                                                                                   |            |
| Balance<br>Pat2<br>PatX<br>Line<br>LinB | DC<br>DC<br>Equ<br>DC<br>DC<br>DS | C' ',X'20206B20202<br>*<br>C' Your account ba | Credit balance of \$123.45<br>21482020',C' CREDIT' Pattern = C'•dd,dd<br>Used for defining length of Pat2<br>Nance is'<br>Space for edited result | s.dd∙CRED] |
|                                         |                                   | ce is -\$123.45 (the<br>t•Balance•is••••12    | bank owes you) the result is<br>23.45•CREDIT                                                                                                      |            |
|                                         |                                   | ce is +\$321.09 (yo<br>t•Balance•is•●●32      | u owe the bank) the result is<br>21.09•••••••                                                                                                     |            |

| – Ifth                           | e SI is                    | itical to ED, exc<br>OFF when the firs<br>out in GR1 | t significant digit is zoned into the pattern, it                                                                    | s   |
|----------------------------------|----------------------------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-----|
| <ul> <li>Example</li> </ul>      | ole: a "                   | floating" curren                                     | cy symbol                                                                                                            |     |
|                                  | MVC<br>Edmk<br>BCTR<br>MVI | LPat,PayPat<br>LPat,PayAmt<br>1,0<br>0(1),C′\$′      | Move pattern to Line<br>Edit and Mark result<br>Decrement GR1 (move left one byte)<br>Put \$ sign before first digit |     |
| PayAmi<br>PayPai<br>Line<br>LPat | DC<br>DC                   | • •                                                  |                                                                                                                      |     |
|                                  |                            | nificant digit is t<br>nanged                        | forced by a SS, the SI will be ON and G                                                                              | àR1 |

| Editing N                 | lultipl  | e Fields (*)                                                      |                                                      | 38                      |
|---------------------------|----------|-------------------------------------------------------------------|------------------------------------------------------|-------------------------|
| - A fie                   | ld sepa  | arator (FS) (1) s                                                 | K can edit multiple fi<br>ets the SI OFF, and (2)    |                         |
| <ul> <li>Examp</li> </ul> |          | •                                                                 | decimal values                                       |                         |
|                           | ED       | Pat2,PD2<br>-                                                     | Edit two packed dec                                  | imal values             |
| PD2<br>Pat2               | DC<br>DC | <b>P'</b> +024', <b>P'</b> − <b>135</b><br><b>X'</b> 402021204022 | <b>′ Two values</b><br>202120 <b>′ C'∙dsdf•dsd</b> ′ |                         |
| – The                     | result i | is C'••24••135'                                                   |                                                      |                         |
|                           |          |                                                                   | one nonzero digit forc<br>placed in GR1              | ces the SI ON, only the |
| - The                     | SI will  | then be OFF if                                                    | that digit has a + code                              | in the right digit      |
|                           |          |                                                                   |                                                      |                         |
|                           |          |                                                                   |                                                      |                         |
|                           |          |                                                                   |                                                      |                         |
|                           |          |                                                                   |                                                      |                         |

| Pattern<br>Character (PC) | Get<br>Source<br>Digit? | SI  | Source<br>Digit | Result    | Set<br>SI | Sign code in right digit?                             |
|---------------------------|-------------------------|-----|-----------------|-----------|-----------|-------------------------------------------------------|
|                           |                         | 1   | Any             | ZD        | 1         | If +, set SI OFF;                                     |
| X'20' (DS)                | Yes                     | 0   | Nonzero         | ZD        | 1         | otherwise, leave it                                   |
|                           |                         | 0   | Zero            | Fill Char | 0         | unchanged                                             |
|                           |                         | 1   | Any             | ZD        | 1         | If +, set SI OFF;<br>otherwise, leave it<br>unchanged |
| X'21' (SS)                | Yes                     | 0   | Nonzero         | ZD        | 1         |                                                       |
|                           |                         | 0   | Zero            | Fill Char | 1         |                                                       |
| X'22' (FS)                | No                      | -   | _               | Fill Char | 0         | No source byte is examined                            |
|                           | NL-                     | 0   | _               | Fill Char | 0         | No source byte is                                     |
| Other (MC)                | No                      | 1   | _               | MC        | 1         | examined                                              |
| Fill Character<br>(FC)    | No                      | N/A | _               | Fill Char | 0         | N/A                                                   |
| These are                 | complex                 |     | owerful ins     |           |           | ©IBM                                                  |

| •   | We use so<br>and displa | ome simple macro instructions for input, output, convers<br>ay                                                                                                     | sion,    |
|-----|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|     | CONVERTI                | converts decimal characters in memory to 32- or 64-b<br>binary integers in a general register                                                                      | it       |
|     | CONVERTO                | converts 32- or 64-bit binary integers in a general reg<br>to decimal characters, or contents of a floating-point<br>register to hexadecimal characters, in memory | ister    |
|     | DUMPOUT                 | displays the contents of storage in hexadecimal and character formats                                                                                              |          |
|     | PRINTLIN                | sends a string of characters to a printer file                                                                                                                     |          |
|     | PRINTOUT                | displays the contents of registers and of named areas memory, and/or terminates execution                                                                          | of       |
|     | READCARD                | reads an 80-byte record from an input file to a specific area of memory                                                                                            | əd       |
| •   | Each mac section        | ro calls an entry point in an automatically generated co                                                                                                           | ntrol    |
| Арр | endix B                 | System z Assembler Language ©                                                                                                                                      | IBM 2015 |

| The macro           | descriptions use these terms:                                                                      |
|---------------------|----------------------------------------------------------------------------------------------------|
| <name></name>       | a symbol naming an area of memory addressable from the macro                                       |
| <number></number>   | a self-defining term (or a predefined absolute symbol)<br>with value limits specified by the macro |
| <d(b)></d(b)>       | specifies an addressable base-displacement operand                                                 |
| <address></address> | specifies a <name> or <d(b)></d(b)></name>                                                         |
| <nfs></nfs>         | an optional name-field symbol on a macro                                                           |
| [item]              | [ ] indicates an optional item                                                                     |
| •••                 | indicates that the preceding item may be repeated                                                  |
| Referring t         | o registers:                                                                                       |
| - Numbers           | 0-15 refer to 32-bit general registers 0-15                                                        |
| - Numbers           | 16-31 refer to 64-bit general registers 0-15                                                       |
| - Numbers           | 32-47 refer to Floating-Point registers 0-15                                                       |





| The DUMPOUT Macro Instruction 5                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>DUMPOUT prints a formatted display of memory (a "dump")</li> <li><nfs> DUMPOUT <address>[,<address>]</address></address></nfs></li> </ul>                                                                                                  |
| <ul> <li>If only one operand is present, only one line is dumped</li> <li>If both operands are present, the dump is from the lower address to the higher</li> </ul>                                                                                 |
| Each line starts on a word boundary and displays 32 bytes                                                                                                                                                                                           |
| - The first line contains the byte at the lower address                                                                                                                                                                                             |
| - The last line contains the byte at the higher address                                                                                                                                                                                             |
| • Example:                                                                                                                                                                                                                                          |
| Dumpout A,B Dump,including bytes from A to B                                                                                                                                                                                                        |
| <ul> <li>produces something like this:</li> </ul>                                                                                                                                                                                                   |
| *** DUMPOUT REQUESTED AT ADDRESS 01A102, STATEMENT 797, CC=0<br>01A000 1B1190EF F00C58F0 F01405EF 00F12802 0001A000 0001A204 F001A002 00000006 *0.001S.0<br>01A020 98EFE000 070090EF F03058F0 F03805EF 00F12802 0001A000 8001A22C 0001A026 *Q0.0001 |
| Sec. B.1.3 System z Assembler Language © IBM 201                                                                                                                                                                                                    |

| Tł  | e PRINTLIN Macro Instruction 6                                                                                                                                                                                                                                    |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •   | PRINTLIN sends up to 121 characters to a print file<br><nfs> PRINTLIN <address>[,<number>]</number></address></nfs>                                                                                                                                               |
|     | <ul> <li>The character string starts at <address></address></li> <li><number> is the number of characters (at most 121)</number></li> <li>If <number> is omitted, it is assumed to be 121</number></li> </ul>                                                     |
| •   | The first character is used for vertical spacing ("carriage control") and is not printed:                                                                                                                                                                         |
|     | <ul> <li>EBCDIC ' ' (blank) means single space</li> <li>EBCDIC '0' (zero) means double space</li> <li>EBCDIC '-' (minus) means triple space</li> <li>EBCDIC '1' (one) means start at the top of a new page</li> <li>EBCDIC '+' (plus) means no spacing</li> </ul> |
| •   | Example:                                                                                                                                                                                                                                                          |
|     | PrTtl PRINTLIN Title                                                                                                                                                                                                                                              |
|     | Title DC CL121'lTitle for Top Line of a Page'                                                                                                                                                                                                                     |
| Sec | B.1.4 System z Assembler Language © IBM 2015                                                                                                                                                                                                                      |



| he READ     |             | Acro Instruction                                             |  |
|-------------|-------------|--------------------------------------------------------------|--|
| READCAR     | D reads {   | 30-byte records into your program                            |  |
| <nfs></nfs> | READCARD    | <address>[,<address>]</address></address>                    |  |
| - The f     | irst operar | nd specifies the location in your program for the record     |  |
| – If no     | records re  | main ("end of file", EOF)                                    |  |
|             |             | operand is present, control is returned to that location     |  |
| 2. If       | the second  | operand is omitted, the program is terminated with a message |  |
|             | *** Execut  | tion terminated by Reader EOF                                |  |
| <b>F</b>    |             |                                                              |  |
| Example     | 9:          |                                                              |  |
| GetARec     | READCARD    | MyRecord, EndFile                                            |  |
| EndFile     |             | Do something about no more records                           |  |
|             |             |                                                              |  |
|             |             |                                                              |  |
|             |             |                                                              |  |
|             |             |                                                              |  |
|             |             |                                                              |  |



| • | All the macros must execute in 24-bit addressing mode, AMODE(24), and reside below the 16MB "line", RMODE(24)                                                                               |
|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | The instructions generated by the macros are self-modifying, as is the generated "service" control section; programs using these macros are not reenterable                                 |
| • | Most operands of the form <address>, <name>, and <number> are<br/>resolved in S-type address constants, so addressability is required<br/>when a macro is invoked</number></name></address> |
| • | Be careful not to reference areas outside your program                                                                                                                                      |
| • | At most 8 characters of <name> and <d(b)> operands are displayed by PRINTOUT</d(b)></name>                                                                                                  |
|   |                                                                                                                                                                                             |
|   |                                                                                                                                                                                             |