# IBM 1620 Simulator Usage 01-Dec-2008

#### **COPYRIGHT NOTICE**

The following copyright notice applies to the SIMH source, binary, and documentation:

Original code published in 1993-2008, written by Robert M Supnik Copyright (c) 1993-2008, Robert M Supnik

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL ROBERT M SUPNIK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Except as contained in this notice, the name of Robert M Supnik shall not be used in advertising or otherwise to promote the sale, use or other dealings in this Software without prior written authorization from Robert M Supnik.

| 1 | Sim | ulator Files                      | 3  |
|---|-----|-----------------------------------|----|
|   |     | 1620 Features                     |    |
|   |     | CPU                               |    |
|   | 2.2 | Console Typewriter (TTY)          | 6  |
|   |     | 1621 Paper Tape Reader (PTR)      |    |
|   | 2.4 | 1624 Paper Tape Punch (PTP)       | 6  |
|   |     | 1622 Card Reader/Punch (CDR, CDP) |    |
|   | 2.6 | 1443 Line Printer (LPT)           | 8  |
|   | 2.7 | 1311 Disk Pack (DP)               | 8  |
| 3 | Sym | nbolic Display and Input          | 9  |
| 4 | Cha | racter Sets                       | 10 |

This memorandum documents the IBM 1620 simulator. This simulator is based on Geoff Kuenning's 1620 simulator, which is used by permission.

## 1 Simulator Files

sim/ scp.h sim\_console.h sim defs.h sim\_fio.h sim\_rev.h sim sock.h sim\_timer.h sim\_tmxr.h scp.c sim\_console.c sim fio.c sim\_sock.c sim\_timer.c sim\_tmxr.c sim/i1620/ i1620\_defs.h i1620\_cpu.c i1620\_fp.c i1620 tty.c i1620\_pt.c i1620 cd.c i1620 lp.c i1620\_dp.c i1620\_sys.c

# 2 IBM 1620 Features

The IBM 1620 simulator is configured as follows:

| device names | simulates                                                                                                                                        |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU          | IBM 1620 Model 1 or Model 2 CPU with 20K to 60K memory Model 1 options: indirect addressing, automatic divide, edit instructions, floating point |
|              | Model 2 options: indexing, binary capability, floating                                                                                           |
|              | point                                                                                                                                            |
| TTY          | IBM console terminal                                                                                                                             |
| PTR          | IBM 1621 paper tape reader                                                                                                                       |
| PTP          | IBM 1624 paper tape punch                                                                                                                        |
| CDR, CDP     | IBM 1622 card reader/punch                                                                                                                       |
| LPT          | IBM 1443 line printer                                                                                                                            |
| DP           | IBM 1311 disk pack with four drives                                                                                                              |

The IBM 1620 simulator implements many unique stop conditions. On almost any kind of error the simulator stops:

- Unimplemented opcode
- Reference to non-existent device

- Invalid digit
- Invalid alphameric character
- Invalid P address digit
- Invalid Q address digit
- Indirect address limit exceeded
- Invalid odd address
- Invalid even address
- Invalid function
- Invalid indicator
- Invalid return address register
- Skip to unpunched carriage control tape channel
- Card reader hopper empty
- Overflow with arithmetic stop switch set
- I/O error with I/O stop switch set
- Invalid disk drive
- Invalid disk sector address
- Invalid disk sector count
- Invalid disk buffer address
- Disk address compare error
- Disk cylinder overflow error
- Disk write check error
- Field exceeds memory
- Record exceeds memory
- Floating point mantissa exceeds maximum length
- Floating point mantissas not the same length
- Floating point exponent check with arithmetic stop switch set
- Floating point exponent missing high flag

The LOAD command is used to load a line printer carriage-control tape. The DUMP command is not implemented.

### 2.1 CPU

The CPU options include the CPU model (Model 1 or Model 2), a number of special features, and the size of main memory.

```
SET CPU IA
                             enable indirect addressing
                             disable indirect addressing
SET CPU NOIA
SET CPU EDT
                             enable extra editing instructions
SET CPU NOEDT
                             disable extra editing instructions
SET CPU DIV
                            enable divide instructions
SET CPU NODIV
                            disable divide instructions
SET CPU IDX
                            enable indexing
SET CPU NOIDX
                             disable indexing
SET CPU BIN
                             enable binary instructions
SET CPU NOBIN
                             disable binary instructions
                             enable floating point instructions
SET CPU FP
SET CPU NOFP
                             disable floating point instructions
SET CPU MOD1
                             set Model 1
                             set Model 2
SET CPU MOD2
SET CPU 20K
                             set memory size = 20K
SET CPU 40K
                             set memory size = 40K
SET CPU 60K
                             set memory size = 60K
```

Model 1 options include IA, EDT, DIV, and FP; the first three are on by default. Model 2 options include IDX, BIN, and FP; IA, EDT, and DIV are standard on the Model 2.

If memory size is being reduced, and the memory being truncated contains non-zero data, the simulator asks for confirmation. Data in the truncated portion of memory is lost. Initially, the CPU is a Model 1, memory size is 20K, and indirect addressing, editing instructions, and divide are enabled.

Memory is implemented as 5 bit BCD digits, as follows:

In BCD, the decimal digits 0-9 are (hex) values 0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, respectively. 0xA is record mark, 0xC non-punching blank, and 0xF group mark, respectively.

CPU registers include the visible state of the processor. The 1620 has no interrupt system.

| name       | size     | comments                                                             |
|------------|----------|----------------------------------------------------------------------|
| IR1<br>IR2 | 16<br>16 | <pre>instruction storage address register (PC) return register</pre> |
| PR1        | 16       | processor register 1                                                 |
| PAR        | 16       | P address register (OR2)                                             |
| OAR        | 16       | Q address register (OR1)                                             |
| SS1        | 1        | sense switch 1                                                       |
| SS2        | 1        | sense switch 2                                                       |
| SS3        | 1        | sense switch 3                                                       |
| SS4        | 1        | sense switch 4                                                       |
| HP         | 1        | high/positive indicator                                              |
| EZ         | 1        | equal/zero indicator                                                 |
| ARCHK      | 1        | arithmetic check (overflow) indicator                                |
| EXPCHK     | 1        | exponent check indicator                                             |
| RDCHK      | 1        | read check indicator                                                 |
| WRCHK      | 1        | write check indicator                                                |
| ARSTOP     | 1        | arithmetic check stop switch                                         |
| IOSTOP     | 1        | I/O check stop switch                                                |
| IND[0:99]  | 1        | indicator array                                                      |
| IAE        | 1        | indirect address enable (Model 2 only)                               |
| IDXE       | 1        | indexing enable (Model 2 only)                                       |
| IDXB       | 1        | indexing band select (Model 2 only)                                  |
| IR1Q[0:63] | 16       | IR1 prior to last branch;                                            |
|            |          | most recent IR1 change first                                         |
| WRU        | 8        | nterrupt character                                                   |

The CPU can maintain a history of the most recently executed instructions. This is controlled by the SET CPU HISTORY and SHOW CPU HISTORY commands:

```
SET CPU HISTORY clear history buffer

SET CPU HISTORY=0 disable history

SET CPU HISTORY=n enable history, length = n

SHOW CPU HISTORY print CPU history

SHOW CPU HISTORY=n print first n entries of CPU history
```

The maximum length for the history is 65536 entries.

# 2.2 Console Typewriter (TTY)

The console typewriter (TTY) is a half-duplex console. The typewriter registers are:

| name | size | comments         |
|------|------|------------------|
| COL  | 7    | current column   |
| TIME | 24   | polling interval |

When the 1620 CPU requests input from the keyboard, a greater than sign (>) is printed. The CPU hangs waiting for input until the return/enter key is pressed. The typewriter has no errors.

## 2.3 1621 Paper Tape Reader (PTR)

The paper tape reader (PTR) reads data from a disk file. The POS register specifies the number of the next data item to be read. Thus, by changing POS, the user can backspace or advance the reader.

The paper tape reader supports the BOOT command. BOOT PTR starts the standard paper tape boot sequence at location 0.

The paper tape reader implements these registers:

| name | size | comments |    |     |       |      |
|------|------|----------|----|-----|-------|------|
| POS  | 32   | position | in | the | input | file |

#### Error handling is as follows:

| error        | IOCHK  | processed as                                                |
|--------------|--------|-------------------------------------------------------------|
| not attached | X      | set RDCHK indicator, report error, stop                     |
| end of file  | X      | set RDCHK indicator, report error, stop                     |
| OS I/O error | Х      | set RDCHK indicator, report error, stop                     |
| parity error | 1<br>0 | set RDCHK indicator, report error, stop set RDCHK indicator |

# 2.4 1624 Paper Tape Punch (PTP)

The paper tape punch (PTP) writes data to a disk file. The POS register specifies the number of the next data item to be written. Thus, by changing POS, the user can backspace or advance the punch.

The paper tape punch implements these registers:

| name | size | comments |    |     |        |      |
|------|------|----------|----|-----|--------|------|
| POS  | 32   | position | in | the | output | file |

#### Error handling is as follows:

| error | IOCHK | processed as |
|-------|-------|--------------|
|       |       |              |

| not attached | X | set | WRCHK | indicator,           | report | error, | stop |
|--------------|---|-----|-------|----------------------|--------|--------|------|
| OS I/O error | X | set | WRCHK | indicator,           | report | error, | stop |
| invalid char | 1 |     |       | indicator, indicator | report | error, | stop |

# 2.5 1622 Card Reader/Punch (CDR, CDP)

The IBM 1622 card/reader punch is simulated as two independent devices: the card reader (CDR) and the card punch (CDP).

The card reader supports the BOOT command. BOOT CDR starts the standard card boot sequence at location 0.

The card reader reads data from a disk file, while the punch writes data to a disk file. Cards are simulated as ASCII text lines with terminating newlines. For each device, the POS register specifies the number of the next data item to be read or written. Thus, by changing POS, the user can backspace or advance these devices.

#### The card reader registers are:

| name | size | comments                          |
|------|------|-----------------------------------|
| LAST | 1    | last card indicator               |
| POS  | 32   | position in the reader input file |

#### The card punch registers are:

| name | size | comments                          |
|------|------|-----------------------------------|
| POS  | 32   | position in the punch output file |

#### Card reader error handling is as follows:

| error        | IOCHK  | processed as                                             |      |
|--------------|--------|----------------------------------------------------------|------|
| end of file  | Х      | set RDCHK indicator, report error, s                     | stop |
| not attached | X      | set RDCHK indicator, report error, s                     | stop |
| OS I/O error | X      | set RDCHK indicator, report error, s                     | stop |
| invalid char | 1<br>0 | set RDCHK indicator, report error, s set RDCHK indicator | stop |

#### Card punch error handling is as follows:

| error        | IOCHK | processed | as |     |       |                      |        |        |      |
|--------------|-------|-----------|----|-----|-------|----------------------|--------|--------|------|
| not attached | ł.    | Х         | S  | set | WRCHK | indicator,           | report | error, | stop |
| OS I/O error | -     | Х         | S  | set | WRCHK | indicator,           | report | error, | stop |
| invalid char | :     | 1 0       |    |     |       | indicator, indicator | report | error, | stop |

## 2.6 1443 Line Printer (LPT)

The IBM 1443 line printer (LPT) writes its data, converted to ASCII, to a disk file. The line printer can be programmed with a carriage control tape. The LOAD command loads a new carriage control tape:

```
LOAD <file> load carriage control tape file
```

The format of a carriage control tape consists of multiple lines. Each line contains an optional repeat count, enclosed in parentheses, optionally followed by a series of column numbers separated by commas. Column numbers must be between 1 and 12; a column number of zero denotes top of form. The following are all legal carriage control specifications:

| <br><br>dank line> | no punch                       |
|--------------------|--------------------------------|
| (5)                | 5 lines with no punches        |
| 1,5,7,8            | columns 1, 5, 7, 8 punched     |
| (10)2              | 10 lines with column 2 punched |
| 1,0                | column 1 punched; top of form  |

The default form is 66 lines long, with column 1 and the top of form mark on line 1, and the rest blank.

The line printer registers are:

| name        | size | comments                                 |  |  |  |
|-------------|------|------------------------------------------|--|--|--|
| LBUF[0:119] | 7    | line buffer                              |  |  |  |
| BPTR        | 7    | buffer pointer                           |  |  |  |
| PCTL        | 8    | saved print control directive            |  |  |  |
| PRCHK       | 1    | print check indicator                    |  |  |  |
| PRCH9       | 1    | channel 9 indicator                      |  |  |  |
| PRCH12      | 1    | channel 12 indicator                     |  |  |  |
| POS         | 32   | position in the output file              |  |  |  |
| CCT[0:131]  | 32   | carriage control tape array              |  |  |  |
| CCTP        | 8    | carriage control tape pointer            |  |  |  |
| CCTL        | 8    | carriage control tape length (read only) |  |  |  |

#### Error handling is as follows:

| error        | IOCHK  | processed as                                          |
|--------------|--------|-------------------------------------------------------|
| not attached | X      | set PRCHK, WRCHK, report error, stop                  |
| OS I/O error | X      | set PRCHK, WRCHK, report error, stop                  |
| invalid char | 1<br>0 | set PRCHK, WRCHK, report error, stop set PRCHK, WRCHK |

# 2.7 1311 Disk Pack (DP)

The disk pack controller supports 4 drives, numbered 0 through 3. Disk pack options include the ability to enable address writing (formatting).

```
SET DPn ADDROFF set unit n address enable off SET DPn ADDRON set unit n address enable on
```

Units can also be set ENABLED or DISABLED.

Unlike most simulated disks, the 1311 includes explicit representation for sector addresses. This is to support non-standard formats, such as the inclusion of the drive number in the sector address. As a result, 1311 sectors are 105 digits long: 5 address digits and 100 data digits. If the 1311 has not been formatted, the addresses are zeroes and are synthesized, if needed, based on the sector number.

The disk pack controller implements these registers:

| name   | size | comments                                |
|--------|------|-----------------------------------------|
|        |      |                                         |
| ADCHK  | 1    | address check (compare error) indicator |
| WLRC   | 1    | wrong length record check indicator     |
| CYLO   | 1    | cylinder overflow check indicator       |
| ERR    | 1    | disk error indicator                    |
| DPSTOP | 1    | disk check stop                         |

#### Error handling is as follows:

| error        | DPCHK | processed as                          |
|--------------|-------|---------------------------------------|
| not attached | Х     | set ERR indicator, report error, stop |

1311 data files are buffered in memory; therefore, end of file and OS I/O errors cannot occur.

# 3 Symbolic Display and Input

The IBM 1620 simulator implements symbolic display and input. Display is controlled by command line switches:

```
-c display as single character (alphameric for CPU and DP, ASCII for others)
-s display as flag terminated alphameric string (CPU and DP only)
-m display instruction mnemonics (CPU and DP only)
-d display 50 characters per line, with flags denoted by
" " on the line above
```

Input parsing is controlled by the first character typed in or by command line switches:

```
' or -c character (alphameric for CPU and DP, ASCII for others)
" or -s alphameric string (CPU and DP only)
alphabetic instruction mnemonic (CPU and DP only)
numeric octal number
```

Instruction input is free format and consists of an opcode and up to three operands:

```
op {+/-}ppppp{(idx)}, {+-}qqqqq{(idx)},flags
```

The p address and, if present, the q address, are always decimal. A plus sign is ignored; a minus sign denotes indirect addressing (or a negative immediate operand). If indexing is enabled, addresses may be indexed; index registers are decimal numbers between 1 and 7. The flags field is used to set extra flags on the instruction. It consists of digit numbers in ascending order, with no separators. For example,

```
AM -12345(5),67890,110
```

#### translates into

111234567890

The flag over digits 3 and 5 specify the P index register; the flag over digit 6 specifies the P indirect address; the flag over digit 7 marks the end of the immediate Q operand; and the flags over digits 1 and 10 are specified by the third field.

# 4 Character Sets

The IBM 1620 uses single digits to represent numbers, and pairs of digits to represent characters (alphameric coding). Only a small number of the 256 possible alphameric codings have legitimate values. Further, the translation between alphameric and devices varied from device to device. The simulator implements a code called 1620 ASCII, which allows all 64 possible card codes to be represented by upper case ASCII characters. In addition, lower case alphabetic characters are accepted on input as equivalent to upper case. In the RN column, small "f" denotes the flag bit.

| Card code                                                                                                                                                              | PT code                                                                                                                 | RA                                                                                 | RN                                                                       | LPT WA                           | ASCII representation                          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------------|-----------------------------------------------|
| <br><black><br/> 1<br/> 2<br/> 3<br/> 4<br/> 5<br/> 6<br/> 7<br/> 8<br/> 9<br/> 2 + 8<br/> 3 + 8<br/> 4 + 8<br/> 5 + 8</black>                                         | C 1 2 C21 4 C41 C42 421 8 C81 C82 821 C84 841                                                                           | 0<br>71<br>72<br>73<br>74<br>75<br>76<br>77<br>78<br>79<br>?OA<br>33<br>34         | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>A<br>B<br>C            | blank 1 2 3 4 5 6 7 8 9 na = 0 0 | blank 1 2 3 4 5 6 7 8 9 ^ = (or #) @ (or ') : |
| 6 + 8<br>7 + 8<br>12<br>12 + 1<br>12 + 2<br>12 + 3<br>12 + 4<br>12 + 5<br>12 + 6<br>12 + 7<br>12 + 8<br>12 + 9<br>12 + 2 + 8<br>12 + 3 + 8<br>12 + 3 + 8<br>12 + 4 + 8 | 842<br>C8421<br>XOC<br>XO1<br>XO2<br>XOC21<br>XO4<br>XOC41<br>XOC42<br>XO421<br>XO8<br>XOC81<br>XOC82<br>XO821<br>XOC84 | ?0E<br>?0F<br>10<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>?5A<br>3 | E<br>F<br>O<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>?f+A<br>?f+B | na na + A B C D E F G H I na .   | <pre>.</pre>                                  |
| 12 + 4 + 6<br>12 + 5 + 8<br>12 + 6 + 8<br>12 + 7 + 8<br>11<br>11 + 1<br>11 + 2                                                                                         | X0841<br>X0842<br>X0C8421<br>X<br>XC1<br>XC2                                                                            | 40<br>?5E<br>5F<br>20<br>51<br>52                                                  | 0<br>?f+E<br>f+F<br>f+0<br>f+1<br>f+2                                    | na<br>na<br>na<br>-<br>J<br>K    | /<br>[<br><<br>}<br>—<br>J<br>K               |

```
11 + 3
                                  f+3
             X21
                           53
                                        L
                                                      L
11 + 4
                                  f+4
                           54
             XC4
                                         Μ
                                                      Μ
11 + 5
                                  f+5
             X41
                           55
                                         Ν
                                                      Ν
11 + 6
             X42
                           56
                                  f+6
                                         0
                                                      0
                                                      Р
11 + 7
             XC421
                           57
                                  f+7
                                         Р
11 + 8
                                                      Q
             XC8
                           58
                                  f+8
                                         Q
11 + 9
             X81
                           59
                                  f+9
                                         R
                                                      R
11 + 2 + 8
                                                      !
             X82
                           5A
                                  f+A
                                         na
11 + 3 + 8
                                                      $
             XC821
                           13
                                  f+B
                                         $
11 + 4 + 8
             X84
                           14
                                  f+C
                                         *
                                                      *
11 + 5 + 8
             XC841
                           50
                                  f+0
                                         _
                                                      ]
11 + 6 + 8
             XC842
                           ?5E
                                  ?f+E
                                         na
                                                      ;
11 + 7 + 8
             X8421
                           5F
                                  f+F
                                         na
                                                      0
0
             0
                           70
                                  0
                                         0
0 + 1
             OC1
                           21
                                  1
                                         /
                                                      /
0 + 2
                                                      S
             OC2
                           62
                                  2
                                         S
0 + 3
             021
                           63
                                  3
                                         Τ
                                                      Τ
0 + 4
             OC4
                           64
                                  4
                                         U
                                                      U
0 + 5
             041
                           65
                                  5
                                         V
                                                      V
0 + 6
                           66
                                         W
                                                      W
             042
                                  6
0 + 7
             OC421
                           67
                                  7
                                         Χ
                                                      Χ
0 + 8
                           68
                                  8
                                         Υ
                                                      Υ
             OC8
0 + 9
                                  9
                                         Ζ
                                                      Ζ
             081
                           69
0 + 2 + 8
             082
                           0A
                                  Α
                                         na
                                                      0 + 3 + 8
                           23
             OC821
                                  В
0 + 4 + 8
                           24
                                  С
                                                       (
             084
                                         (
                                                        (or %)
0 + 5 + 8
             OC841
                                  0
                           60
                                         na
                                                       \
0 + 6 + 8
             OC842
                           ΟE
                                  Ε
                                         na
0 + 7 + 8
                                                       "
             08421
                           0F
                                  F
                                         na
                                         2
                                                      ?
                                         12
                                                       !
                                         22
                                                      32
                                                      0
                                         35
                                         36
                                                      blank
11 + 0
                           50
```