|                    |                                               |                                  |                      |                              |                             | 04 Sep 2025 12:07:22 Page 1                                                                                                  |
|--------------------|-----------------------------------------------|----------------------------------|----------------------|------------------------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------|
| LOC                | OBJECT CODE                                   | ADDR1                            | ADDR2                | STMT                         |                             |                                                                                                                              |
|                    |                                               |                                  |                      | 2 * 3 *                      | Jurge                       | Winkelmann's MSA-5 'PRNO' instruction test                                                                                   |
|                    |                                               |                                  |                      | 4 *<br>5 *<br>6 *            |                             | module tests the PRNO instruction standalone environment.                                                                    |
|                    |                                               |                                  |                      | 7 *<br>8 *                   | Opera                       |                                                                                                                              |
|                    |                                               |                                  |                      | 9 *<br>10 *<br>11 *          |                             | TEST exercises PRNO QUERY, DRNG, and TRNG functions does plausibility checks on the results.                                 |
|                    |                                               |                                  |                      | 12 *<br>13 *<br>14 *<br>15 * |                             | all tests pass, PRNOTEST enters a disabled wait state the a PSW address of X'000000000000000000000000000000000000            |
|                    |                                               |                                  |                      | 16 *<br>17 *<br>18 *         | - I <sup>.</sup>            | a test fails, the test sequence is aborted a disabled wait state X'00000000000EAD' is entered.                               |
|                    |                                               |                                  |                      | 19 * Fi<br>20 *<br>21 *      | ish 2025-09                 | <ul><li>1. Do each test for each addressing mode too</li><li>2. Added GitHub #765 test ==&gt; Addressing Exception</li></ul> |
|                    |                                               |                                  |                      | 22 *<br>23<br>40             | PRINT<br>PRINT              |                                                                                                                              |
| 000000             |                                               | 00000000<br>00000000<br>00000000 | 000007FF<br>000001A0 | 41 PRNC<br>42<br>43          | OTEST CSECT<br>USING<br>ORG | *,0<br>PRNOTEST+X'1A0' # z/Arch restart PSW                                                                                  |
| 0001A0             | 00000000 00000000                             |                                  |                      |                              | RTNEW DC<br>DC<br>DC        | X'000000000000000000000000000000000000                                                                                       |
| 00001B0<br>00001D0 | 00020000 00000000                             | 000001B0                         | 000001D0             | 47<br>48 PROG<br>49 **       | ORG                         | PRNOTEST+X'1D0' # z/Arch pgm new PSW X'0002000000000000000000000000000000000                                                 |
| 0001E0             |                                               | 000001E0                         | 00000200             | 50 **<br>51<br>52 ***        | DC<br>ORG                   | X'0002000180000000000000000000DEAD' # z/Arch pgm new PSW (64-bit n<br>PRNOTEST+X'200'                                        |
| 000200             | C001 0000 0000                                |                                  |                      | 53 ***<br>54 ***<br>55       | QUERY<br>LGFI               | R0,0 R0->function code 0                                                                                                     |
| 0000206<br>000020C | D2EF 0480 0600<br>4110 0480<br>B93C 0024      | 00000480                         | 00000600<br>00000480 | 56<br>57<br>58               | MVC<br>LA<br>PRNO           | PB(240),PBNULL clear parameter block R1,PB R1->parameter block R2,R4 perform random number operation                         |
| 0000214            | D50F 06F0 0480<br>4780 0220                   | 000006F0                         | 00000480<br>00000220 | 59<br>60<br>61               | CLC<br>BE<br>DC             | ERQUERY(16),PB compare with expected result *+6 result OK H'0' disabled wait DEAD if result invalid                          |
|                    |                                               |                                  |                      | 62 ***<br>63 ***<br>64 ***   |                             | FIPS known answer test                                                                                                       |
| 0000226            | C001 0000 0083<br>D2EF 0480 0600<br>4110 0480 | 00000480                         | 00000600<br>00000480 | 65<br>66<br>67               | LGFI<br>MVC<br>LA           | R0,131 R0->function code 3 with modifier: seed PB(240),PBNULL clear parameter block R1,PB R1->parameter block                |
| 0000230<br>0000234 | 4120 0800<br>C031 0000 0000<br>4140 0570      |                                  | 00000800             | 68<br>69<br>70               | LA                          | R2,F0 R2->first operand address R3,0 R3->first operand length R4,S0 R2->second operand address                               |
| 000023E            | C051 0000 0040<br>D23F 0570 0708<br>B93C 0024 | 00000570                         | 00000708             | 71<br>72<br>73               |                             | R5,64 R3->second operand length SO(64),ENTROPY provide predefined entropy R2,R4 perform random number seed operation         |

DC

X'105A3783CFE0BF5A'

185

00000710 105A3783 CFE0BF5A

FIPS known answer test

| SMA Ver. 0.7.0 Standalone Test PRNO Instruction | 04 Sep 2025 12:07:22 Page | 6 |
|-------------------------------------------------|---------------------------|---|
| ACRO DEFN REFERENCES                            |                           |   |
| o defined macros                                |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |
|                                                 |                           |   |

