# Systems Reference Library # IBM 1410 Principles of Operation This manual describes IBM 1410 Data Processing System operating principles; consequently, description includes the IBM 1411 Processing Unit, the IBM 1415 Console with console I/O printer, and the basic 1410 instruction set with timing formulas. Addressing, indexing, and chaining are detailed, as are the 1410 accelerator, processing overlap, and data channel 2 special features. This manual is: (1) a reference and guide for those familiar with the 1410 system, and (2) an aid for development and training of programmers and operators. The material is presented in a direct manner; it is assumed that the reader is familiar with the information in *IBM 1410 Systems Summary*, Form A22-0524. The manual also describes the magnetic tape, console I/o printer, 1403 printer, and 1402 punched card inputs and outputs, and gives the related I/O instructions and timing considerations. Functions of the IBM 1414 Input/Output Synchronizers are included. For information on other I/O devices and features shown on the IBM 1410 Configurator, Form A22-6688, refer to IBM 1410/7010 Bibliography, Form A22-6826. All basic, I/O, and special feature instructions for the 1410 are collected in a complete list on the IBM 1410 Instruction Card, Form X22-6740. The information in this manual is machine oriented; that is, the explanation of operations and instructions are primarily in actual machine language. Publications that provide information programming systems and available programs for the 1410 system are listed in the 1410/7010 bibliography. This publication, Form A22-0526-3, is a reprint of Form A22-0526-2. It incorporates Technical Newsletter N22-0169-0. Copies of this and other IBM publications can be obtained through IBM branch offices. Address comments concerning the contents of this manual to: IBM Customer Manuals, Dept. B98, P.O. Box 390, Poughkeepsie, New York 12602 # Contents | IBM 1410 System Processing Character Coding Word Marks | 5 | Input-Output Instructions Checking Execution of 1/0 Instructions | | |--------------------------------------------------------|----|------------------------------------------------------------------|----| | Addressing | | IDM 1415 Council | 4 | | Instructions | | IBM 1415 Console | | | Chaining Instructions | 12 | Console 1/0 Printer | | | onaming instructions | | Control Section | | | Indexing | 14 | Indicator Light Panel ивм 1415 Console се Test Panel | | | | | | | | Arithmetic Operations | | IBM 1402 Card Read Punch, Model 2 | | | Arithmetic Operation Codes | 17 | Operation Codes for 1402 | | | | | Timing Considerations for 1402 | 6 | | Processing Control Operations | 22 | Special Feature – Interchangeable | _ | | Store Address Register | 22 | 51-Column Read Feed | 6 | | Set Word Mark | | | | | Clear Word Mark | 22 | IBM 1403 Printer | 6 | | Clear Storage | | Operation Codes for 1403 | | | Clear Storage and Branch | 23 | Timing Considerations for 1403 | 8 | | Halt | | Special Features for 1403 | 8 | | Halt and Branch | 23 | | | | No Operation | 24 | Magnetic Tape Units | 8 | | | | Operation Codes for Magnetic Tape Units | | | Data Operations | 25 | Timing Considerations for Tape Units | | | Data Moving | | | _ | | Move Characters and Suppress Zeros | | System Features | 9 | | Comparing | | Data Channel 2 | 9 | | Table Lookup | | Processing Overlap | | | Editing | | 1410 Accelerator | | | | | івм 1401-1410 Compatibility | | | Branch Operations | 36 | | | | Branch Codes | | Appendix | | | Input and Output Operations | 40 | • • • • • • • • • • • • • • • • • • • • | | | ивм 1414 Input-Output Synchronizer | | Index | 10 | івм 1410 Data Processing System All data entering or leaving the IBM 1410 Data Processing System must pass through the IBM 1411 Processing Unit (Figure 1), where the operations that produce processed results at the 1411 output take place. Processing consists of logic, arithmetic, table lookup, comparing, and print editing operations. Numerous check points in the 1411 assure accuracy and reliability of the input and results. Other data manipulation features of the 1411 are: - 1. Alphameric data representation - 2. Variable word length - 3. Sixty-four ways of moving data - 4. Core storage cycle of 4.5 microseconds per character (see "1410 Accelerator") - 5. Double-address type instructions - 6. Instruction chaining - 7. Fifteen index registers Processing needs determine the core storage capacity of the 1411. Five 1411 models are available: | MODEL | STORAGE POSITIONS | |---------|-------------------| | l or lA | 10,000 | | 2 or 2A | 20,000 | | 3 or 3A | 40,000 | | 4 or 4A | 60,000 | | 5 or 5A | 80,000 | Models with suffix A have a fifth (E) frame. Basic concepts about the 1410 system and brief descriptions of all system units, including the special units requiring the E frame, are in the *IBM 1410 System Summary*, Form A22-0524. # **Character Coding** The IBM 1410 Data Processing System stores alphameric characters internally in binary-coded decimal form. The bit configuration of a character is determined by the presence of BA8421 bits and a check bit. When the character used is an operation code or is the first character in a field, another bit, called a wordmark bit, is included. Each character must contain an odd number of bits, called parity, for that character. If the combination of BA8421 bits results in an even-bit configuration, a check bit is added to give the character odd-bit parity. If the character has a word mark, this word mark (wm) is counted in the character configuration before the check-bit status is determined. Each character is checked at various locations in the system to be sure that it has an odd number of bits including the check bit and the word mark. ### Examples | CHARACTER | ва8421 | WORD | ADD CHEC | K ODD | |-----------|--------|-------|----------|--------| | | BITS | mark? | віт? | PARITY | | Ą | BA 1 | No | No | BA1 | | À | BA 1 | Yes | Yes | WMCBA1 | | Ç<br>Č | BA 21 | No | Yes | CBA21 | | Č | BA 21 | Yes | No | WMBA21 | | X | A 421 | No | Yes | CA421 | | X | A 421 | Yes | No | WMA421 | Figure 2 shows the 64 code points (bit combinations) and their character equivalents that are valid in the IBM 1410. The chart is arranged in ascending collating sequence with a blank having the lowest collating Figure 1. IBM 1411 Processing Unit | Com-<br>merce | Science<br>(Pro- | | | | | | | $\neg$ | | | | | | 1 1 | | 1 | - 1 | - 1 | - 1 | | |---------------|------------------|--------------|----------------------|----------|----------------|--------------------------------------------------|--------------------------------------------------|----------------|------------------|-------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------|----|----------|----------|-----|-----------| | Report) | gram) | | | | | | | | | | Com-<br>merce<br>(Report) | Science<br>(Pro-<br>gram) | | | | | | | | | | ь | | No Punches | С | | | | | | | | G | | 12-7 | | В | A | | 4 | 2 | 1 | | • | | 12-3-8 | | В | A | 8 | | 2 | 1 | | н | | 12-8 | | В | A | 8 | | | - | | | ) | 12-4-8 | С | В | A | 8 | 4 | | | | ı | | 12-9 | С | В | A | 8 | | | 1 | | [ | | 12-5-8 | | В | A | 8 | 4 | | 1 | (4) - | ! | | 11-0 | | | | 8 | | 2 | | | < | | 12-6-8 | | В | A | 8 | 4 | 2 | | | J | ļ | 11-1 | | В | | | | | Ľ | | ‡ | | 12-7-8 | С | В | A | 8 | 4 | 2 | 1 | | K | | 11-2 | С | В | | | _ | | | | & | + | 12 | С | В | A | | | | | | L | | 11-3 | | В | | | | 2 | L | | \$ | | 11-3-8 | С | В | | 8 | | 2 | 1 | | М | | 11-4 | С | В | | | 4 | | - | | * | | 11-4-8 | | В | | 8 | 4 | | | | N | | 11-5 | | В | | | 4 | | Ĺ | | ] | | 11-5-8 | С | В | | 8 | 4 | | 1 | | 0 | | 11-6 | | В | | | 4 | 2 | | | ; | | 11-6-8 | С | В | | 8 | 4 | 2 | | | Р | | 11-7 | С | В | _ | | 4 | 2 | L | | Δ | | 11-7-8 | | В | | 8 | 4 | 2 | 1 | | Q | | 11-8 | С | В | | 8 | | | | | | | 11 | | В | | | | | | | R | | 11-9 | | В | | 8. | | | | | / | | 0-1 | С | | A | | | | 1 | | # | | 0-2-8 | | | A | 8 | | 2 | | | , | | 0-3-8 | С | | A | 8 | | 2 | 1 | | S | | 0-2 | С | | A | | | 2 | | | | ( | 0-4-8 | 1 | | A | 8 | 4 | | | ĺ | T | | 0-3 | | | Α | | | 2 | | | | | 0-5-8 | С | | A | 8 | 4 | | 1 | | U | | 0-4 | С | | A | | 4 | | I | | \ | | 0-6-8 | c | | Α | 8 | 4 | 2 | | 1 | V | | 0-5 | | | Α | | 4 | | | | 4# | | | | | A | 8 | 4 | 2 | 1 | 1 | w | | 0-6 | | | A | | 4 | 2 | Γ | | ъ | | | $\top$ | | Α | | | | | 1 | Х | | 0-7 | С | | A | | 4 | 2 | | | | = | | + | $\vdash$ | | 8 | | 2 | 1 | 1 | Y | | 0-8 | С | | A | 8 | | | Ι | | | 1 | | c | | <u> </u> | 8 | 4 | T | | 1 | <del>Z</del> | <u> </u> | 0-9 | | | A | 8 | | | | | | <u> </u> | | + | | † <del>-</del> | 1 | - | | 1 | 1 | | <u> </u> | 0 | С | T | | 8 | | 2 | T | | | · | | + | <u> </u> | | 8 | 4 | 2 | | 1 | 1 | | 1 | | T | | | | | | | | | | - C | | <del> </del> | ┼ | - | ┼ | 1 | 1 | | | | - | | | T | | 2 | T | | | ļ | | | B | A | ┼ | Ė | ┼ | | | | - | | c | + | T | | | 2 | T | | | | | + | + | + | <del> </del> | | <del> -</del> | 1 | 1 | | | | + | T | | | 4 | | T | | | | | +- | +- | + | +- | - | 2 | Ė | 1 | <b></b> | | | С | $\dagger$ | + | T | 4 | | T | | | | | + | + | Τ. | - | <del> </del> | + | 1 | t | - | - | | | + | T | $\vdash$ | 4 | 2 | t | | | | | + | + | +- | +- | 1 | - | <del> '</del> - | 1 | | + | | + | + | + | $\vdash$ | 4 | 2 | t | | | | | - | ╁ | + | ╁ | <del> </del> | - | ١, | 1 | | 1 | | + | + | + | 8 | - | | t | | | | <del> </del> | | + | +- | + | + | 2 | <del>'</del> | 1 | <b></b> | 1 | | C | $\dagger$ | +- | + | $\vdash$ | | $\dagger$ | | | □ [ | □ ) [ < | □ ) 12-4-8 [ 12-5-8 | □ | □ | □ ) 12-4-8 | □ | | | | | □ 12.48 C B A 8 4 □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ □ <td< td=""><td>□ ○ 12.4-8 C B A B A I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I&lt;</td><td> 1</td><td> 1</td><td> </td><td> </td><td> </td><td> 1</td><td> </td></td<> | □ ○ 12.4-8 C B A B A I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I< | 1 | 1 | | | | 1 | | Figure 2. Standard BCD Interchange Code number of 00 and a nine having the highest of 63. The machine can read, punch, or type out on the IBM 1415 Console-I/O Printer, any of the characters symbolizing the 64 code points. Forty-eight of the characters will print on an IBM 1403 Printer having an alphameric chain. Five of the BCD code points print out as two different characters, depending on the console-I/O printer type head in use and the 1403 printing chain installed. The choice of characters depends on the type of data being processed; for example, 1403 print arrangement A2 is available for report writing and most commercial uses, and print arrangement H2 is for program languages such as COBOL and FORTRAN and meets general scientific requirements for a more mathematical symbolism. Several other 1403 print arrangements are available; this manual assumes that print arrangement A2 (commerce) is being used. The console-I/O printer type head in use corresponds with the print arrangement installed in the 1403 Printer. | OLD | NEW<br>(COMMERCE) | CARD<br>CODE | | | | BCD<br>CODE | : | | | |-----|-------------------|--------------|---|---|---|-------------|---|---|---| | ( | [ | 12-5-8 | | В | Α | 8 | 4 | | 1 | | ) | ] | 11-5-8 | С | В | | 8 | 4 | | 1 | | = | m | 0-5-8 | С | | Α | 8 | 4 | | 1 | | • | . \ | 0-6-8 | С | | A | 8 | 4 | 2 | | | " | +++ | 0-7-8 | | | A | 8 | 4 | 2 | 1 | | ¢ | ъ | 2-8 | | | A | | | | | Figure 3. Differences Between Previous Code and Standard BCD Interchange Code The standard BCD interchange code shown in Figure 2 replaces a previous code; Figure 3 shows the characters affected in the change to the new standard. Systems having the previous code may be converted to the standard BCD interchange code by requesting a no-charge Miscellaneous Engineering Specification (MES). The conversion also provides the 1415 Console-I/O Printer with 12 key-tops and the two type heads corresponding to two common 1403 print arrangements, A2 and H2. Figure 4 indicates the preferred names of special characters that previously had various or uncertain nomenclature. # Word Marks A special eighth plane bit, called a word mark, is used to define the length of each instruction and data field in core storage. This word mark makes it possible to employ the variable-word-length concept in the 1410. It can be set and cleared, when necessary, by storedprogram instructions. If word-mark identification is needed in magnetic tape records or cards, special instructions translate the word marks to word-separator characters during write operations, and translate the word-separator characters to word marks when the data are read back into storage from the tape unit or cards. A special instruction makes it possible to print the digit 1 in the print position, on the 1403 Printer, that corresponds to a word-mark position in the print area. When data are transferred to the console-1/o printer in load mode, each character that | SYMBOL | NAME | |----------|------------------------| | <b>‡</b> | Group Mark | | <b>‡</b> | Record Mark | | +++ | Segment Mark | | <b>-</b> | Word Separator | | @ | At Sign | | # | Number Sign | | & | Ampersand | | ? | Plus Zero | | 1 | Minus Zero | | + | Plus | | - | Minus or Hyphen (Dash) | | * | Asterisk | | % | Per cent | | / | Slash | | \ | Backslash | | | Lozenge | | b | Blank | | 16 | Substitute Blank | | ( | Left Parenthesis | | ) | Right Parenthesis | | [ | Left Bracket | | ] | Right Bracket | | ] | Tape Mark | | < | Less than | | 1 | Greater than | | = | Equal to | | i ; | Semicolon | | : | Colon | | • | Period or Point | | | Prime or Apostrophe | | Δ | Mode Change | Figure 4. Symbol Names contains a word mark in storage has the word mark printed above that character. The letter A with an associated word mark is printed A. In this manual, each character that has an associated word mark has the inverted circumflex (\*) above it. The word mark serves several functions: - 1. It indicates the first character of an instruction. - 2. It defines the size of a data word, or - 3. It signals the end of an instruction. The rules governing the use of word marks are: - 1. Word marks are assigned specific storage locations in the program planning stage. They are set by a program load routine or by specific instructions within the program itself. - 2. Word marks remain in their original locations unless cleared or set by a positive action such as a clear storage, clear word mark, or set word mark instruction or by a data move operation that specifies that they should be altered. - 3. A word mark must be associated with the first character of each instruction (op code position) and is usually associated with the high-order (leftmost) character in a data field. 4. Every instruction in the program must be followed by a word mark. This word mark stops the reading of the instruction. # Addressing Each core-storage position is addressable and has its own five-character address. Valid addresses range from 00000 to as high as 79999 for an 80K system. If an operation decrements addresses, 00001 is the lowest position that can be referenced, or in which data can be read or inserted as the result of an instruction. If 00000 is addressed in a decrementing operation, the system will stop and signal an address-check error. There are no exceptions. Note: 00000 is always a valid address for operations that *increment* addresses. If an operation increments addresses, 59998 is the highest position (assuming a 60K system) that can be referenced, or in which data can be read or inserted as the result of an instruction. If 59999 is addressed in an incrementing operation, the system will stop and signal an address check. There are two exceptions: - 1. A manual console operation; that is, display and alter (see index). This exception does not extend, however, to any subsequent incrementing operation that utilizes 59999 for any purpose whatsoever. - 2. Data may be read from or inserted into 59999, without causing an address check, in the execution of a read or write "to end of core" 1/0 instruction. Note: Assuming the same example of a 60K system, 59999 is always a valid address for operations that *decrement* addresses. Zone bits can be used in the tens and/or hundreds positions of the address in order to tag index registers (Figure 36); however, any address having zone bits in the units, thousands, or ten-thousands positions is invalid. Also, an address is invalid if it contains, in any position, a character that has no numeric-bit total within the range of 0 through 9: such characters as & (no numeric bits), \$ (B821), or # (821). In other words, valid addresses must have only numerals in the units, thousands, and ten-thousands positions; and only numerals letters, or the characters /, ?, !, or # in the tens and hundreds positions. #### **Address Registers** To read out an address from storage, five storage readout cycles are needed. In addition, a device is needed to accept the address characters and keep them until the whole address has been read out. The devices used to do this are the address registers. See Figure 5. Before being stored in the address registers, all characters are translated to two-out-of-five code. Before translation, the BCD characters are checked; an invalid bit combination causes an assembly channel error (Figure 53). The characters are also checked after translation; more or less than two bits in a character then causes an address channel error. Whenever the content of an address register is placed in core storage, as in a G ccccc B (store the B-address register), it is first retranslated to BCD. I-Address Register: The instruction address register (IAR) is a five-character register which is in effect an instruction counter. Its function is to keep track, character by character, of the current address of the stored program. For example, when an instruction is being read out, IAR initially holds an address that specifies the op-code position of the instruction. The address is increased by one each storage cycle as the instruction is being read out. At the end of instruction read-out, IAR holds the op-code address of the next sequential instruction. The setting of IAR is changed by one of four methods: - 1. An address may be loaded into IAR from the console (for instance, the starting address of the program). - 2. During normal sequential operations, IAR advances during each instruction read-out cycle to the address of the next character of the program. - 3. After a successful branch instruction and during the execution of the branched-to instruction, the branched-to address plus one automatically replaces the current program address in IAR (see example under "Chaining Instructions"). - 4. A program reset or computer reset automatically loads 00001 into the IAR. A- and B-Address Registers: The A- and B-address registers (AAR and BAR) are five-character registers; they accept the five-character addresses that specify the core-storage locations of the units positions of any data fields called for in the instruction (see "note" for exceptions). After each position of the data field is acted on, the address is decreased by one (if data were addressed by the low-order position) or increased by one (if data were addressed by the high-order position). The BAR contains the address of the input or output field during non-overlapped I/O operations. The AAR and BAR also contain the addresses needed to accomplish a branch to a subroutine while keeping track of the main routine (see "Chaining Instructions"). Note: In most cases, data fields are addressed by specifying the location of the rightmost character. This is done so that addition, subtraction, and other operations start with the units position and end with the data's high-order position. However, data are addressed by specifying the location of the leftmost character when (1) records are moved from one area to another Figure 5. Addressing and Data Flow, Simplified within core storage; (2) data are read into or out of core storage. Exception: the data from documents in certain 1/0 devices, such as the IBM 1419 Magnetic Character Reader, are addressed by the rightmost character and are read and stored from right to left. C-Address Register: The C-address register is a five character register used in store address register, multiply, divide, table lookup, and other operations; it is not accessible to the programmer. In Store Address Register instructions (for instance, a Ğ ccccc B equaling Ğ 12345 B), the ccccc signifies only that the C-address register (CAR), and not AAR, is used to store the contents of the BAR at the storage address 12345. The main significance is that the AAR is not changed. *D-Address Register:* The D-address register is a fivecharacter register used in multiply, divide, recomplement, and other operations; it is not accessible to the programmer. E- and F-Address Registers: The E- and F-address registers are described under "Processing Overlap." Storage Address Register: Each address register addresses core storage indirectly through the storage address register (STAR), a five-character register. STAR is not accessible to the programmer. # **Single-Character Registers** The A- and B-data registers, Op and Op-modifier registers, 1/0 channel select register, unit select register, and unit number register are single-character registers used to store data during the execution of various instructions. Registers E1, E2, F1, F2 are described under "Processing Overlap." B-Data Register: The B-data register accepts each character as it leaves the 1410 core-storage area. The character is stored in an eight-bit form (BCD code, check bit, and a word-mark bit). This register is reset and filled with a character from core storage during every storage read-out operation. The character can be entered back into storage from the output of the B-data register. A-Data Register: The A-data register is reset and filled with the eight-bit character output from the B-data register whenever the operation requires it. Op-Register: The Op (operation) register is reset and filled with a seven-bit character (the wm bit is dropped) output from the B-data register whenever the character is an operation code. The Op register stores the Op code of the instruction in process for the duration of the operation. Processing may be overlapped with certain I/O operations whose instructions have Op codes M or L. During overlap time, the M or L is held by a group of latches, freeing the Op-register for handling the successive Op codes of the processing instructions. Op-Modifier Register: The Op-modifier register is reset and filled with a seven-bit character output from the B-data register whenever the character is a d-character of an instruction. The Op-modifier register stores the modifier of the instruction in process for the duration of the operation. Processing may be overlapped with certain I/O operations. During overlap time, the A channel keeps track of the read or write condition signified by the d-character of the instruction, freeing the Op-modifier register for handling the successive d-characters of the processing instructions. I/O Channel Select Register: The I/O channel select register accepts the hundreds position of an x-control field. This position specifies the data channel to be used and whether the operation will be performed in the overlap or non-overlap mode. (See "System Features" for more detail on processing overlap.) Unit Select Register (Channels 1 and 2): A unit select register is associated with each data channel. The register accepts the tens position of the x-control field. The tens position specifies the input or output unit being used for the operation. Unit Number Register (Channels 1 and 2): A unit number register is associated with each data channel. The register accepts the units position of the x-control field. The units position specifies the 1/0 unit number or the operation shown in Figure 107. ### Addressing Example (Figure 6) Instruction address 02000 contains the operation code for the following instruction, which adds the field specified by the A-address to the field specified by the B-address. OP CODE A-ADDRESS B-ADDRESS A 05389 05399 Both fields are addressed by their low-order positions. Addition progresses character by character from right to left, up to and including the first B-field position containing a word mark. For example, an A-field of 4 1 2 3 added to a B-field of 0 0 2 results in a B-field sum of 1 2 5. Figure 6. Addressing Example #### Instructions The 1410 uses stored-program instructions to cause all of the input and output devices to operate and to perform all arithmetic, branch, general data, and miscellaneous operations. The operation performed is indicated by the form and contents of the instruction. The programmer can write one-for-one instructions in actual machine language or one of the 1410 Autocoder systems. Functional instructions may be written in fortran or cobol program languages. In actual machine language, the programmer must write the actual instructions and actual storage addresses (not symbolized by mnemonics, labels, etc.). Programs written in other than actual language are converted to actual language by use of the appropriate 1410 assembly program. For information on the various assembly programs, consult *IBM 1410 Bibliography*, Form A22-0523. Once the actual-language program has been produced, it can be kept permanently in punched cards, in disk storage, or on magnetic tape. #### Instruction Form The basic instruction form for the IBM 1410 Data Processing System is divided into four parts — the operation code, the A- or I-address (or x-control field), the B-address, and a d-character that modifies the operation code. Because of the variable length instruction form, the total length of an instruction can vary from one to 12 positions. An address notation of (A), (I), or (B) is used wherever ease of personal reading or vocalizing an instruction is more important than indicating the number of storage positions occupied. Op Code is always a single character that specifies the basic machine operation to be performed. A-Address is always five characters and specifies a core-storage location. An A-address may be symbolized by aaaaa or (A). *I-Address* is always five characters and specifies the address of an instruction in storage. An I-address may be symbolized by iiiii or (I). X-Control Field: If the field between the Op code and the B-address is made up of three characters, it is called the x-control field. The x-control field is used only for I/O operations. In its hundreds or leftmost position, the x-control field specifies: (1) Which of two possible channels are used, and (2) Whether operation is in the overlap or non-overlap mode. Four characters, %, @, \pi, or \*, cover the four possibilities. (See "Processing Overlap.") In its tens or center position, the x-control field specifies the kind of I/O device ad- dressed by a character — such as 1 for reader, 2 for printer, 4 for punch, U for tape unit, or T for console-I/O printer. The units or rightmost position further defines the operation. For example, M %48 bbbbb W causes operation on channel 1 and in the non-overlap mode (%), and the field called for by the B-address is written out (W) by the punch (4). The cards are stacked as specified in pocket 8. *B-Address* is always five characters and specifies a core-storage location. A B-address may be symbolized by bbbbb or (B). *d-Character* is a single alphabetic, numeric, or special character used to specify an operation within the control of the operation code of the instruction. # Instruction Sequence The IBM 1410 has a sequential method of program execution. Thus, instruction 1 is followed by instruction 2 and so on, unless special circumstances during processing make it necessary to alter this sequence. Branch instructions make it possible to test for special conditions and change the sequence of program execution, repeat an instruction or group of instructions, or transfer to special subroutines. These tests can be made at any time during processing and control the logic of the program. #### Instruction Word Marks Each instruction must have a word mark set over the operation code, and must not contain word marks in any other position. Also, a word mark must be set in the core-storage location immediately to the right of the last character of an instruction. This is normally the word mark associated with the operation code of the next sequential instruction. # Instruction Length Validity Instruction length checking is incorporated in the system to ensure that each instruction read contains a valid number of characters for the operation code specified. Valid instruction words vary in length from one to twelve characters depending on the amount of information required for the operation. The general instruction form consists of a single-character operation code followed by one or two 5-character addresses, or a 3-character input-output operation specification (x-control field) and, in many cases, a d-character. Valid instruction word lengths are: ``` O = 1 position O d = 2 positions O xxx d = 5 positions O aaaaa d = 6 positions O axx bbbbb d = 7 positions O aaaaa bbbbb d = 10 positions O aaaaa bbbbb d = 12 positions ``` The O specifies an operation code. The five a's specify the five-character address of the A-field and five b's specify the five-character address of the B-field. The three x's specify the x-control field, and the d specifies an operation modifier (definer). ### Instruction Descriptions In this manual, instructions are described by using a standard form. Instructions that perform similar functions are incorporated in one general description. In these cases, individual instructions and details are shown in charts. Descriptions follow this form: Instruction Form: This contains the basic autocoder mnemonic operation code, the actual Op code, the A-address (or I-address or x-control field), the B-address, and d-character. Function: This is the description of the operation performed. Word Marks: This is the information the programmer must have to determine the effect of word marks on the operation. All instructions must have a word mark associated with the operation code. Timing: This is the formula used in calculating the time required for executing the instruction (in microseconds). See Figure 7 for symbols used in the formulas. Because there are several valid lengths for some instructions, these lengths, as they apply to the timing formula, are included in the section. Some operations also have extra steps, depending on the data, etc. When this condition is present, the numbers assigned to these steps (D, E, R, etc.) are also given. (All timing formulas change when the 1410 Accelerator feature is installed; the faster timings resulting from the feature are listed together in this manual under "1410 Accelerator.") Note: These are special notations or additional information pertaining to the operation. Address Registers after Operation: The contents of the address registers are represented by the codes described under "Chaining Instructions." # **Chaining Instructions** If the A- and B-address registers contain addresses of the next fields to be processed during the execution of a program, another complete instruction is not necessary. The operation code, alone, can be given and the contents of the address registers are used to specify the A- and B-fields. Connecting instructions together in this manner is called chaining. This method conserves storage space and saves time, because the address registers do not have to be reloaded during the reading of the instruction. For example, an ADD instruction, Å 05985 06985, is executed. Field A has five characters - A is the A-field length. - B is the B-field length. - C is 1 if the branch is taken. It is zero otherwise. - D is the number of characters in the B-field from the start of zero suppression to the place where the dollar sign is inserted. If no dollar sign is inserted, D is zero. - E is 2 on a single-character multiply or divide operation. It is 1 on a single-character add, subtract, zero and add, zero and subtract, table lookup, or a 6-character multiply or divide operation. It is zero otherwise. - is the time used by input/output device to accept or send data and the Synchronizer access time, when applicable. - L is the instruction length. - M is the multiplier length. - N is the number of fields actually compared on a table search. The B-field length on a table search includes only those argument fields actually compared and the intervening function values. - Q is the quotient length. - R is 1 if a recomplement is taken on an add or subtract operation. It is zero otherwise. - Z is the number of characters in the B-field from the start of zero suppression (as indicated in the control field) to the left end of the B-field. Figure 7. Timing Formula Symbols and field B has six characters. The address registers after the operation contain: A-ADDRESS REG (decreased B-ADDRESS REG (decreased 05980 five positions) 06979 six positions) The A- and B-addresses of the fields to be used in the next operation are 05980 and 06979, respectively. The next instruction need contain only the operation code, because the A- and B-address registers are already at the desired locations. The instruction S causes the data at location 05980 to be subtracted from the data at 06979. This chaining technique can be used to link several instructions together. The only restriction is that the fields remain in sequence and that the address registers contain valid addresses. However, if a two-address instruction does not require a d-character (11-position instruction), the op-modifier register is blanked; thus, any chained instructions then directly following will be automatically assigned a blank d-character. The descriptions of the instructions include the contents of the address registers after the operation has been performed. The programmer can use this information to determine which instructions can be chained in particular situations. Figure 8 shows the symbols that represent the contents of the address registers. Branch instructions have the following effects: ### If Branch Occurs: 1. After the instruction has been read and IAR has accordingly stepped, the address in the IAR transfers to the BAR. This NSIB (no longer the next instruction | Abbreviation | Meaning | |--------------|------------------------------------------------------------------------------------------------------------------------------------| | Α | A-address of the instruction | | В | B-address of the instruction | | NSI | Address of the next sequential instruction | | ВІ | Address of the next instruction if a branch is taken | | NSIB | Address of the next instruction in storage fol-<br>lowing the branch (not executed in normal<br>sequence because branch was taken) | | LA | The number of characters in the A-field | | LB | The number of characters in the B-field | | LW | The number of characters in the A- or B-field, whichever is shorter | | Ap | The previous contents of the A-address register | | Вр | The previous contents of the B-address register | Figure 8. Address-Register Symbols to be read out) can be stored by a $\check{\mathbf{G}}$ (C) B after the branch operation. 2. The next instruction read is at the address in the AAR. (During the reading of the branched-to instruction, the Op-code address is taken from AAR and the address in AAR is placed in STAR; this address is then increased by one and placed in IAR for read-out of the subsequent positions in the branched-to instruction and all the positions of instructions following it.) If No Branch Occurs (Two-Address Branch Instructions): After the operation, AAR contains the BI (branch-to) address, the IAR contains the NSI, and BAR contains the B-address minus one. This permits the next position to be given the same test, without specifying a B-address, until either the BAR has decremented to a position meeting the test and causing the branch, or until there are no more such conditional branch instructions in the series. If No Branch Occurs (One-Address Branch Instructions): After the operation, both AAR and BAR contain the BI (branch-to) address. The IAR contains the NSI. Example: Chained Two-Address Branch Instruction | No Branch<br>(no 3<br>in 580) | <b>Š</b> 00600 00580 3 | before<br>after | 1AR<br>01000<br>01012 | 02000<br>00600 | BAR<br>03000<br>00579 | |--------------------------------------|------------------------|-----------------|-----------------------|----------------|-----------------------| | No Branch<br>(no 3<br>in 579) | <b>Š</b> | before<br>after | 01012<br>01013 | 00600<br>00600 | 00579<br>00578 | | Branch (3 in 578) | $ {B}$ | before<br>after | $01013 \\ 01014$ | 00600<br>00600 | 00578<br>01014 | | Optional<br>Branch-To<br>Instruction | <u>Ğ 04000 В</u> | before<br>after | 01014<br>00607 | 00600<br>00600 | 01014<br>01014 | | | CAR is used | l to store | content | of bar i | n 4000 | # Indexing The IBM 1410 Data Processing System is equipped with fifteen index registers that can be used to modify the A-, I-, or B-address of most instructions. Each index register is assigned five storage locations (Figure 9). | INDEX REGISTER | INDEX FACTOR<br>STORAGE LOCATIONS | |----------------|-----------------------------------| | 1 | 00025 to 00029 | | 2 | 00030 to 00034 | | 3 | 00035 to 00039 | | 4 | 00040 to 00044 | | 5 | 00045 to 00049 | | 6 | 00050 to 00054 | | 7 | 00055 to 00059 | | 8 | 00060 to 00064 | | 9 | 00065 to 00069 | | 10 | 00070 to 00074 | | 11 | 00075 to 00079 | | 12 | 00080 to 00084 | | 13 | 00085 to 00089 | | 14 | 00090 to 00094 | | 15 | 00095 to 00099 | Figure 9. Index Register Locations in Storage Addresses that cannot be indexed: - 1. X-control field of M, L, or U instruction. - 2. G instruction (Store address register). To modify addresses, the index register containing the index factor must be selected. The index factor (contents of the index register) is not a field address, but an actual number. To select the correct index register, the A-address, the B-address, or both addresses must be tagged. A tag is a zone bit over the hundreds position, the tens position, or both the hundreds and tens positions of the address to be modified (Figure 10). Both the A- and B-addresses may be tagged; if they are, the index register tagged in the A-address is not necessarily the same as the one tagged in the B-address (see Example 5). The index factor of the index register selected is added algebraically to the address of the instruction after the address has entered the address register from storage and before the instruction is executed. The address is modified in the appropriate address register. | B-BIT<br>OVER<br>HUNDREDS<br>POSITION | A-BIT<br>OVER<br>HUNDREDS<br>POSITION | B-BIT<br>OVER<br>TENS<br>POSITION | A-BIT<br>OVER<br>TENS<br>POSITION | TAG<br>INDEX<br>REGISTER | |---------------------------------------|---------------------------------------|-----------------------------------|-----------------------------------|--------------------------| | | | | | NONE | | | | | A | 1 | | | | В | | 2 | | | | В | A | 3 | | | A | | | 4 | | | A | | A | 5 | | | A | В | | 6 | | | A | В | A | 7 | | В | | | | 8 | | В | | | A | 9 | | В | | В | | 10 | | В | | В | A | 11 | | В | A | | | 12 | | В | A | | A | 13 | | В | A | В | | 14 | | В | A | В | A | 15 | Figure 10. Zone Bits Used to Tag Index Registers Thus, the actual instruction in storage itself is not changed but, because data are read from storage under control of the address registers, the effect of the original instruction is changed. The index factor also remains unchanged as a result of indexing; however, the index factor can be changed, whenever required, by other operations. For example, an index register containing 00123 can be reduced to 00000 by a subtract (one field). If the sign of the index factor is plus, the factor is added to the tagged address; if negative, the factor is subtracted from the tagged address. The arithmetic overflow latch is not set as a result of overflows incurred during indexing. The result of this modification must be a valid storage address, or the system will stop on an error when the instruction is executed. The validity of addresses must be considered when altering or interchanging programs between 10K, 20K, 40K, 60K, and 80K systems. Note: For proper operation of indexing on a 10K system, the high-order position of the address being indexed must always contain a zero. Storage positions 00025 to 00099 can be used for general storage if they are not required for indexing purposes. Word marks can be set in this area at any time because they do not control the indexing operation, which ignores word marks. Zone bits are undisturbed in the index registers and have no effect on indexing except when they appear in the sign position of an index factor. Timing: T = 34.5 for each single address indexed. Examples: 1. Modify the A-address of this instruction: ``` OP CODE A-ADDRESS B-ADDRESS A 009Z6 00961 ``` The A-address is tagged by an A bit over the tens position (Z = A81). Index register 1 is selected (Figure 10). Because the index register 1 factor is minus it is subtracted from the A-address: Valid addresses on 10K and larger systems. 2. Modify the B-address of this instruction: | OP CODE | A-ADDRESS | B-ADDRESS | |---------|-----------|-----------| | À | 00459 | 01MT1 | The B-address is tagged by a B bit over the hundreds position and an A bit over the tens position (M = B4 and T = A21). Index register 9 is selected. Because the index register 9 factor is plus, it is added to the B-address: Valid addresses on 10K and larger systems. 3. Modify the A- and B-addresses of this instruction: | OP CODE | A-ADDRESS | B-ADDRESS | |---------|-----------|-----------| | Š | 00V51 | 00W50 | Both the A- and B-addresses are tagged by an A bit over the hundreds position (V = A41 and W = A42). Index register 4 is selected. Because the index register 4 factor is unsigned, it is added to both addresses. ``` A-address = 00V51 00551 Index register 4 factor +00100 Effective A-address 00651 00W50 B-address 00650 Index register 4 factor +00100 Effective B-address 00750 A-ADDRESS B-ADDRESS OP CODE Effective instruction: 00651 00750 ``` Valid addresses on 10K and larger systems. 4. Modify the A-address of this instruction: | OP CODE | A-ADDRESS | B-ADDRESS | |---------|-----------|-----------| | Å | 126A8 | 06429 | The A-address is tagged by B and A bits over the tens position (A = BA1). Index register 3 is selected (Figure 10). Because the index register 3 factor is plus, it is added to the A-address. Valid addresses on 20K and larger systems. 5. Modify the A- and B-addresses of this instruction, by tags selecting two different index registers: ``` OP CODE A-ADDRESS B-ADDRESS A 77TM8 23GY5 ``` The A-address is tagged by an A bit over the hundreds position and a B bit over the tens position (T = A21 and M = B4). Index register 6 is selected (Figure 10). Because the factor in index register 6 is positive, it is added to the A-address. The B-address is tagged by B and A bits over the hundreds position and an A bit over the tens position (G = BA421) and Y = A8). Index register 13 is selected (Figure 10). Because the factor in index register 13 is negative, it is subtracted from the B-address. ``` 77348 A-address 77TM8 = Index register 6 factor 0020B = +00202 Effective A-address 77550 B-address 23GY5 = 23785 Index register 13 factor = 0200N 02005 Effective B-address 21780 OP CODE B-ADDRESS A-ADDRESS 21780 77550 ``` Valid addresses on 80K system. # **Arithmetic Operations** The add, subtract, zero and add, zero and subtract, multiply, and divide operation codes are used to perform the system's arithmetic operations. The use of add-to-storage logic in the IBM 1410 Data Processing System eliminates the need for special-purpose accumulators or counters in the system. Because any group of storage positions can be used as an accumulating field, the capacity for arithmetic functions is not limited by a predetermined number of counter positions. # Sign Change or Development The sign of a factor in a field is determined by the combination of zone bits in its units position. A minus sign is always indicated with a B bit. A plus sign may be indicated in any of three ways: by B and A bits, no zone bits, or (less commonly) by an A bit. (See Figure 11.) When the sign of a field is changed or developed as the result of an arithmetic operation, the machine method of signing the factor is with B and A bits for plus or the usual B bit for minus. (The test for a minus result from an operation can thus be made with a branch if zone equal B instruction, $\mathring{\mathbf{V}}$ (I) (B) K; if no branch results, the bit structure for the sign is necessarily BA, A, or no bits, and all are positive.) | SIGN | BCD CODE BIT<br>CONFIGURATION | CARD CODE<br>CONFIGURATION | |-------|-------------------------------|----------------------------| | Plus | No B or A Bit | No Zone | | Plus | B and A Bits | 12 Zone | | Minus | B Bit Only | 11 Zone | | Plus | A Bit Only | 0 Zone | Figure 11. Bit Equivalents for Signs # **Add Cycles** The arithmetic operations in the 1410 system are performed by using one of two types of add cycles: - 1. True-add - 2. Complement-add The type of add cycle performed depends on the arithmetic operation and the signs and values of the two factors involved (Figure 12). In an algebraic subtraction, recall that the sign of the subtrahend (A-field, in 1410) is changed and the subtrahend, with its changed sign, is then *added* to the minuend (B-field). The sign of the result is the "sign of the greater value" only *after* the A-field sign is considered to have been changed. | TYPE<br>OF<br>OPER. | A-FLD.<br>SIGN | B-FLD.<br>SIGN | TYPE OF ADD<br>CYCLE | SIGN OF<br>RESULT | |---------------------|----------------|----------------|---------------------------------------|---------------------------------------------------------------------| | | + | + | True – Add | + | | A<br>D+ | T | _ | Compl – Add | Sign of Greater | | D | | + | Compl – Add | Value | | | | _ | True – Add | _ | | | | _ | True – Add | _ | | S<br>U<br>B<br>T | + | + | Compl – Add | Sign of Greater<br>Value (after A-<br>field sign is<br>changed as a | | R<br>A<br>C<br>T | _ | Compl – Add | result of the subtract in- struction) | | | | _ | + | True – Add | + | Figure 12. Types of Add Cycles and Sign of Result for Add and Subtract Operations The BCD characters to be added are checked for valid BCD coding, and an invalid bit combination causes an A or B channel error (Figure 53). The characters are then translated to qui-binary code and fed to the adder. The adder's output is retranslated to BCD; an invalid combination of bits at this point causes an assembly channel error. # **Digit Coding** With regard to numeric value, all 1410 characters fall into two classes. All numerals, all letters, and the characters /, ?, !, and + are in the first class, each having numeric bits that add up to a total within the range of 0-9. All other 1410 characters are in the second class, having either no numeric bits (b, &, -, も) or numeric bits that add up in each case to a total that exceeds the range of 0-9. When any of this second class of characters is involved in an arithmetic operation, its numeric-bit portion is changed from blank to zero (8) and 2 bits) or reduced to the decimal range by dropping the 8 bit, whichever is appropriate for the character. Thus a group mark (CBA8421) added to a zero, becomes a G (BA421) if its zone bits are retained or a 7 (421) if its zone bits are stripped in the arithmetic operation. For example, an A-field of 4\pm 4\%\pm zero-added to a B-field of 22222 changes the B-field to 4744G. Likewise, a # (821) becomes a 3. ### Overflow If the result exceeds the limit of the B-field (determined by the B-field word mark), the carry is lost and the arithmetic overflow indicator turns on. One of the branch instructions, $\check{J}$ (I) Z, tests and turns off this indicator. #### Zero Balance If the result of any add, subtract, multiply, zero and add, or zero and subtract operation is a zero balance, the zero balance indicator is turned on. This indicator can be tested by one of the branch instructions, $\mathring{J}(I)V$ . The indicator is turned off by the next arithmetic instruction, if applicable (any except divide), that does not result in a zero balance. # **Arithmetic Operation Codes** ### Add (Two Fields) Instruction Form: Timing: T = 4.5 (L + 1 + E + A + 1.5B + 1.5RB). When L = 1, E = 1; when L = 11, E = 0. Address Registers after Operation: $\begin{array}{cccc} \text{I-ADDRESS REG} & \text{A-ADDRESS REG} & \text{B-ADDRESS REG} \\ \text{NSI} & \text{A-LW} & \text{B-LB} \end{array}$ Function: The numeric data in the A-field are added algebraically to the numeric data in the B-field. The sum is stored in the B-field. Zone bits in the B-field are unchanged except for any in the sign position, which may be changed. If the sign is changed from minus to plus, the plus sign will have the B and A bit configuration. A-field zone bits are ignored in all positions except the sign position. Example: An A-field of 123 added to a B-field of 00K results in a B-field sum of 12A. To illustrate a shorter A-field (discussed below): an A-field of 123 added to a B-field of 3#300K results in a B-field sum of 33287R (see "Digit Coding"). Word Marks: The B-field word mark stops the operation and must be set to define the field's high-order, leftmost position. The A-field requires a word mark only if it is shorter than the B-field; in that case, the system adds zeros to the extra high-order positions of the B-field up to, and including, its word-mark position. If the A-field is longer than the B-field, the high-order positions of the A-field that exceed the limit imposed by the B-field word mark are not processed. # Add (One Field) Instruction Form: Timing: $$T = 4.5 (L + 1 + A + 1.5A)$$ . $L = 1 \text{ or } 6$ . Address Registers after Operation: $\begin{array}{cccc} \textbf{I-ADDRESS REG} & \textbf{A-ADDRESS REG} & \textbf{B-ADDRESS REG} \\ \textbf{NSI} & \textbf{A-LA} & \textbf{A-LA} \end{array}$ Function: The numeric data in the A-field are image-added and the doubled result is stored in the A-field. Zone bits in the field are unchanged and the sign bit configuration is the same as it was before the operation. Example: An A-field of 01234, added to itself, produces 02468 as the sum. Also, an A-field of &AB\$@, added to itself, produces PBDO8 as the sum (see "Digit Coding"). Word Marks: The A-field word mark stops the operation and must be set to define the field's high-order, leftmost position. ### Subtract (Two Fields) Instruction Form: Timing: T = 4.5 (L + 1 + E + A + 1.5B + 1.5RB). When L = 1, E = 1; when L = 11, E = 0. Address Registers after Operation: Function: The numeric data in the A-field are subtracted algebraically from the numeric data in the B-field. The remainder is stored in the B-field. Zone bits in the B-field are unchanged except for any in the sign position, which may be changed. If the sign is changed from minus to plus, the plus sign will have the B and A bit configuration. A-field zone bits are ignored in all positions except the sign position. Example: An A-field of 222B subtracted from a B-field of 6666 results in a B-field remainder of 4444. Also, an A-field of 5N5N subtracted from a B-field of 2B2K results in a B-field remainder of 3C3C (see "Add Cycles"). To illustrate a shorter A-field (discussed below): an A-field of 5N5N subtracted from a B-field of 4@42B2K results in a B-field remainder of 4436F6P (see "Digit Coding"). Word Marks: The B-field word mark stops the operation and must be set to define the field's high-order, leftmost position. The A-field requires a word mark only if it is shorter than the B-field; in that case, the system subtracts zeros from the extra high-order positions of the B-field up to, and including, its word-mark position. If the A-field is longer than the B-field, the high-order positions of the A-field that exceed the limit imposed by the B-field word mark are not processed. #### Subtract (One Field) Instruction Form: MNEMONIC OF CODE A-ADDRESS S S aaaaa $$Timing: T = 4.5 \ (L + 1 + A + 1.5A).$$ $$L = 1 \ \text{or} \ 6.$$ Address Registers after Operation: Function: The numeric data in the A-field are imagesubtracted and the zeroed result is stored in the A-field. Zone bits in the field are unchanged and the sign bit configuration is the same as it was before the operation. *Example:* An A-field of ABQ, subtracted from itself, leaves ??! as the remainder. Word Marks: The A-field word mark stops the operation and must be set to define the field's high-order, leftmost position. # Zero and Add (Two Fields) Instruction Form: MNEMONIC OF CODE A-ADDRESS B-ADDRESS ZA P aaaaa bbbbb $$Timing: T = 4.5 (L + 1 + E + A + 1.5B).$$ When L = 1, E = 1; when L = 11, E = 0. Address Registers after Operation: Function: The numeric data in the A-field are stored in the B-field with the same sign as in the A-field. Zone bits are stripped from all positions in the B-field except the sign position. If the A-field has a plus sign that is not composed of B and A bits, it is changed, for the B-field, to the B and A bit configuration. Example: An A-field of ÅB3, zero-added to a B-field of 1234567, changes the B-field to 000012C. (This also illustrates the shorter A-field discussed below.) Word Marks: The B-field word mark stops the operation and must be set to define the field's high-order, leftmost position. The A-field requires a word mark only if it is shorter than the B-field; in that case, the system sets to zero the extra high-order positions of the B-field up to, and including, its word-mark position. If the A-field is longer than the B-field, the high-order positions of the A-field that exceed the limit imposed by the B-field word mark are not processed. #### Zero and Add (One Field) Instruction Form: MNEMONIC OF CODE A-ADDRESS ZA ? aaaaa $$Timing: T = 4.5 \, (L + 1 + A + 1.5A).$$ L = 1 or 6. Address Registers after Operation: I-ADDRESS REG A-ADDRESS REG B-ADDRESS REG NSI A-LA A-LA Function: Zone bits are stripped from all positions in the A-field except the sign position. Numeric data in the field are unchanged and the sign of the field keeps the same polarity. If the A-field has a plus sign that is not composed of B and A bits, it is changed to the B and A bit configuration. Example: An A-field of ABCD5, zero-added to itself, is changed to 1234E. Also, an A-field of #b&-b\(\tilde{\pi}\), zero-added to itself, is changed to 300004D (see "Digit Coding"). Word Marks: The A-field word mark stops the operation and must be set to define the field's high-order, leftmost position. # Zero and Subtract (Two Fields) Instruction Form: MNEMONIC OF CODE A-ADDRESS B-ADDRESS ZS I aaaaa bbbbb $$Timing: T = 4.5 \text{ (L + 1 + E + A + 1.5B)}.$$ When L = 1, E = 1; when L = 11, E = 0. Address Registers after Operation: I-ADDRESS REG A-ADDRESS REG B-ADDRESS REG NSI A-LW B-LB Function: The numeric data in the A-field are stored in the B-field with the opposite sign, as shown in Figure 13. Zone bits are stripped from all positions in the B-field except the sign position. Example: An A-field of ÅBL, zero-subtracted from a B-field of 12345, changes the B-field to 0012C. (This also illustrates the shorter A-field discussed below.) Word Marks: The B-field word mark stops the operation and must be set to define the field's high-order, leftmost position. The A-field requires a word mark only if it is shorter than the B-field; in that case, the system sets to zero the extra high-order positions of the B-field up to, and including, its word-mark position. If the A-field is longer than the B-field, the high-order positions of the A-field that exceed the limit imposed by the B-field word mark are not processed. | A-FIELD SIGN | B-FIELD SIGN<br>AT END OF OPERATION | |---------------------------|-------------------------------------| | No B and No A bits (plus) | B bit (minus) | | B bit (minus) | B and A bits (plus) | | B and A bits (plus) | B bit (minus) | | A bit (plus) | B bit (minus) | Figure 13. Sign Changes for Zero and Subtract (Two Fields) #### Zero and Subtract (One Field) Instruction Form: MNEMONIC OP CODE A-ADDRESS ZS $$\dagger$$ aaaaa $Timing: T = 4.5 (L + 1 + A + 1.5A).$ $$L = 1 \text{ or } 6.$$ Address Registers after Operation: Function: Zone bits are stripped from all positions in the A-field except the sign position. Numeric data in the field are unchanged but the sign of the field changes to the opposite polarity. If the sign is changed from minus to plus, the plus sign will have the B and A bit configuration. Example: An A-field of ÅB3b&%□, zero-subtracted from itself, is changed to 123004M. (See "Digit Coding.") Word Marks: The A-field word mark stops the operation and must be set to define the field's high-order, leftmost position. # Multiply Instruction Form: MNEMONIC OF CODE A-ADDRESS B-ADDRESS M & aaaaa bbbbb $$Timing: T \approx 4.5 \ [L + 1 + E + 2.5M + (2.5M + 1.5) \ (2.5A + 3)]$$ $$L = 1, 6, or 11$$ Address Registers after Operation: $$\begin{array}{cccc} \text{I-ADDRESS REG} & \text{A-ADDRESS REG} & \text{B-ADDRESS REG} \\ \text{NSI} & \text{A-LA} & \text{B-LB} \end{array}$$ Function: The multiply instruction causes the numeric data in the A-field (multiplicand) to be repetitively added and stored in the B-field (product), starting with the rightmost positions. The multiplier is initially located in the B-field, but in the high-order positions. B-field Length: Because the product is developed in the B-field, the field must be big enough to accommodate the repetitive additions of the A-field and still not interfere with the multiplier position. Therefore, the length of the B-field is determined by adding 1 to the sum of the number of digits in the multiplicand and the multiplier. Because the multiplier has three positions and the multiplicand has five positions, the product field (B- field) has nine positions. Before the multiply instruction is given, an image of the multiplier must be moved or otherwise placed in the high-order positions of the product field, which then reads XXXZZZZZZ. During the multiply, the product field (B-addressed by its units position) is multiplied by the multiplicand, which is A-addressed by its units position. The first scan automatically replaces any data in the positions to the right of the multiplier with zeros, giving XXX000000, and the first add changes that to XXx0YYYYY as it removes the sign, decrements the multiplier image by 1, and adds the multiplicand to the low-order positions of the product field. Repetitive addition of the multiplicand continues as long as any part of the multiplier image remains, with the final product algebraically signed and the multiplier image destroyed, giving a product field of OPPPPPPPP. Zone Bits and Sign: Zone bits that appear in any position of the multiplicand (A-field) are undisturbed by the multiply operation. Zone bits that appear in the assigned product area are eliminated before product development starts. Zone bits that appear in the multiplier (high-order position of the B-field) are eliminated during product development. Before zonebit elimination starts, both the units position of the multiplicand and the multiplier are checked for zone bits (the sign of the factor). The presence or absence of zone bits is used to determine the sign of the product. Like signs in the units position of the multiplicand and multiplier result in a plus sign. Unlike signs result in a minus sign. At the end of the operation, the sign of the product is placed in the units (sign) position of the B-field. Multiplier Factor: As the product is developed, the multiplier is eliminated, digit by digit. If it is required for later use in the program, it must be retained in another storage area. Word Marks: Word marks must be set to identify the high-order position of the multiplicand, and also of the multiplier as represented in the product field. Example: Multiplication in the example shown (Figure 14) is a series of repetitive true or complement additions. The number and type of additions are determined by the multiplier digit. A multiplier digit from one to four causes the A-field (multiplicand) to be true-added that number of times. The multiplier digit is reduced by one each true-add cycle until zero is reached. The recognition of the zero ends the true-add cycles, and shifts the portion of the product field, being developed, one position to the left. A multiplier digit of five or more causes the A-field to be repetitively complement-added in the low-order positions of the Figure 14. Multiplication Example product field. The number of complement-additions depends on the multiplier digit. Thus, if the multiplier digit is 8, two complement-additions occur (the tens complement of 8 is 2). After the required number of complement-additions have been made, the product field is left-shifted and the A-field is true-added to the product field, starting in the *tens* position of the product. This method of processing multiplier digits five through nine saves processing cycles and time. For example, a multiplier digit of 8 causes, instead of eight true-added cycles, only three total cycles. | EXAMPLE | | PRODUCT FIELD | | |---------------------|------------------------|---------------|------------------| | 3456* | | -►800000 | leftmost | | × 8- | CA | 96544 | one | | 27648 | | 896544 | result of 1st CA | | | $\mathbf{C}\mathbf{A}$ | 96544 | two | | *Tens complement of | | 993088 | result of 2nd CA | | 3456 multiplicand | TA | 3456 | three | | = 96544 | | 027648 | end result | ### Divide Instruction Form: MNEMONIC OF CODE A-ADDRESS B-ADDRESS D Subbbb Arange: $$T \approx 4.5 \, \{L+1+E+6.5Q \, [A+1.5 \, (A+2)]\}$$ . L = 1, 6, or 11 Address Registers after Operation: Address Registers after Operation: I-ADDRESS REG A-ADDRESS REG B-ADDRESS REG NSI A-LA Tens position of the quotient field. Function: During a divide operation, the dividend located in the B-field is divided by the divisor located in the A-field. The result (quotient) is stored in the leftmost positions of the B-field. The dividend is destroyed during the operation, except for any remainder, which remains in the rightmost positions of the field. Conditions that must be considered before and during a divide operation are: - 1. Addressing of Factors: The A-address specifies the units position of the divisor. The B-address specifies the leftmost position of the dividend. The dividend itself is located in the rightmost positions of the quotient-dividend (B) field. - 2. B-field Length: Because the quotient is developed in the B-field, the field must be big enough to accommodate the repetitive complement-additions of the A-field and still not interfere with the quotient position being developed. Therefore, the length of the B-field is determined by adding 1 to the sum of the number of digits in the divisor and dividend fields. 3. Sign and Zeros: The divisor (located in the A-field) can be signed or unsigned. If no bits are in the units position of the divisor, the system assumes that the divisor is positive. There must be a sign in the units position of the dividend (located in the B-field). The sign will stop the division. The sign must consist of B and A bits for plus, or a B bit for minus. The quotient field must contain zeros when the divide operation starts. Moving the dividend into the B-field by means of a zero and add instruction ensures both the presence of zeros in the leftmost (quotient) positions of the B-field and the proper signing of the B-field. Word Marks: A word mark must be set to define the leftmost position of the divisor (A-field). If a zero and add instruction was used to move the dividend into the B-field, the leftmost position of the B-field retains the word mark required by the zero and add instruction. This B-field word mark is not needed during the divide operation; it is ignored, but still retained. Example: Division in the example shown (Figure 15) is a series of complement-additions, and, in the case of an overdraw, a true-addition. Complement-add cycles take place until signalled by a no-carry condition. The divisor factor is true-added, and then the shift to the next position takes place. The carry resulting from a successful complement-add cycle is used to develop the quotient. This type of operation con- Figure 15. Division Example tinues until the true-add cycle that corrects the units position of the dividend occurs. During this cycle, the signs of the dividend and the divisor are analyzed. The resultant sign is then applied to the units position of the quotient and the operation is ended. At the completion of the operation: - 1. The quotient is in the leftmost positions of the B-field. The location of the units position of the quotient is the address of the units position of the dividend, minus the length of the divisor, minus one. - 2. The remainder is located in the rightmost positions of the B-field. - 3. The sign of the quotient follows algebraic sign rules (Figure 16), and appears over the units position of the quotient at the end of the operation. - 4. The sign of the remainder is the sign of the original dividend (Figure 16). ### Notes: 1. Because only one quotient digit can be developed at a time, it is important to address the leftmost position of the dividend (B-address of the divide instruction). This ensures that the first divide operation results in a single high-order quotient digit. An improperly addressed dividend can cause a divide overflow condi- | Divisor Sign | + | + | _ | _ | |----------------|---|---|---|---| | Dividend Sign | + | | + | | | Remainder Sign | + | _ | + | - | | Quotient Sign | + | _ | _ | + | Figure 16. Division Sign Control tion if the result of the first divide operation is greater than 9. - 2. If the quotient field is not large enough, a resulting overflow may or may not be indicated. If the field is one position too small, there will not be an overflow indication, even though the units position of the adjacent field is changed. If the field is two or more positions short, the divide operation usually results in a divide overflow. Too small a quotient field is a programming error, and is not checked by the system. The divide overflow condition can be tested, however, by one of the branch instructions, $\check{J}$ (I) W. - 3. Division by zero always results in a divide overflow indication. - 4. If a larger quotient is required, extra zeros can be added to the dividend before the divide operation starts. For each additional quotient digit desired, insert one zero to the right of the dividend as shown in Figure 17. Figure 17. Additional Quotient Digits # **Processing Control Operations** ### Store Address Register Instruction Form: | MNEMONIC | OP CODE | C-ADDRESS | d-character | |----------|---------|-----------|--------------| | SAR | Ğ | cecce | A | | SBR | Ğ | ccccc | В | | SER | Ğ | cccc | E | | SFR | Ġ | ccccc | $\mathbf{F}$ | Timing: T = 69.75. Note: This instruction cannot be indexed. Address Registers after Operation: | I-ADDRESS REG | A-ADDRESS REG | B-ADDRESS REG | |---------------|---------------|---------------| | NSI | Ap | Bp | Function: The contents of the register specified by the d-character are stored in the C-field. The C-address specifies the rightmost position of the field in core storage where the register contents will be stored. The C-address signifies only that the C-address register, and not the A-address register, is used in storing the address register contents; the significance is that the A-address register is not changed. This instruction makes it possible to store the contents of the A- and B-address registers after any operation. (Contents of the E- and F-address registers can be stored after any tape operation in the overlap mode.) The store address register operation is particularly useful when fields or records of variable length are being processed, or when a method of linking the main routine with a subroutine is needed. The latter is made possible by the fact that the B-address register contains the address of the NSIB (next sequential instruction in the *main* routine) at the time that the program branches to a subroutine. If, therefore, the first instruction of the subroutine stores the B-address register contents into the I-address of a branch unconditionally instruction that is written as the last step of the subroutine, the program will branch back to the next instruction of the main routine as soon as the subroutine has been executed. (See the example under "Chaining Instructions.") Word Marks: Word marks in the C-field have no effect on the operation. Note: If there are zones in the C-field, they are not disturbed. ### Set Word Mark Instruction Form: | MNEMONIC | OP CODE | A-ADDRESS | B-ADDRESS | |----------|---------|-----------|-----------| | SW | Y, | aaaaa | bbbbb | Timing: T = 4.5 (L + 4). L = 1, 6, or 11. Address Registers after Operation: | | I-ADDRESS REG | A-ADDRESS REG | B-ADDRESS REG | |---------------|---------------|---------------|---------------| | Two Addresses | s NSI | A - 1 | B - 1 | | One Address | NSI | A - 1 | A - 1 | | No Addresses | NSI | Ap - 1 | Bp - 1 | Function: If this instruction is given as shown in the instruction form, a word mark is set in the specified A-address location and in the specified B-address location. The data characters in the specified locations are not disturbed. If this instruction is given with only one address (A-address), a word mark is set in the specified A-address location only. The data character in the specified location is not disturbed. If this instruction is given with no address specified (a no-address chained instruction), word marks are set in the address locations that are specified by the A- and B-address registers (contents from the previous operation). Word Marks: Word marks are explained in the previous paragraph. #### **Clear Word Mark** Instruction Form: MNEMONIC OP CODE A-ADDRESS B-ADDRESS CW $$\stackrel{\leftarrow}{\square}$$ aaaaa bbbbb Timing: $T=4.5~(L+4)$ . $$L = 1, 6 \text{ or } 11.$$ Address Registers after Operation: | | I-ADDRESS REG | A-ADDRESS REG | B-ADDRESS REG | |---------------|---------------|---------------|---------------| | Two Addresses | NSI | A - 1 | B - 1 | | One Address | NSI | A - 1 | A - 1 | | No Addresses | NSI | Ap - 1 | Bp-1 | Function: If this instruction is given as shown in the instruction form, a word mark is cleared, if present, from the specified A-address location and from the specified B-address location. The data characters in the specified locations are not disturbed. If this instruction is given with only one address (A-address), a word mark, if present, is cleared from the specified A-address location only. The data character in the specified location is not disturbed. If this instriction is given with no address specified (a no-address chained instruction), word marks, if present, are cleared from the address locations that are specified by the A- and B-address registers (contents from the previous operation). Word Marks: Word marks are explained in the previous paragraph. # **Clear Storage** Instruction Form: MNEMONIC OP CODE B-ADDRESS bbbbb $$Timing: T = 4.5 (L + 1 + B).$$ $$L = 1 \text{ or } 6$$ Address Registers after Operation: | I-ADDRESS REG | A-ADDRESS REG | B-ADDRESS REG | |---------------|---------------|---------------| | NSI | В | bbb00-1 | Function: A storage area is cleared of data and word marks, right-to-left, from the specified B-address location to, and including, the nearest hundreds position. For example, to clear storage from 12590 to 12500, use a / 12590 instruction. The B-address register, at the end of the operation, will hold 12499. If this instruction is given with no address specified (a no-address chained instruction), the contents of the B-address register are used as the B-address location. (In this case, the A-address register is not loaded at instruction loading time and is undisturbed at the end of the clear storage operation.) By chaining the instruction in this manner, several blocks of 100 core storage positions can be quickly cleared. For clearing larger blocks of core storage, a simple program loop (as shown in Figure 18) proves more efficient. This example clears the core storage area from positions 00500 to 36199. The first instruction sets a word mark in the low-numbered position of the core storage area being cleared. | | | | | | IN | STR | UCTI | ОИ | | | | | |--------------------------------------------------|---------|-----|---------------|---|-----------|-------------|-------------|----|-----------------------|------|---|---| | INSTRUCTION<br>ADDRESS | ОР | d | A<br>−x<br>fì | | IELC<br>d | ) | d | | В—Г | IELC | ) | d | | 0 0 1 2 3<br>0 0 1 2 9<br>0 0 1 3 5<br>0 0 1 4 2 | , / G > | 0 0 | 0 | 5 | 3 | 0<br>4<br>9 | 3<br>B<br>O | 6 | i<br>i<br>i<br>i<br>5 | 9 | 9 | 1 | Figure 18. One Method for Clearing Core Storage The second instruction starts clearing the specified core storage area at the high-numbered position. This instruction clears the core storage area from 36199 to 36100. (At the end of the operation, the B-address register contains the number 36099.) The third instruction stores the B-address register contents in core storage, starting at the address specified by the C-address register. The C-address register contains the core storage address that is the units position of the clear storage B-field. After the operation, core storage positions 00130-00134 contain the number 36099. The fourth instruction tests core storage position 00500 for the word mark that was previously put there. If the word mark is still there, the program branches to the specified I-address. The I-address is the core storage address that contains the clear storage operation code. The next 100 positions of core storage are cleared. When the last group of 100 core storage positions is cleared, the word mark is removed from core storage position 00500. The test instruction is performed, but no branch occurs. This signifies that the clear operation is complete, and the program proceeds with the next sequential instruction. Word Marks: Word marks are cleared in the area specified. # Clear Storage and Branch Instruction Form: MNEMONIC OP CODE 1-ADDRESS B-ADDRESS bbbbb $$Timing: T = 4.5 (L + 2 + B)$$ Address Registers after Operation: Function: This instruction has the same effect as clear storage except that the next instruction is taken from the I-address. This is an unconditional branch instruction. Word Marks: Word marks are cleared in the storage area specified by the B-address. #### Halt Instruction Form: $$\begin{array}{ccc} & \text{MNEMONIC} & \text{OP CODE} \\ & \text{H} & \text{Y} \\ \\ \textit{Timing: T = 4.5.} \\ & \textit{Address Registers after Operation:} \\ & \text{I-Address reg} & \text{A-Address reg} & \text{B-Address reg} \\ & \text{NSI} & \text{Ap} & \text{Bp} \\ \end{array}$$ Function: The system stops. Pressing the start key starts system operation with the next sequential instruction Word Marks: Word marks are not affected. If this is the last instruction in the program, a word mark must be preset in the storage location immediately to the right of the operation code. # **Halt and Branch** Instruction Form: | MNEMONIC | OP CODE | I-ADDRESS | |----------|---------|-----------| | H | · · | iiiii | Timing: T = 36. Address Registers after Operation: I-ADDRESS REG NSIB A-ADDRESS REG BI B-ADDRESS REG NSIB Function: The system stops. When the start key is pressed, the program resumes with the instruction located at the I-address. This is an unconditional branch instruction. Word Marks: Word marks are not affected. If this is the last instruction in the program, a word mark must be preset in the storage location immediately to the right of the halt and branch instruction. # **No Operation** Instruction Form: MNEMONIC NOP OP CODE Ň Timing: T = 4.5 (L + 1). $$L = 1, 2, 3 \dots$$ No Limit Address Registers after Operation: I-ADDRESS REG NSI A-ADDRESS REG Ap B-ADDRESS REG Bp Function: This operation code can be substituted for the operation code of any instruction to make that instruction ineffective. Word Marks: Word marks are not affected. These operations are used to manipulate data within core storage during processing. They include data moving, comparing, table lookup, and editing. # **Data Moving** This operation concerns moving data, either left-toright or right-to-left, from the A-field to the B-field (with or without word marks). Data can be moved by fields or by records. If a data field is moved, the operation can be programmed to stop at: - 1. A word mark in the A-field. - 2. A word mark in the B-field. - 3. A word mark in either field. If a record is moved, the operation can be programmed to stop at: - 1. A record mark in the A-field. - 2. A group-mark word-mark in the A-field. - 3. Either a record mark or group-mark word-mark in the A-field. The operation code for the move instruction is D. The bit structure of the d-character used with the move instruction determines the type of operation that will be performed. (In Figure 19, all 64 characters composed of the bits shown in the figure are valid; each one accomplishes a special purpose.) These operations are: - 1. The transfer of the numeric portion of the data field. - 2. The transfer of the zone portion of the data field. - 3. The transfer of word marks from the A-field to the B-field. - 4. The scanning of the A-field and B-field for word marks, record marks, or group-mark—word-marks (this operation is used when the storage positions containing the stated symbols can vary from one record to another no data are transferred). #### Move Instructions Instruction Form: MNEMONIC OF CODE A-ADDRESS B-ADDRESS d-CHARACTER x - - x D aaaaa bbbbb x (See Figure 22) Timing: $$T = 4.5 (L + 1 + A + 1.5B)$$ . $$L = 1, 6 \text{ or } 12$$ An instruction length of 6 chains the B-address and uses the last previous operation modifier. Address Registers after Operation: See Figure 20. Function: Data are moved from left to right or from right to left, serially by character, from the A-field to the B-field under control of the d-character (Figure 19).\* The portion of the A-field that is transferred replaces only the corresponding portion of the B-field. If data are moved from left to right, the A-address specifies the leftmost position of the A-field; the B-address specifies the leftmost position of the B-field. If data are moved from right to left, the A-address specifies the rightmost position of the A-field; the B-address specifies the rightmost position of the B-field. The | IARACTER | | |-----------------------|--------------------------------------------------------------------------------------------------------------| | TROL BITS | CONTROL | | 1 | Transfer of numeric portion of<br>data field | | 2 | Transfer of zone portion of data field | | 4 | Transfer word marks from A–field to B–field | | Blank<br>2, or 4 Bit) | Scan for word marks, record marks, or group-mark — word-marks | | No B and No A Bits | Stop transfer or scan at first word mark sensed in either field | | * A-Bit Only | Stop transfer or scan at A-field | | B-Bit Only | Stop transfer or scan at A—field<br>group-mark — word-mark | | B and A Bits | Stop transfer or scan at A—field<br>record mark or group-mark —<br>word-mark | | No B and No A Bits | Transfer or scan only one storage position | | * A-Bit Only | Stop transfer or scan at A—field<br>word mark | | B-Bit Only | Stop transfer or scan at B—field<br>word mark | | B and A Bits | Stop transfer or scan at first word mark sensed in either field | | | 2 4 Slank 2, or 4 Bit) No B and No A Bits * A-Bit Only B-Bit Only B and A Bits * A-Bit Only B and No A Bits | \*Whenever the A-bit d-character modifier is used in instructions to write programs on tape, the odd parity mode should be used. See Figure 95. Figure 19. d-Character Control Bits for Move Instructions | CONTROL | DIRECTION | Α | ADDRESS REGISTERS | | | |---------------------------------------------------------|-----------|-------------|-------------------|------------|--| | CONTROL | DIRECTION | 1–Add. Reg. | A-Add. Reg. | B-Add. Reg | | | Stop at first word mark sensed in either field | L to R | NSI | A + LW | B + LW | | | Stop at A—field record mark | L to R | NSI | A + LA | B + LA | | | Stop at A-field group-mark—word-mark | L to R | NSI | A + LA | B + LA | | | Stop at A-field record mark or group-mark—<br>word-mark | L to R | NSI | A + LA | B + LA | | | Stop after one storage position | R to L | NSI | A — 1 | B — 1 | | | Stop at A—field word mark | R to L | NSI | A - LA | B — LA | | | Stop at B-field word mark | R to L | NSI | A - LB | B-LB | | | Stop at first word mark sensed in either field | R to L | NSI | A - LW | B — LW | | Figure 20. Address Registers after Move Operations position that contains the terminating character is moved or replaced the same as the rest of the field. This same instruction, with the appropriate d-characters, is also used for scan operations (no data transferred). Word Marks: See Figure 19. #### **Mnemonics** Because each mnemonic character has a special meaning (Figure 21), it is possible to construct the entire mnemonic for any of the sixty-four move instructions by applying certain rules. These rules are: ### **Data Transferred** - 1. The first character of the mnemonic is M. - 2. The second character of the mnemonic specifies the direction of data movement, either left-to-right or right-to-left (L is right-to-left; R is left-to-right). - 3. The third section of the mnemonic specifies the portion of data moved. If only one portion of data is moved, this section contains a single mnemonic character (w, z, n, or c). If word marks and one other portion of data are moved, this section contains two mnemonic characters (zw, nw, or cw). - 4. The fourth section of the mnemonic specifies the terminating condition. If more than one data character is moved, the terminating mnemonic character is A, B, blank, R, G, or M. If only one data character is moved, the terminating mnemonic character is s. ### No Data Transferred (Scan) - 1. The first three characters of the mnemonic are scn. - 2. The fourth character of the mnemonic specifies the direction of scan, either L or R. - 3. The fifth character of the mnemonic specifies the terminating condition. The terminating mnemonic character is A, B, blank, R, G, M, or s. | | T | r | 1 | |-------------------------------|-----------------------|--------------------------------------|--------------------------------------------------------------| | CONTROL | MNEMONIC<br>CHARACTER | MEANING | DESCRIPTION | | | M | Move | Move data serial by character | | Direction<br>or<br>Type<br>of | SCN | Scan | Affect A- and B-address registers only, do not move data | | Operation | L L | Left | Right to left operation | | | R | Right | Left to right operation | | | N | Numeric | Move only numeric portion of data | | Portion<br>of | Z | Zone | Move only zone<br>portion of data | | Data<br>Transferred | С | Character | Move character(s) (zone and numeric portions of data) | | | w | Word Mark | Move word mark(s) | | | A (L) | A-Field<br>Word Mark | Stop at A-field word<br>mark | | | B (L) | B-Field<br>Word Mark | Stop at B-field word<br>mark | | | blank<br>(L or R) | Either A- or<br>B-Field<br>Word Mark | Stop at first word<br>mark sensed in either<br>A- or B-field | | TERMINAL<br>POINT | S (L) | One Position | Affect only one position | | | R (R) | Record Mark | Stop at A-field record<br>mark | | | G (R) | Group Mark | Stop at A-field group-<br>mark—word-mark | | | M (R) | Record or<br>Group Mark | Stop at A-field record<br>mark or group-mark —<br>word-mark | Figure 21. Mnemonic Characters for Move Instructions #### Example of Scan Instruction: Ď 00520 00720 Y (mnemonic scnrr). The most important results shown are the contents of the address registers after the operation. No data are transferred. The B-address must be a part of the instruction, even if, as in the example, the scan is for the first record mark in the A-field exclusively. Because the scan is from left to right, the A- and B-addresses specify the leftmost positions of the respective fields. Figure 22 is a complete chart of the data move d-characters and mnemonics. # **Move Characters and Suppress Zeros** $Instruction\ Form:$ | Direction<br>of<br>Move | Condition Which<br>Ends Operation | No Portion<br>Moved | Move<br>Numeric<br>Portion of<br>A-Field to<br>B-Field | | Move<br>Numeric<br>and Zone<br>from<br>A-Field to<br>B-Field | Move WM<br>in A-Field<br>to B-Field | Move<br>Numeric<br>and WM<br>from<br>A-Field to<br>B-Field | Move<br>Zone<br>and WM<br>from<br>A-Field to<br>B-Field | Move Numeric, Zone, and WM from A-Field to B-Field | d-Ch<br>BCD<br>Coding<br>(BA8<br>Bits) | |-------------------------|-----------------------------------------------------|---------------------|--------------------------------------------------------|-----------|--------------------------------------------------------------|-------------------------------------|------------------------------------------------------------|---------------------------------------------------------|----------------------------------------------------|----------------------------------------| | | Move data one position | blank<br>SCNLS | 1<br>MLNS | 2<br>MLZS | 3<br>MLCS | 4<br>MLWS | 5<br>MLNWS | 6<br>MLZWS | 7<br>MLCWS | NONE | | RIGHT | Move data through 1st WM in<br>A-field | 5<br>SCNLA | /<br>MLNA | S<br>MLZA | T<br>MLCA | U<br>MLWA | V<br>MLNWA | W<br>MLZWA | X<br>MLCWA | A | | LEFT | Move data through 1st WM in<br>B-field | _<br>SCNLB | J<br>MLNB | K<br>MLZB | L<br>MLCB | M<br>MLWB | N<br>MLNWB | O<br>MLZWB | P<br>MLCWB | В | | | Move data through 1st WM in<br>either A- or B-field | &<br>SCNL | A<br>MLN | B<br>MLZ | C<br>MLC | MLW<br>D | E<br>MLNW | F<br>MLZW | G<br>MLCW | В, А | | | Move record through 1st WM in either A- or B-field | 8<br>SCNR | 9<br>MRN | 0<br>MRZ | #<br>MRC | @<br>MRW | :<br>MRNW | ><br>MRZW | √<br>MRCW | 8 | | LEFT | Move record through 1st RM in | Y<br>SCNRR | Z<br>MRNR | ‡<br>MRZR | ,<br>MRCR | %<br>MRWR | MRNWR | \<br>MRZWR | <del>III-</del><br>MRCWR | A, 8 | | RIGHT | Move record through 1st GM-<br>WM in A-field | Q<br>SCNRG | R<br>MRNG | !<br>MRZG | \$<br>MRCG | *<br>MRWG | ]<br>MRNWG | ;<br>MRZWG | Δ<br>MRCWG | В, 8 | | | Move record through 1st RM or<br>GM-WM in A-field | H<br>SCNRM | I<br>MRNM | ?<br>MRZM | •<br>MRCM | □<br>MRWM | [<br>MRNWM | <<br>MRZWM | ‡<br>MRCWM | в, А, 8 | | | d-Ch BCD Coding (421 Bits) | NONE | 1 | 2 | 2, 1 | 4 | 4, 1 | 4, 2 | 4, 2, 1 | | Figure 22. Data Move d-Characters and Mnemonics Address Registers after Operation: Function: This instruction causes the data in the A-field to be moved to the B-field. The A-field remains unchanged after the operation. High-order zeros and commas in the B-field are replaced by blanks, and zone bits in the units (sign) position of the B-field are removed. Refer to Figure 23 for an example of move characters and suppress zeros. | Example | Op Code | A–address | B–address | |----------------------------------|---------|---------------------------------|-----------------------------------| | Move Char. and<br>Suppress Zeros | ž | xxxxx | xxxxx | | Storage before | | A—field (data)<br>v ±<br>001206 | B—field (data)<br>V V ±<br>bbbbbb | | Storage after | | 001206<br>± | bb1206 | Figure 23. Move Characters and Suppress Zeros Example Figure 24 is another example of the move characters and suppress zeros instruction, but one involving a multiple field transfer. In this operation there are effectively two groups of high-order zeros. Alphabetic characters and most special characters (for example, the @ sign) are recognized as not being a significant digit or a zero, blank, comma, decimal, or minus sign. Thus, not only are the two high-order zeros suppressed, but also the two zeros to the right of the @ sign. | Example | Op Code | A–address | B-address | |----------------------------------|---------|--------------------------------------|-------------------------------------------------------------------| | Move Char. and<br>Suppress Zeros | ž | xxxxx | xxxx | | Storage before | | A-field (data)<br>v ±<br>0010b@00.25 | B-field (data)<br>V V V ±<br>bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb | | Storage after | | 0010b@00.25 | bb10b@bb.25 | Figure 24. Move Characters and Suppress Zeros Example, Multiple Field Word Marks: The A-field must have a defining word mark. It is this word mark that specifies the length of the data moved to the B-field. B-field word marks within this specified area, including the leftmost position, are removed during the operation. # Comparing The IBM 1410 compares data fields by testing the bit structure of each character in the B-field with the bit structure of each character in the A-field. All BA8421 bits are compared, but not C bits or word marks. The result of the compare operation is determined by the collating sequence of 1410 characters (see Figure 2). B can be equal to, unequal to, higher than, or lower than A. ### Compare Instruction Form: MNEMONIC OF CODE A-ADDRESS B-ADDRESS bbbbb Timing: T = 4.5 (L + 1 + A + B). L = 1, 6 or 11. Address Registers after Operation: $\begin{array}{cccc} \text{I-ADDRESS REG} & \text{A-ADDRESS REG} & \text{B-ADDRESS REG} \\ \text{NSI} & \text{A}-\text{LW} & \text{B}-\text{LW} \end{array}$ Function: The data in the B-field are compared to the data in the A-field. The comparison is never made A to B, but always B to A. The operation does not change either field. The result of the compare sets the high (B > A), equal (B = A), or low (B < A) indicator, depending on whether the B-field data are high, equal, or low with respect to the A-field. These internal indicators are tested by a subsequent branch instruction: branch if compare high, branch if compare equal, branch if compare low, or branch if compare unequal. The high, equal, and low indicators are represented by panel lights at the console. (When the unequal indicator turns on, either the high or the low indicator, with its light, also turns on.) To avoid losing the result of a compare operation, the appropriate indicator must be tested before all four are turned off by the next compare, table lookup, or branch if character equal instruction and are set to the result of that next operation. Word Marks: The compare operation is ended by either an A-field or a B-field word mark. If the A-field is shorter than the B-field, the high indicator is turned on (example 5). If the B-field is shorter than the A-field, or of the same length as the A-field, the high, equal, low, and unequal indicators are correctly set for the portions of the fields compared. # Examples Instruction: Č 00520 00720 (used for all examples). The address register contents are shown before and after the compare operation. The result of the compare is above each example. 1. Result: B-field is equal to A-field. 2. Result: B-field is low because of collating sequence. 3. Result: B-field is high. 4. Result: B-field is equal to A-field. 5. Result: B-field is high because A-field is shorter. 6. Result: B-field is high, even though negative. # Table Lookup Many commercial and scientific applications are characterized by the need to search through a table for rates, mathematical factors, or other types of information that vary with the requirements of the input data. The IBM 1410 Data Processing System has a powerful table lookup instruction that causes the system to search through the table and find the *function* (desired factor or address of desired factor). To do this, the machine requires two arguments in addition to the function. They are the search argument and the table argument. # Search Argument The search argument is a data field that has been generated internally or read into the system from a card, tape, disk record, or other input medium. It is used to find the table argument. ### **Table Argument** The table argument is kept in a table of arguments in core storage. It is exactly the same number of characters as the search argument. If it is shorter, it signifies the end of the table and ends the table search. ### **Function** The function is kept in core storage with the table argument. If the desired factor is five positions or less, it is often practical to store the factor itself in this place. In this case, the desired factor is the function. If the desired factor is more than five characters, it is usually kept in another area of core storage. In this case, the function is the five-character address of the desired factor. Because the timing of the table lookup operation is determined by the number of characters in the table that are read before a table argument is found, it is desirable to have the least possible number of characters in the function. Another suggested method for reducing the number of characters in the function is to store the desired factors in a separate table and store the starting address of this table in an accumulator field. If the function contains a factor (less than five characters) that can be added to the starting address to give the actual address of the desired factor, the lookup operation takes less time. Function values may also be stored a fixed number of core-storage positions from their arguments. Thus, having found the location N of the argument, the function is located at N+C, where C is the fixed separation of the functions from the arguments. #### Finding the Function The operation can be programmed to stop when a table argument is found that is equal to the search argument. The program can then move the desired factor to a working area for processing. If the function is the desired factor, it can be moved directly to the working area. If not, it is necessary to bring out the address of the desired factor and then move the factor to the working area. A table lookup operation can also be stopped if a table argument is found that is higher than, or lower than, the search argument, or when the table argument is *shorter* than the search argument. (The last condition turns on the high-compare indicator.) ### **Table Lookup** Instruction Form: Timing: $$T = 4.5 (L + 1 + B + NA)$$ . $L = 1, 6 \text{ or } 12$ . An instruction length of 6 chains the B-address and uses the last previous operation modifier. Address Registers after Operation: I-ADDRESS REG A-ADDRESS REG NSI A-LW A B-ADDRESS REG Address of the function at immediate left of the table argument that stopped the operation. NOTE: If a table field is found that is shorter than the search argument, the B-address register will contain the address of the position at the immediate left of the short table field. Thus, a short table field can be used to signal the end of the table. This condition results in setting the high compare indicator on. Function: Table lookup, a general name for the group of specific instructions listed in Figure 25, causes the system to search through the table from right to left until it finds the function. The search for the function is made indirectly, by searching for a table argument that is equal to, higher than, or lower than the search argument, as specified by the dcharacter. The table lookup operation stops one position to the left of the first table argument that satisfies the specifications of the lookup instruction; consequently, the stopped B-address register contains the address of the rightmost character of the function, as shown in Figure 26. (For variations, see the preceding note and "Function.") Also, the equal, high, or low-compare indicator is turned on as a result of the last argument comparison. The A-address is the address of the rightmost position of the search argument. At the start of each search cycle, the C-address register automatically receives this address and, if no hit is made, replaces it in the | DESCRIPTION | MNEMONIC | d-CHARACTER | TABLE SEARCH<br>RESULT | |-------------------------|----------|-------------|-------------------------------------------| | Lookup Low | LL | 1 | Lower than search<br>argument | | Lookup Equal | LE | 2 | Equal to search argument | | Lookup Low<br>or Equal | LLE | 3 | Equal to or lower than search argument | | Lookup High | LH | 4 | Higher than search<br>argument | | Lookup Low<br>or High | LLH | 5 | Lower than or higher than search argument | | Lookup Equal<br>or High | LEH | 6 | Equal to or higher than search argument | | Lookup to Any | none | 7 | Stop on any | | Lookup to End | none | blank | Search to end of table | Figure 25. Valid d-Characters for Table Lookup Instructions A-address register so the search can be repeated at the next table argument to the left. The B-address is the address of the rightmost character of the entire table. Each table field within the table is an implicit B-field, including one table argument in its rightmost positions and one function in its leftmost positions. The number of characters in the table argument must be equal to the number of characters in the search argument, if the search is to continue. Word Marks: The search argument (A-field) must have a word mark set to define its leftmost position. Each table field must also have a defining word mark in its leftmost position. The A-field word mark stops the comparison against the table argument. If no hit is made, the system starts to compare arguments again at the position to the immediate left of the word mark in the table field (rightmost position of next table argument). | Search | TABLE FIELD | | | | | | |-------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------------------------------------------|--|--|--|--| | Argument | Function<br>(Desired Factor) | Table Argument | | | | | | i 2 4 2 | 5 9 8<br>6 9 8 | 1 2 4 3<br>1 2 4 2 Hit | | | | | | Example: Table arguments stored in table in ascending order, right to left. (Table always searched from right to left.) | 2 9 7<br>9 1 9 8<br>9 8<br>3 9 5<br>4 9 5 | 1 2 4 1<br>1 1 1 5<br>1 1 1 4<br>1 1 1 3<br>1 0 0 2 Search | | | | | Figure 26. Table Lookup Operation Example: Find the unit price of part number 1242. The unit price is the desired factor, and the part number is the search argument and the table argument (Figure 26). The table is searched from right to left with, in this example, a lookup equal instruction. When the search argument equals the table argument, the search stops. The B-address register then holds the address of the units position of the function. # **Editing** The IBM 1410's edit instruction causes all desired commas, decimals, dollar signs, asterisks, credit symbols, and minus signs to be inserted automatically in a numeric output field. Also, unwanted zeros to the left of significant digits can be suppressed (Figure 27). The step-by-step editing is shown in Figure 34. In editing, two fields are needed: the data field and a control field. The data field is the data to be edited for output. The control field specifies how the data field is to be edited: the location of punctuation, condition of special characters, and where zero suppression is to occur. The control field (mask) is divided into two parts: the body (used for punctuating the A-field) and the status portion (containing the special characters). The body of the control field begins with the rightmost blank or zero (Figure 27) and continues to the left until the A-field word mark is sensed. The remaining portion of the control field is the *status* portion. Sign printing is partly controlled by the sign of the A-field. An edit operation requires two instructions. A move instruction transfers the control field and its word mark to the output area; the edit instruction moves the data to the output area and edits the data. | Example | Op Code | A-address | B-address | |----------------|---------|---------------------------|--------------------| | Edit Inst. | Ě | 12163-7 | 04685 | | | | A-field | B-Field (control | | | | (data) | field) | | | | 1 | status body status | | Storage | | 00257426 \$bbb,bb0.bb&CR8 | | | Result of Edit | | | B-field ↓ | | Storage | | 00257426 | \$ 2,574.26 * | Figure 27. Results of Editing ### Move Characters and Edit Instruction Form: | MNEMONIC | OP CODE | A-ADDRESS | B-ADDRESS | |----------|---------|-----------|-----------| | MCE | Ě | aaaaa | bbbbb | Timing: T = 4.5 (L + 1 + A + 1.5B + 1.5Z + 1.5D). $$L = 1, 6 \text{ or } 11.$$ Address Registers after Operation: I-ADDRESS REG A-ADDRESS REG B-ADDRESS REG Varies with result of edit Function: The data field (A-field) is modified by the contents of the edit control field (B-field), and the result is stored in the B-field. The data field and the control field are read from storage alternately, character by character, under control of the word marks and the editing specifications. See "Editing Specifications." Any sign in the units position of the data field is removed during the operation. Word Marks: A word mark must be set in the highorder position of the B-field to control the edit operation. The A-field must also have a defining word mark. When the A-field word mark is sensed, the remaining commas in the B-field are set to blanks. The edited output field does not contain any A-field data that have not been moved before the word mark for the control field is sensed. The data field can contain fewer, but should not contain more, positions than the number of blanks and zeros in the body of the control word. # **Editing Specifications** All numeric, alphabetic, and special characters can be used in the control field. The characters shown in Figure 28 have special meanings. #### **Zero Suppression** Zero suppression is the deletion of unwanted zeros at the left of significant digits in an output field (Figure 29). A special 0 is placed (in the body of the control field) in the rightmost limit of zero suppression. #### Forward Scan - 1. The positions in the output field at the right of this special zero are replaced by the corresponding digits from the A-field. - 2. When the special zero is detected in the control field, it is replaced by the corresponding digit from the A-field. - 3. A word mark is automatically set in this position of the B- (output) field. - 4. The scan continues until the B-field (high-order) word mark is sensed and removed. | CONTROL CHARACTER | FUNCTION | |-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | b (blank) | Replaced with the character from the corresponding position of the A-field. | | O (zero) | Used for zero suppression. Replaced with a corresponding character from the A-field. The rightmost 0 in the control field indicates the rightmost limit of zero suppression. | | . (point) | Remains in the edited field in the posi-<br>tion where written, unless decimal control<br>was in effect, and the data field did not<br>contain a significant digit. (See "Decimal<br>Control.") | | , (comma) | Undisturbed in the output data field in<br>the position where written, unless zero<br>suppression takes place and no signifi-<br>cant numeric character is found at the left<br>of the comma. | | CR (credit) | Body Portion: undisturbed in the position where written. Status Portion: if sign of the data field is plus, these two positions are replaced by blanks. If the sign of the data field is minus, they are undisturbed in the output field in the positions where written. (See also "Sign Control Left.") | | — (minus) | Same as CR. | | & (ampersand) | Causes a blank space in the output field.<br>It can be used in multiples. | | * (asterisk) | Status Portion: undisturbed in the position where written. Body Portion: (See "Asterisk Protection.") | | \$ (dollar) | Status Portion: undisturbed in the position where written. Body Portion: (See "Floating Dollar Sign.") | | | | Figure 28. Editing Specifications | EXAMPLE: | | |-------------------------|--------------------------| | A-field | 0010900 | | Control field (B-field) | y<br>\$bb,bb0.bb | | Forward scan | \$00,10 <sup>9</sup> .00 | | Reverse scan | \$bbb109.00 | | Results of edit | \$ 109.00 | Figure 29. Zero Suppression # Reverse Scan - 1. All zeros and punctuation at the left of the first significant character (up to and including the zero suppression code position) are replaced by blanks in the output field. - 2. When the automatically set zero-suppression word mark is sensed, it is erased and the operation ends. # **Asterisk Protection** When it is necessary to have asterisks appear at the left of significant digits, the asterisk protection feature is used (Figure 30). The control field is written with the asterisk in the body to the left of the zero-suppression code (if the asterisk appears in the body to the right of the zero-suppression code, it is treated as a blank). | EXAMPLE: | | |-------------------------|----------------------| | A-field | 0025742 <del>6</del> | | Control field (B-field) | v<br>bbb,b*0.bb&CR | | Forward scan | 002,574.26 CR | | Reverse scan | **2,574.26 CR | | Results of edit | **2,574.26 CR | Figure 30. Asterisk Protection #### Forward Scan - 1. The normal editing process proceeds until the asterisk is sensed. - 2. The asterisk is replaced (in the output field) by the corresponding digit from the A-field. - 3. The editing process continues normally until the B-field word mark is sensed and removed. #### Reverse Scan - 1. Zeros, blanks, and punctuation to the left of the first significant digit are replaced by asterisks. - 2. The word mark (set during the forward scan) signals the end of editing. It is erased, and the operation stops. Note: Asterisk protection and floating dollar sign cannot be used in the same control field. # Floating Dollar Sign This feature causes the insertion of a dollar sign in the position at the left of the first significant digit in an amount (Figure 31). | EXAMPLE: | | |-------------------------|----------------------| | A-field | 00257426 | | Control field (B-field) | <b>b</b> bbb,b\$0.bb | | First forward scan | ь002,574.26 | | Reverse scan | bbb2,574.26 | | Second forward scan | \$2,574.26 | | Results of edit | \$2,574.26 | Figure 31. Floating Dollar Sign The control field is written with the "\$" in the body to the left of the zero-suppression code (if the dollar sign appears in the body to the right of the zerosuppression code, it is treated as a blank). Three scans are necessary to complete this editing operation. #### First Forward Scan - 1. The editing proceeds until the "\$" is sensed. - 2. The "\$" is replaced (in the output field) by the corresponding digit from the A-field. - 3. Editing continues until the B-field word mark is sensed and removed. #### Reverse Scan - 1. Zeros and punctuation to the left of the first significant digit are replaced by blanks. - 2. The reverse scan continues until the word mark (set over the zero-suppression code during the first forward scan) signals the start of the second forward scan. #### Second Forward Scan 1. The word mark is erased, and the scan continues until the first blank position is sensed. This blank position is replaced by "\$," and the operation stops. Note: Floating dollar sign cannot be used at the right of the decimal point. Also, floating dollar sign and asterisk protection cannot be used in the same control field. If floating dollar sign protection is needed for data having cents but no dollars, decimal control must *not* be used at the same time as floating dollar sign control. For example, if both controls are in use and the control field is bb\$.b0, an A-field of 00025 is edited to .25 and not \$.25. To include the floating dollar sign and a decimal point in the edited result without activating the decimal control, place the zero-suppression code to the *left* of the point in the control field (example: b\$0.bb). ### Sign Control Left CR or - symbols can be placed at the left of a negative field (Figure 32). | EXAMPLE: | | |-------------------------|---------------| | A-field | 00378940 | | Control field (B-field) | ČR&bbb,bb0.bb | | Forward scan | CRb003,789.40 | | Reverse scan | CRbbb3,789.40 | | Results of edit | CR 3,789.40 | Figure 32. Sign Control Left The control field is written with the CR or - symbols in the high-order status position. #### Forward Scan - 1. The scan proceeds until the zero-suppression code (0) in the control field is sensed. - 2. The corresponding character from the A-field is placed in this position of the output field. - 3. A word mark is automatically inserted in this position in the output field. - 4. The scan proceeds until the A-field word mark is sensed, indicating the end of the body of the control field. - 5. Editing continues until the B-field word mark is sensed. If the sign of the A-field is minus, the CR or is undisturbed; if the A-field sign is plus the CR or is blanked. #### Reverse Scan - 1. Zeros and puctuation are replaced by blanks in the output field. The scan continues until the automatically set word mark is sensed. - 2. This word mark is erased and the operation ends. #### **Decimal Control** This feature ensures that decimal points print only when there are significant digits in the A-field (Figure 33). The control word is written with a point in the body to the left of the zero-suppression code (0). Two scans are sufficient to complete this editing operation unless the field contains no significant digits; in that case, three scans are required. | EXAMPI | LES: | | |--------|-------------------------|-----------------------| | 1. | A-field | ŏ0000 | | | Control field (B-field) | bbb.b0 | | | First forward scan | 000.00 | | | Reverse scan | bbb.00 | | | Second forward scan | bbb | | | Results of edit | (Blank Field) | | 2. | A-field | <sup>v</sup><br>29437 | | | Control field (B-field) | bbb.b0 | | | First forward scan | 294.37 | | | Reverse scan | 294.37 | | | Result of edit | 294.37 | | 3. | A-field | ŏ0001 | | | Control field (B-field) | bbb.b0 | | | First forward scan | 000.01 | | | Reverse scan | bbb.01 | | | Results of edit | .01 | Figure 33. Decimal Control #### First Forward Scan - 1. When the zero-suppression code (0) is sensed during editing, this position is replaced by the corresponding digit from the A-field. - 2. A word mark is set automatically in this position in the B (output) field. - 3. Editing continues normally until the B-field word mark is sensed and removed. #### Reverse Scan 1. Zeros and punctuation are replaced by blanks in the output field until the decimal point is sensed. 2. The decimal point and the digits at its right are unaltered. The automatically set word mark is erased. If there are no significant digits in the field, the second forward scan is initiated; otherwise, the edit operation stops. # Second Forward Scan - 1. The zeros at the right of the decimal point, and the decimal point itself, are replaced by blanks. - 2. The operation stops at the decimal column. Figure 34 is a step-by-step editing process of the example shown in Figure 27. | STEP | TYPE<br>OF | ADD | RESS REGIST | ERS | DATA RE | GISTER | PUT<br>BACK | B-FIELD<br>AT | REMARKS | |------|------------|-------|-------------|--------|---------|--------|-----------------|--------------------|----------------------------| | SIEF | CYCLE | I | A | В | В | A | INTO<br>STORAGE | END OF CYCLE | REMARKS | | 1 | l-op | 00002 | ????? | 777?? | Ě | Ě | Ě | \$bbb,bb0.bb&CR&** | Read Instruction Op Code | | 2 | 1-1 | 00003 | 1???? | ????? | 1 | 1 | 1 | Same | Load A-address register | | 3 | I-2 | 00004 | 12??? | ????? | 2 | 2 | 2 | Same | Load A-address register | | 4 | 1-3 | 00005 | 121?? | 22222 | 1 | 1 | 1 | Same | Load A-address register | | 5 | I-4 | 00006 | 1216? | ????? | 6 | 6 | 6 | Same | Load A-address register | | 6 | 1-5 | 00007 | 12163 | ????? | 3 | 3 | 3 | Same | Load A-address register | | 7 | 1-6 | 80000 | 12163 | 0.3333 | 0 | 0 | 0 | Same | Load B-address register | | 8 | 1-7 | 00009 | 12163 | 04??? | 4 | 4 | 4 | Same | Load B-address register | | 9 | 1-8 | 00010 | 12163 | 046?? | 6 | 6 | 6 | Same | Load B-address register | | 10 | 1-9 | 00011 | 12163 | 0468? | 8 | 8 | 8 | Same | Load B-address register | | 11 | I-10 | 00012 | 12163 | 04685 | 5 | 5 | 5 | Same | Load B-address register | | 12 | 1-11 | 00012 | 12163 | 04685 | Ŏρ | Ŏр | Ŏρ | Same | Op Code & next instruction | | 13 | A | 00012 | 12162 | 04685 | 6 | 6 | 6 | Samo | Execute EDIT instruction | | 14 | В | 00012 | 12162 | 04684 | * | 6 | * | Same | | | 15 | В | 00012 | 12162 | 04683 | * | 6 | * | Same | | | 16 | В | 00012 | 12162 | 04682 | & | 6 | Blank | \$bbb,bb0.bb&CRb** | | | 17 | В | 00012 | 12162 | 04681 | R | 6 | Blank | \$bbb,bb0.bb&Cbb** | | | 18 | В | 00012 | 12162 | 04680 | С | 6 | Blank | \$bbb,bb0.bb&bbb** | | | 19 | В | 00012 | 12162 | 04679 | & | 6 | Blank | \$bbb,bb0.bbbbb** | | | 20 | В | 00012 | 12162 | 04678 | ь | 6 | 6 | \$bbb,bb0.b6bbb** | | | 21 | A | 00012 | 12161 | 04678 | 2 | 2 | 2 | Same | | | 22 | В | 00012 | 12161 | 04677 | ь | 2 | 2 | \$bbb,bb0.26bbbb** | | | 23 | A | 00012 | 12160 | 04677 | 4 | 4 | 4 | Same | | Figure 34. Step-by-Step Editing Process (continued on next page) | | TYPE | ADD | RESS REGIST | TERS | DATA R | EGISTER | PUT<br>BACK | B-FIELD | | |------|-------------|-------|-------------|-------|--------|---------|-----------------|---------------------------------|------------------------------| | STEP | OF<br>CYCLE | 1 | A | В | В | A | INTO<br>STORAGE | AT<br>END OF CYCLE | REMARKS | | 24 | В | 00012 | 12160 | 04676 | • | 4 | • | Same | | | 25 | В | 00012 | 12160 | 04675 | 0 | 4 | 4 | \$bbb,bb4.26bbbb** | Zero Suppress | | 26 | A | 00012 | 12159 | 04675 | 7 | 7 | 7 | Same | | | 27 | В | 00012 | 12159 | 04674 | b | 7 | 7 | \$bbb,b74.26bbbb** | | | 28 | A | 00012 | 12158 | 04674 | 5 | 5 | 5 | Same | | | 29 | В | 00012 | 12158 | 04673 | b | 5 | 5 | \$bbb,574.26bbbb** | | | 30 | A | 00012 | 12157 | 04673 | 2 | 2 | 2 | Same | | | 31 | В | 00012 | 12157 | 04672 | , | 2 | , | Same | | | 32 | В | 00012 | 12157 | 04671 | ь | 2 | 2 | \$bb2,574.26bbbb** | | | 33 | A | 00012 | 12156 | 04671 | o | 0 | 0 | Same | | | 34 | В | 00012 | 12156 | 04670 | ь | 0 | 0 | \$b02,574.26bbbb** | | | 35 | Α | 00012 | 12155 | 04670 | ŏ | ŏ | ŏ | Same | | | 36 | В | 00012 | 12155 | 04669 | ь | ŏ | 0 | \$002,574.26bbbb** | | | 37 | В | 00012 | 12155 | 04668 | \$ | ŏ | \$ | \$002,57 <sup>4</sup> .26bbbb** | Sense Word Mark — Rev. Scan | | 38 | В | 00012 | 12155 | 04669 | ? | ŏ | ? | \$002,57 <sup>4</sup> .26bbbb** | Units Position of next Field | | 39 | В | 00012 | 12155 | 04670 | \$ | ŏ | \$ | Same | | | 40 | В | 00012 | 12155 | 04671 | 0 | ŏ | Blank | \$b02,574.26bbbb** | | | 41 | В | 00012 | 12155 | 04672 | 0 | ŏ | Blank | \$bb2,574.26bbbb** | | | 42 | В | 00012 | 12155 | 04673 | 2 | ŏ | 2 | Same | | | 43 | В | 00012 | 12155 | 04674 | , | ŏ | , | Same | | | 44 | В | 00012 | 12155 | 04675 | 5 | ŏ | 5 | Same | | | 45 | В | 00012 | 12155 | 04676 | 7 | ŏ | 7 | Same | | | 46 | В | 00012 | 12155 | 04677 | ¥ | ŏ | 4 | \$bb2,574.26bbbb** | | Figure 34. Step-by-Step Editing Process (Continued) # **Branch Operations** The 1410 program can examine (test for) any one of many conditions that arise during processing and transfer the program to a predetermined instruction or subroutine as a result of the specific test. This transfer from one instruction to another instruction or subroutine that is not in the sequential order of program steps is called a program branch. A branch instruction is one of two types: - 1. A branch that occurs as a direct result of the execution of the instruction itself is called an *unconditional branch*. Thus, no special condition (other than the execution of the program step) is needed to transfer the program out of its normal sequential execution. - 2. A branch that occurs as a result of a particular condition such as an arithmetic overflow, zero balance, etc., is called a *conditional branch*. If the condition is present at the time a conditional branch instruction is executed, sequential execution of program steps is bypassed, and the program branches to the address of the instruction specified by the I-address of the conditional branch instruction. If the condition is not present, the system simply continues with the next sequential instruction. All branch instructions have a d-character that is used to specify the conditions necessary for a program transfer. # **Branch Codes** # **Branch Unconditionally** Instruction Form: $$L = 1 \text{ or } 7$$ Address Registers after Operation: | I-ADDRESS REG | A-ADDRESS REG | B-ADDRESS REG | |---------------|---------------|---------------| | NSIB | BI | NSIB | Function: This is an unconditional branch instruction. Whenever it is executed, it causes a program branch to the location specified by the I-address. Word Marks: No special considerations. # **Branch Conditionally (One Address)** Instruction Form: Timing: $$T = 4.5 (L + 1 + C)$$ . $$L = 1 \text{ or } 7$$ Address Registers after Operation: | | I-ADDRESS REG | A-ADDRESS REG | B-ADDRESS REG | |-----------|---------------|---------------|---------------| | Branch | NSIB | BI | NSIB | | No Branch | NSI | BI | BI | Function: Branch conditionally (one address) instructions, a general name for the group of specific instructions listed in Figure 35, permit the program to test for conditions that may arise during the processing. All use the J op code. The d-character is variable and specifies the internal indicator or condition that is tested for the on or off state. If the indicator is on, the program branches to the I-address specified within the branch instruction. If the indicator is off, the program merely continues to the next sequential instruction. Two uses for the branch if overlap in process instruction, J(I) or J(I) 2, that are practically mandatory for overlap processing are described under "Overlap Operational Considerations" (see index). The carriage channel 9 and carriage channel 12 indicators are turned on whenever the corresponding holes in the carriage tape are sensed. They are turned off whenever another carriage tape channel is sensed. To avoid losing the result of a compare operation, it is necessary to test the compare indicators before they are turned off by the next compare, table lookup, or | DESCRIPTION | MNEMONIC | d-CHAR | |--------------------------------------------|---------------|--------| | Branch if Arithmetic Overflow | BAV | Z | | Branch if Carriage 9 (Ch 1) | BC9 or BC91 | 9 | | Branch if Carriage 9 (Ch 2) | BC92 | ! | | Branch if Carriage Busy (Ch 1) | BPCB or BPCB1 | R | | Branch if Carriage Busy (Ch 2) | BPCB2 | L | | Branch if Carriage Overflow, 12 (Ch 1) | BCV or BCV1 | @ | | Branch if Carriage Overflow, 12 (Ch 2) | BCV2 | П | | Branch if Compare Equal (B = A) | BE | S | | Branch if Compare High (B $>$ A) | вн | U | | Branch if Compare Low (B < A) | BL | Т | | Branch if Compare Unequal (B $>$ or $<$ A) | BU | 1 | | Branch if Divide Overflow | BDV | w | | Branch if Inquiry Request (Ch 1) | BNQ or BNQ1 | Q | | Branch if Inquiry Request (Ch 2) | BNQ2 | * | | Branch if Overlap in Process (Ch 1) | BOL1 | 1 | | Branch if Overlap in Process (Ch 2) | BOL2 | 2 | | Branch if Tape Indicator (for CE use) | | K | | Branch if Zero Balance | BZ | v | Figure 35. Specific Instructions of Branch Conditionally (One Address) branch if character equal instruction and are set to the result of that next operation. The overflow indicators are turned off by either a specific branch instruction testing the indicator or a computer reset operation. A computer reset operation also turns off the zero result indicator and turns on the low-compare and unequal-compare indicators. Word Marks: No special considerations. #### Branch if I/O Channel Status Indicator On Instruction Form: | MNEMONIC xxx xxx (See Figure 3 | OP CODE<br>Ř (Ch. 1)<br>X (Ch. 2) | I-ADDRESS<br>iiiii<br>iiiii | d-character<br>x<br>x | | | | |--------------------------------|-----------------------------------|-----------------------------|-----------------------|--|--|--| | Timing: T = | = 4.5 (L + 1 · | <b>+ C</b> ). | | | | | | L = 7 | | | | | | | Address Registers after Operation: | | I-ADDRESS REG | A-ADDRESS REG | B-ADDRESS REG | |-----------|---------------|---------------|---------------| | Branch | NSIB | BI | NSIB | | No Branch | NSI | BI | BI | Function: Branch if I/O channel status indicator on instructions, a general name for the group of specific instructions listed in Figure 36, cause the program to branch to the specified I-address if the I/o channel status indicator or indicators that are tested by the specific instruction are on when tested. All use the Ř op code for channel 1 or the Ž op code for channel 2. The d-character is variable and its bit configuration determines which test or tests are made. Specific indicators and console panel lights within one set for each channel turn on if any input, output, or I/O device is unable to execute an I/O instruction, or if the device executes the instruction but data errors are detected. Some devices do not require the use of all six indicators in a set. To avoid stopping the system, one of these instructions must be given between two 1/0 instructions on the same channel. (1/0 instructions requiring this intervening instruction are those with op codes of M, L, U, F, Ž, K, or Ž.) During the reading out of the 1/0 instruction, an interlock indicator is turned on; if it is still on when the next 1/0 instruction is read out on the same channel, the system stops. This forces the program to check that each 1/0 instruction is executed as planned. Only two provisions will remove the interlock: 1. A branch if any I/o channel status indicator on instruction $\mathring{X}$ - or $\mathring{R}(I) \equiv is$ given before the next I/o unit instruction, or; | DESCRIPTION | MNEMONIC | INDICATOR | d-CHARACTER | OPERATION | |----------------------------------------------|------------|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Branch if I/O<br>unit Not Ready | BNR 1 or 2 | Not Ready | 1 | The indicator is internally set during instructions involving in-<br>put/output devices, if these devices or their associated buffers<br>are in a not ready condition, but before any data transfer takes | | B 144.45 | | | | place. If the indicator is set ON, the operation is terminated and no data are transferred. | | Branch if I/O | BCB 1 or 2 | B | • | | | unit Busy | BCB 1 or 2 | Busy | 2 | The indicator is internally set during instructions involving in-<br>put/output devices, if these devices or their associated buffers<br>are in a busy condition, but before any data transfer takes place.<br>If the indicator is set ON, the operation is terminated and no<br>data are transferred. | | Branch if I/O Unit | | | ĺ | data are transferrea. | | Data Check | BER 1 or 2 | Data Check | 4 | The indicator is set ON, after the transfer of data involving input/output devices, their associated buffers or the processing unit, if a parity error was detected during the data transfer. | | Branch if I/O Unit | | | | | | Condition | BEF 1 or 2 | Condition | 8 | The indicator is normally set during the move or load instruction, before any data transfer takes place. As an example, the indicator is set ON if an end of file (last card stacked) has occurred in the card reader. If the indicator is set ON, the operation is terminated and no data are transferred. | | Branch if I/O | 1 | Wrong Length | [ | | | Wrong Length Record | BWL 1 or 2 | Record | - (B-bit) | The indicator is set ON, if the record written from storage or written in storage is not the correct length. | | Branch if I/O Unit | | | | | | No Transfer | BNT 1 or 2 | No Transfer | 名 (A-bit) | No Transfer. The indicator is normally set before any data trans-<br>fer takes place. If it is set ON, it indicates that no data was<br>available to transfer. | | Branch if Any I/O | | | | | | Channel Status<br>Indicator On | BAlor 2 | All | ‡ | The group mark has all the bits needed to test all of the above six indicators. | | Branch if Any On in<br>Plural Indicator Test | BEX 1 or 2 | Not All | ## | Example has A8421 bits and tests all indicators except wrong | Note: These indicators are reset at the beginning of the next I/O operation Figure 36. Branch if I/O Channel Status Indicator On Instructions 2. A specific X- or Ř (I) d instruction (see Figure 36) is given and results in a branch before the next 1/0 unit instruction. Figure 36 is a chart of the 1/0 channel status indicators, the d-characters that test them, and a brief description of their operation. For more detailed information concerning these indicators, see "Input and Output Operations." If an $\mathring{R}$ (I) $\rightleftharpoons$ (BA8421 bits in the d-character) instruction is given following a channel 1 input-output operation, this instruction tests all channel 1 indicators and, if any of them are on, the program branches to the specified I-address. Then the program can test the indicators (individually or in groups, determined by the bit structure of the d-characters) to determine the exact condition present. This technique saves total program execution time because individual test instructions need be given only if processing conditions call for them. Note: If the processing overlap feature is installed, the program should ascertain (with a J (I) 1 or J (I) 2 instruction) that an overlapped I/O operation is complete before giving any R or X instruction. If an R or X instruction is encountered in the processing while the system is performing an overlap operation, the processing is suspended until the I/O data transfer is complete (remainder of the operation is converted to the non-overlap mode). The reason for this is explained under "Overlap Operational Considerations" (see index). Word Marks: No special considerations. #### **Branch if Character Equal** Instruction Form: MNEMONIC OF CODE I-ADDRESS B-ADDRESS d-CHARACTER BCE B iiiii bbbbb x $$Timing: T = 4.5 \; (L + 2.5 + C).$$ $$L = 1, 6 \text{ or } 12.$$ An instruction length of 6 chains the B-address and uses the last previous operation modifier. Address Registers after Operation: | | I-ADDRESS REG | A-ADDRESS REG | B-ADDRESS REG | |-----------|---------------|---------------|---------------| | Branch | NSIB | BI | NSIB | | No Branch | NSI | BI | B-1 | Function: This instruction causes the bit configuration (BA8421 bits) of the character at the B-address to be compared to the bit configuration of the d-character. If the comparison is equal, the program branches to the I-address for the next instruction. If the two characters are not exactly the same, the program continues with the next sequential instruction. This instruction also results in the setting of the high, low, or equal indicator. The high indicator is set if the B-address character is higher than the d-character (collating sequence). Word Marks: Word marks do not affect this operation. The nature of the instruction specifies that only one character is to be included in the test. #### **Branch if Bit Equal** Instruction Form: mnemonic of code 1-address B-address d-character BBE $\mathring{W}$ iiiii bbbbb x Timing: T = 4.5 (L + 2.5 + C). L = 1, 6 or 12. An instruction length of 6 chains the B-address and uses the last previous operation modifier. Address Registers after Operation: Function: This instruction causes the character at the B-address to be compared, bit by bit, with the d-character. If any bit in the character at the B-address matches any bit in the configuration of the d-character, the program branches to the I-address (wm and C bits not compared). For example, if position 05896 (B-address) contains a Z (A81 bits) and the d-character contains a 3 (C21 bits), the program branches. Word Marks: Word marks cannot be tested with this instruction and have no effect on the operation. ### Branch if Word Mark Present, or Zone Equal Instruction Form: Timing: T = 4.5 (L + 2.5 + C). L = 1, 6, or 12. An instruction length of 6 chains the B-address and uses the last previous operation modifier. Address Registers after Operation: I-ADDRESS REG A-ADDRESS REG B-ADDRESS REG Branch NSIB BI NSIB No branch NSI BI B-1 Function: This instruction examines the character located at the B-address for the zone or word-mark combinations specified by the d-character. A correct comparison branches the program to the specified I-address. A I bit in the d-character examines the B-address for a word mark. A 2 bit compares the zone bits of the B-address character against the zone bits in the d-character. A combination of the 1 bit and 2 bit allows either a word mark or a correct zone bit comparison to cause a branch to the specified I-address. The criterion for a correct zone-bit comparison is established by the zone bits present, or absent, in the actual d-character. Both actual and mnemonic d-characters, and the conditions they test, are shown in Figure 37. If the program does not branch to the I-address, it continues with the next sequential instruction. Word Marks: A word mark is not required at the B-address to stop transmission because this is always a one-character operation. | INSTRUCTION | ACTUAL OP CODE, ADDRESSES, AND ACTUAL d-CHARACTER | MNEMONIC OP CODE, ADDRESSES, AND MNEMONIC d-CHARACTER | TRANSLATION | |--------------------------------------------------------|---------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------| | Branch if Word<br>Mark Present | V<br>V(I)(B)1 | BW(I)(B) | Branch to 1-address if B-address has a WM-bit. | | Branch if Zone<br>Bits Absent | V<br>V(I)(B)2 | BZN(I)(B) | Branch to 1-address if B-address has no B nor<br>A bits. | | Branch if Zone<br>Equal AB | V(I)(B)B | BZN(I)(B)AB<br>or BZN(I)(B) + | Branch to I-address if B-address has both B and A bits (plus test). | | Branch if Zone<br>Equal B | V<br>V(1)(B)K | BZN(I)(B)B<br>or BZN(I)(B) — | Branch to I-address if B-address has a B bit but no A bit (minus test). | | Branch if Zone<br>Equal A | V(I)(B)S | BZN(I)(B)あ<br>or BZN(I)(B)も | Branch to 1-address if B-address has an A bit<br>but no B bit. | | Branch if Word<br>Mark Present, or<br>Zone Bits Absent | V(I)(B)3 | BWZ(I)(B) | Branch to 1-address if B-address has either a WM-bit or no B nor A bits. | | Branch if Word<br>Mark Present, or<br>Zone Equal AB | V(I)(B)C | BWZ(I)(B)AB<br>or BWZ(I)(B) + | Branch to I-address if B-address has either a WM-bit or both B and A bits. | | Branch if Word<br>Mark Present, or<br>Zone Equal B | V(I)(B)L | BWZ(I)(B)B<br>or BWZ(I)(B) — | Branch to I-address if B-address has either a WM bit or a B bit but no A bit. | | Branch if Word<br>Mark Present, or<br>Zone Equal A | V(I)(B)T | BWZ(I)(B)A<br>or BWZ(I)(B)5 | Branch to I-address if B-address has either a WM bit or an A bit but no B bit. | Figure 37. Branch if Word Mark Present, or Zone Equal Instructions # **Input and Output Operations** # IBM 1414 Input-Output Synchronizer The IBM 1414 Input-Output Synchronizer (Figure 38) contains the circuitry necessary to transmit data to and from the 1411 Processing Unit and the I/O units indicated in Figure 39. The 1414 is available in many models; the model used with a specific 1410 system depends on the kinds of I/O devices in the system. Model 1 controls up to ten івм 729 ії, їv, от v Magnetic Tape Units (in any combination) on a single channel (івм 7330 units can also be controlled if the Tape Intermix Feature is installed). Model 2 of the 1414 controls up to ten івм 7330 Magnetic Tape Units. Model 7 has the same control capabilities as Model 1 but can also control івм 729 vi tape units. Model 3 houses the 80-character card read and punch core buffers and a 100- or 132-character print core buffer, for intermediate storage between the 1402 and 1403 and the 1411 Processing Unit. (Buffering is described in the 1410 Systems Summary, Form A22-0524.) Model 8 is similar to Model 3 but lacks card read and card punch buffers and controls. Model 4, a two-module unit, includes the 1414 Model 3 features and has additional facilities for telecommunication features, including controls and core buffers for the IBM 1011 Paper Tape Reader, the IBM 1009 Data Transmission Unit, up to 20 IBM 1014 Remote Inquiry Units, and Telegraph Input-Output. Model 5 is similar to Model 4 but lacks card read, card punch, and print buffers and controls. Figure 38. IBM 1414 Input-Output Synchronizer Figure 39. Synchronizer Models and Their Uses The tape intermix feature, required to mix IBM 729's and 7330's, and any other features or adapters that are optional or required to complete an installation, are shown in the *IBM 1410 Configurator*, Form A22-6688. # Input-Output Instructions Input-output instructions are commands to specific I/O devices to act as input or output for the 1411 Processing Unit. The form and meaning of an I/O instruction are described under "Instructions" in the first part of this manual and on the *IBM 1410 Instruction Card*, Form X22-6740-1. I/O instructions may be made in the move or load mode; the only difference between move and load is in the processing of word marks and word separators. #### Move Mode #### Input Word separators in incoming data are stored unchanged as word separators in core storage. #### Output Word separators in core storage are written unchanged as word separators on output devices. No core storage word marks are transferred to the output medium. #### **Load Mode** #### Input A single word separator in incoming data is stored in core storage as a word mark over the next incoming character. Two *consecutive* word separators enter core storage as a single word separator. Thus, the input record length is shortened one position in either of these operations: storing one word mark, or storing one word separator. Note: Disk storage units can handle word marks directly in eight-bit mode. ### Output Core storage word marks are converted to word separators when transferred to output devices. The character with the word mark, as stored in the processing unit, is moved in the output medium to the position following the word separator. A word separator in core storage is converted to two word separators in the output. # Checking Execution of I/O Instructions Six status indicators on the console (Figure 52) automatically reveal, for a specific data channel, two conditions: (1) the inability of an I/O device to execute an I/O instruction, and (2) the detection of data errors during the execution of the I/O instruction. These indicators are common to all I/O devices on that channel. Some I/O devices, such as the 1403 Printer, do not require the use of all six indicators for a full status test. The significance of each status indicator varies with the kind of I/O device and is described in this and other manuals with the given unit. Certain status indicators are associated with the mechanical state of the I/O unit; the others are associated with data transfer. Status checking occurs twice during the completion of an I/O instruction. The first test determines whether the unit is capable of executing the instruction. If it is not, the system does not stop; it ignores the instruction and reads out the next sequential instruction. The second test follows the data transfer (for example, from the 1414 to core storage), and determines whether the unit has satisfactorily executed the instruction. The test is for a parity error, a wrong-length record, etc. If one of the status indicators checking data transfer is set, the effects vary with the I/O device. The program can only ascertain that the 1/0 instruction was executed by interrogating the status indicators. # Example: Checking Execution of a Card Read Instruction The meaning of the channel status indications can be understood best by examining a specific I/O operation — for example, a card-read operation — for the status testing sequence and the significance of each test. First, it is necessary to understand the way an image of the first card enters the buffer. This begins with manual operations at the card reader: the operator places cards in the feed hopper and presses the start key. No I/O instruction is needed yet. Three cards feed into the machine when the start key is pressed, and an image of the first card enters the buffer. The program can now be executed. When a cardread instruction is encountered, the results should be: (1) the image of the first card transfers from the buffer to core storage, (2) the first card is stacked, and (3) the image of the second card enters the buffer. Three simultaneous and automatic status tests are made before the instruction is executed: - 1. Is the reader ready? If it is not, turn on the not-ready indicator. Conditions causing this indicator to turn on are: a card jam, no cards, 1402 power off, cover open, stacker full, omission of the above manual operations, etc. - 2. Is the reader busy? If it is, turn on the busy indicator. The condition causing this indicator to turn on is: the reader is mechanically in motion (buffer is being filled). - 3. Is there a "condition"? If there is, turn on the condition indicator. The condition causing this indicator to turn on is: end of file, last card has been processed and stacked (provided the end-of-file key on the 1402 had been pressed). If any of the three indicators turn on, the 1/0 instruction is ignored and the system goes on to the next sequential instruction. If none of the three indicators turn on, the card image in the buffer is transferred unconditionally to core storage and three additional, simultaneous, automatic tests are made: - 1. Is there an error in the data transferred? If there is, turn on the data check indicator. Conditions causing this indicator to turn on are: a parity error, a timing error, a hole count check, or an invalid card code. - 2. Is the record of "wrong length"? If it is, turn on the wrong-length record indicator. The condition causing this indicator to turn on, for a card read, is: a group-mark word-mark is not correctly located in core storage. - 3. Were data transferred under normal or legal circumstances? If not, turn on the no transfer indicator. Conditions causing this indicator to turn on are: (1) a card image has already been transferred from buffer to core storage and the same card image is transferred to core storage again, or (2) two successive cards entered the buffer without a command to read the first into core storage (in this case, the data from the first card would be lost). Following the I/O operation, and before the next I/O instruction, the condition of all status indicators can be (and usually is) tested by the program to satisfy a system status-check requirement. The alternative to testing all six status indicators is to test at least one status indicator but, in this case, the status test is satisfied only if a branch results from the test. #### Role of the 1414 The words displayed on the console by an I/o channel status indicator light depend for meaning on the kind of I/o device addressed by the I/o instruction. The I/O devices operating through the IBM 1414 Input-Output Synchronizer are linked to their common channel status indicators by the 1414. If the program calls upon a 1414-attached 1/0 device that is mechanically incapable of executing the instruction, the 1414 is the unit that causes the appropriate 1/0 channel status indicator lamps to light. If no indicators turn on, the data are transferred. If the data transfer was unsatisfactory, the 1414 turns on the appropriate remaining 1/0 channel status indicators. #### Testing the I/O Channel Status Indicators Before the next I/O instruction, the on or off condition of the status indicators must be tested by an X- or R-type branch instruction, branch if I/O channel status indicator on. (See Note.) The d-character in the branch instruction selects the indicator or combination of indicators that are tested. An $\mathring{R}(I) \not\equiv \text{or } \mathring{X}(I) \not\equiv \text{resulting in a branch shows that at least one indicator is on, because the group mark contains all bits necessary to check all six status indicators. The I-address is usually the beginning of a subroutine that defines the error condition.$ Interrogation of the status indicators with an X- or R-type branch instruction does *not* reset the indicators; they are reset only as the next 1/0 instruction is read out (Figure 40). Note: If the system has the processing overlap feature, the overlap-in-process indicator should first be tested with a test and branch instruction; otherwise, an overlapped operation may become non-overlapped. #### Results of Omitting the Status Test During the reading out of an I/o instruction, an interlock indicator is turned on; if it is still on when the next I/o instruction is read out, the system will stop. This forces the program to check that each I/o instruction is executed as planned. Only two provisions will remove the interlock, and both are program instructions: (1) any of the X- or R-type branch instructions that tests one or more indicators, if it also results in a branch, or (2) an $\check{X}$ - or $\check{R}$ (I) $\rightleftharpoons$ instruction, with no requirement of an actual branch. #### **Summary in Actual Sequence** These steps occur automatically when the system encounters an I/O instruction in the program: 1. Recognize an 1/o instruction. Figure 40. Automatic Events When System Encounters an I/O Instruction - 2. Test the interlock indicator. If it is on, the system stops. - 3. Reset all six I/O status indicators associated with the instruction. - 4. Test the ability of the addressed I/O device to execute an I/O instruction. If it is not able, set the status indicator showing the reason. - 5. Turn on the interlock indicator, blocking further I/O instructions. - 6. If any status indicator is on, prevent the execu- tion of the 1/0 instruction (skip steps 7 and 8) and proceed to the next sequential instruction. - 7. Transfer data. - 8. Test for errors in the data transfer. If there are any, set the status indicator showing the kind of error (or programmed situation). - 9. Proceed to the next sequential instruction. This can never be an I/O instruction (see "Results of Omitting the Status Test"). Processing Unit Meter Recording <sup>\*</sup> The chart indicates that it is not mandatory for the meter switch to be on before starting the program. If a program halt precedes the program selection of the assignable unit, the meter switch may be turned on any time prior to or during the halt. Figure 40A. Meter (Enable) Switch Operation ### System Reaction and Recovery Techniques— Metered Machines An IBM data processing system consists of a CPU cluster, assignable units and I/O units. The customer usage meter on assignable units (control units, channels, and files) is controlled by an "Enable Switch." This switch is effective only during a CPU halt condition (see Figure 40A) and should be on when the program is started. If the enable (meter) switch is off, the assignable unit and any attached I/O units are disabled and a "Not Ready" Channel Status Indicator is set when the program selects a disabled unit. The following procedure may be used to recover from such a condition: ### System Reaction The assignable unit reacts as a "Not Ready" unit. Depending upon the program, the system can: - 1. Bypass I/O instruction and return later. - 2. Wait in loop for the I/O - 3. Halt and type out I/O unit identity and status. #### Recovery Technique Stop the system (if the program has not already done so). Turn the unit's meter switch On, and re-start the system. Note: "Re-start System" means that the same precautions should be followed that are taken in recovering from a similar reaction due to any other cause. Through the IBM 1415 Console (Figure 41), the operator of a 1410 system can enter information, display core storage contents, and read records from tape or disk storage units. The console consists of an I/O printer, a control section, an indicator-light panel, and includes desk space. # **Console I/O Printer** The I/O printer on the IBM 1415 Console can: - 1. Provide an operating log of all major manual console 1/0 printer operations (reset key operations are not logged but are indicated by a carrier return and vertical space). All alterations to internal data and their addresses are logged by the console printer. Before the alteration is made, the data must be displayed on the console printer. - 2. Provide display facilities for some registers and all storage locations. - 3. Provide an inquiry mode of operation under control of the console operator. - 4. Provide messages under program control. A programmed print-out can be overlapped with compute if the overlap feature is included. 5. Provide print-out of the instruction address register, A- and B-address registers, Op register, Opmodifier register, A- and B-channel contents, assembly channel contents, and the unit select and unit number register for both channels I and 2 on manual-stop, programmed-stop, and error-stop operations (Figure 42). The printing mechanism of the console-I/O printer is an IBM Selectric® typewriter; it can print 64 characters (10 numeric, 26 alphabetic, 28 special), a word-mark symbol, and an underscore symbol (invalid bit parity print-out). This printer has no type bars or movable carriage. Instead, it has a sphere-shaped type head containing all of the characters. The type head moves from left to right across the paper during a printing operation. Maximum rate of the console-I/O printer is 932 characters per minute. The paper forms have feed holes in the left and right margins. Vertically, the holes must be ½ inch apart; horizontally, the rows must be 9% inches apart. Because this typewriter is used as the console-I/O printing mechanism, the functions of vertical spacing (indexing or line spacing), backspacing, and type head carrier return are inoperative from the keyboard. Figure 41. IBM 1415 Console | OPERATION AND VERTICAL SPACES BEFORE PRINT-OUT | PRINTOUT IDENT. | S P A C E | I<br>A<br>R | S P A C E | A<br>A<br>R | SPACE | 1 | S P A C E | OPERATION CODE<br>OP MODIFIER | S P A C E | A CHANNEL CONTENTS B CHANNEL CONTENTS ASSEMBLY CHANNEL | S P A C E | UNIT SEL REG CH. #1 | UNIT SEL REG UNIT NUM REG | |----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------|--------------------------------------------------------------------------------------------------------------------------------|-----------|-------------|-------|-------|-----------|-------------------------------|-----------|--------------------------------------------------------|-----------|---------------------|---------------------------| | NORMAL STOP (Double Space) | s | | xxxxx | | xxxxx | | xxxxx | | xx | | xxx | | xx | xx | | HALF-CYCLE (Double Space) | С | | xxxxx | | xxxxx | | xxxxx | | xx | | xxx | | xx | xx | | ERROR STOP (Double Space) | E | | xxxxx | | xxxxx | | xxxxx | | ХХ | | xxx | | xx | xx | | ADDRESS SET (Single Space) | B<br>(Note) | | xxxxx | | | _ | | | | | | | | | | STORAGE SCAN SET (Single Space) | #<br>(Note) | | xxxxx | | | | | | | • | | • | | | | DISPLAY (Single Space) | D<br>D | | XXXXX<br>XXXXXXXX | ζ | ) | | | | | | | | | | | ALTER (Single Space) | Α | | XXXXXXXX Not IAR read-out; length of printing line determined by margins set, operator's line length, and write field length. | | | | | | | | | | | | | CONSOLE INQUIRY (Single Space) | ı | | xxxxxxx | κ | | | | | | | | | | | | CONSOLE REPLY (Single Space) | R | | * XXXXXXXX | ( | J | | | | | | | | | | | * Indicated Invalid Character (Underlined) Note: Print-out B if address entry switch is set on Normal; all other positions of the switch cause a print-out #. | | | | | | | | | | | | | | | Figure 42. IBM 1415 Printing Layout ### **Console Printer Control Keys and Levers** ### Inquiry Keys The IBM 1415 Console can be used as an inquiry station by using the console inquiry keys (Figure 43). The entry of inquiries and the print-out of their replies are under program control, and can occur while the system is operating in either the run mode or the I/E-cycle mode. The use of each key is discussed in the order of use during an inquiry request operation. # Request Key A console inquiry is initiated by pressing the inquiry-request key. A signal requesting permission to process a console inquiry is sent to the 1411 Processing Unit (turns on the inquiry status latch in the 1411). The inquiry request is discovered by the 1410 system when the program tests the inquiry status latch with one of the branch instructions (J iiiii Q). If the latch is set on, the program branches to a subroutine that contains the read console printer instruction M/L %T0 bbbbb R (Figure 44). Acknowledgment of the inquiry request by the 1410 system causes the character I to be printed, after which the console-I/O printer takes one space and then the keyboard unlocks. Manual entry of the inquiry request, character by character, can now proceed. The first inquiry character is placed in the storage address specified by the read console instruction B-address. Subsequent characters are placed in the next higher storage positions to the right. If a request is made but has not yet been recognized, pressing the cancel key resets the inquiry status latch. If an error is recognized while the message is being printed, pressing the cancel key sets the condition 1/0 channel-status indicator on, and the program continues. Figure 45 shows the conditions that set the 1/0 channel-status indicators and turn on their associated lights during a console printer read operation. Note: Where two characters are shown in a case (three on a key top), the actual characters printed depend on the type head in use (see Figure 2). Figure 43. Console-1/o Printer Keyboard | OP<br>CODE | X-CTRL<br>FIELD | DESCRIPTION | d-CHAR-<br>ACTER | MNE-<br>MONIC | TIMINGANDADDRESS REGISTERS AFTER OPERATION | OPERATION | |------------|-----------------|-----------------------------------------------|------------------|---------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------| | Ň | %то | Read Console Printer<br>(without word marks) | R | RCP | T = 49.5 + I/O | Operator keys the data transfer from console-I/O printer directly to storage. WM in storage are undisturbed. | | ĭ | %т0 | Read Console Printer<br>(with word marks) | R | RCPW | IAR AAR BAR NSI Ap B + LB + 1 | Operator keys the data transfer from console-I/O printer directly to storage. WM in storage are erased and entered. | | ň | %т0 | Write Console Printer<br>(without word marks) | w | WCP | T = 49.5 + 1/O | <ol> <li>Data are transferred directly from storage and printed.</li> <li>WM are not indicated.</li> <li>is not printed with message.</li> </ol> | | ř | %т0 | Write Console Printer<br>(with word marks) | w | WCPW | IAR AAR BAR<br>NSI Ap B + LB + 1 | <ol> <li>Data are transferred directly from storage and printed.</li> <li>WM are indicated.</li> <li>is not printed with message.</li> </ol> | Note: To avoid stopping the system, one of the branch if I/O channel status indicator on instructions (Figure 36) must be given between a console printer instruction and the next I/O instruction on channel 1. See "Results of Omitting the Status Test." Figures 45 and 46 show the I/O channel status indicators that may be set (turned on) during console printer read or write operations. Figure 44. Instructions for Console-1/o Printer *Error Condition:* Any system error stops the system and initiates an error print-out operation; the inquiry request operation is ended. | INDICATOR<br>TESTED | d-CHARACTER | CONDITION | |------------------------|-------------|---------------------------------------------------------| | Not Ready | 1 | Never set | | Busy | 2 | Never set | | Data Check | 4 | Processing unit detects input character validity error | | Condition | 8 | Cancel Key operated during in-<br>quiry | | Wrong Length<br>Record | — (B-bit) | Wrong length record | | No Transfer | to (A-bit) | No message request — Cancel Key operated before inquiry | Figure 45. I/O Channel Status Tests After Read Console Printer #### Release Key The inquiry is released to the processing unit by pressing the release key after the correct number of characters have entered storage. The programmer has already specified the length of the inquiry (a certain number of characters that occupy specific storage locations). The next higher storage location must contain a previously inserted group-mark — word-mark. As the last inquiry character is entered in its storage location, the addressing circuitry is set up to read out the group-mark — word-mark. The operator must press the release key at this time to obtain a correct-length record, and to ensure the processing of the inquiry. If it is desirable to request a second inquiry while entering a first inquiry, this can be accomplished by holding down the inquiry request key while pressing the inquiry release key to release the first inquiry. This causes the inquiry status latch to remain on. After a request is initiated, the inquiry status latch can be reset before any characters are entered, by pressing the release key. Operating the release key also initiates a carrierreturn and vertical-space operation, and locks the keyboard. Wrong-Length Record (Inquiry). Operating the release key, when the number of characters printed is less than the prescribed form on an inquiry request, causes: - 1. A carrier-return and vertical-space operation. - 2. The wrong-length record 1/0 channel status indicator to be set on. - 3. The program to go to the next instruction. When the number of characters entered is more than the prescribed form on an inquiry request, additional characters are not accepted by the processing unit. When the operator presses the release key or the cancel key, the wrong-length record I/O channel status indicator turns on but the program continues. #### Cancel Key Operating the cancel key ends the inquiry routine in process at that time. Operating the cancel key during the inquiry-request-message printing sets the condition I/O channel status indicator on, releases the system, causes a carrier-return and vertical-space operation, and allows the normal program to resume. If it is desirable to request a second inquiry while cancelling a first inquiry, this can be done by holding down the inquiry request key while pressing the cancel key to cancel the first inquiry. This causes the inquiry status latch to remain on. After a request is initiated, the inquiry status latch can be reset off, by pressing the cancel key, before any characters are entered. #### **Word Mark Key** Pressing this key prints a word mark; after the word mark is printed, the carrier is backspaced one position. Pressing a character key then prints the character under the word mark and enters both the word mark and the character into storage. The word mark key must be pressed first in order to enter a character with a word mark into storage. ### Shift Keys Pressing either one of the two shift keys shifts the console printer into upper case. Figure 43 illustrates the console I/O printer keyboard. The characters shown at the top of the keys are upper-case characters and require a shift key to be operated before the character key is pressed. The printer automatically returns to lower-case shift when the key is released. #### Lock Key Pressing this key activates the shift keys, and locks the console I/o printer in upper-case shift. (Release is accomplished by pressing one of the shift keys or by locking the keyboard through completing an input operation.) #### **Copy Control Lever** Operating the copy control lever (at the left rear of the console printer) positions the type-head carrier forward or backward so that various thicknesses of printing material are accommodated. The copy-control lever can be set in five different positions. Moving the lever forward decreases the distance between the platen and printing mechanism; moving the lever to the rear increases this distance. #### Paper Release Lever Pulling forward on the paper release lever (the outer lever at the right rear of the printer) releases the pressure of the front and rear feed rolls on the platen. This permits accurate paper positioning and easy paper removal. This lever should be forward when the pin-feed platen is used. It should only be pushed back when it is desired to move the paper vertically backward through the paper feed. # **Margin-Set Levers** The left and right margins are determined by the position of the margin stops. The left or right margin is set by operating the associated margin-set lever (at the top of the keyboard). The margin-set lever is operated by exerting pressure toward the rear of the console printer and sliding the lever to the right or left. ### Index Selector Lever When the index selector lever (the inner lever at the right rear of the console printer) is set toward the rear, the platen double-spaces each line of printing (three lines per inch). With the index selector lever set toward the front of the machine, the platen single-spaces each line of printing (six lines per inch). #### **Console Reply Routine** A reply routine or programmed print-out can occur at any time. The console write instruction $\mathring{M}/\mathring{L}~\%T0$ bbbbb W causes: - 1. The character R to print. - 2. A space. - 3. Data to be transferred from storage and printed by the console-I/o printer until a group-mark wordmark is sensed in storage. (A valid blank in storage causes the console printer to space.) - 4. A carrier return and vertical-space operation. - 5. The program to continue with the next instruction. Figure 46 shows the conditions that set the I/O channel-status indicators on and that turn on their associated lights during a console printer write operation. | INDICATOR<br>TESTED | d-CHARACTER | CONDITION | |------------------------|-------------|-----------------------------------------------------| | Not Ready | 1 | Never set | | Busy | 2 | Carriage returning | | Data Check | 4 | I/O Printer detects output character validity error | | Condition | 8 | Never set | | Wrong Length<br>Record | (B-bit) | Never set | | No Transfer | 15 (A-bit) | Never set | Figure 46. 1/0 Channel Status Tests After Write Console Printer CPU Processing Error: A CPU processing error during the data transfer ends the reply routine and causes an error print-out operation. Operation of the start key is necessary to complete the programmed print-out. I/O Printer Error: If a parity error is sensed in the console printer, the error character is printed and underlined. The data-check I/O channel status indicator is also set on. The reply routine continues until a group-mark — word-mark is sensed in storage. ### **Console Load Read and Write Operations** If the console 1/0 printer is addressed on a load-write operation (L Op code), blank characters in storage are printed as small b's, and each word mark is printed as an inverted circumflex over the character associated with the word mark. It is possible to enter word marks into storage during a console-inquiry routine if the instruction calls for a load-read operation. The word mark prints on the log sheet and enters storage. A console printer space operation generates a blank character in storage. #### **Control Section** The control section (Figures 47, 48, and 56) contains the power keys and lights and other keys and switches that control the 1410 system. #### **Computer Reset** Operating this key resets the check circuits, resets the program to 00001, resets all timing clocks, and resets all machine indicators (overflow latches, compare triggers, etc.). The inquiry latches (except the console inquiry latch) and the tape density latch are not reset. The computer reset key is intended to reset system status before starting a new operation. To merely suspend processing with the intention of resuming it where interrupted, use the stop key. The computer reset key should not be used to stop the program if the same processing is to continue, because: - 1. All system and 1/0 status indications are lost. - 2. If the system is in an I/O operation, some data may be lost. - 3. Some of the characters at the stopping address in core storage may be changed. #### Power Keys, Lights, and Switches The power keys, lights, and switches (Figure 47) control the application of power to the 1410. #### **Emergency Off** This pull switch should be used only in case of emergency, when all power must be shut off immediately to prevent injury to an individual or damage to the system. Pulling the switch removes all power from all units. If this switch is used, only a Customer Engineer should turn on the power again. #### Power On Operating this switch normally provides full operating power to the 1410 system, either from a power-off or Figure 47. Power Keys, Lights, and Switches operation is initiated when power is first applied or reapplied to the system, and causes all system registers, latches, rings, etc., to be reset. The first operation of the switch starts the internal sequencing of power to the system and turns on the illuminated portion of the power-on key. The key light remains on until either the emergency power-off switch or the power-off key is operated. When the system power is fully on, the ready light is turned on. #### Power Off Pressing the power-off key removes all power from the system, except on units with CE panel power local-remote switch set to LOCAL. Removal of system power also turns off the ready light and the illuminated portion of the power-on key. To restore full operating power to the system, the power-on key must be pressed. #### DC Off Pressing this key turns off the system dc power only, except in those units with ce panel power local-remote switch set to LOCAL. The key is used when the system will be idle for a short time. Operating the key turns off the ready light, but the light comes on again as soon as full power is restored to the system. The power-on light remains on. # **Ready Light** The ready light is turned on when full operating power is applied to the system. It takes a short time for the machine to reach ready status because the power is supplied to the system units or frames in a specified sequence. The ready light turns on immediately if the power-on key is pressed while the machine is in the dc-off mode. # Mode Switch The six modes of machine operation are selected by the mode switch. The six modes are modified by the CE controls. Usually, these CE controls are set to the normal or off operating mode. Any change in the mode switch setting causes a stop print-out operation, which begins as soon as the execution of the previous setting is complete. # **CE** (Customer Engineer) When the mode switch is set to CE, the customer engineering function of storage scan is available for use. ### I/E Cycle With the mode switch set to I/E CYCLE, the first operation of the start key causes the system to read one complete instruction from storage, then stop and print out. Because this print-out occurs while the machine is in the I/E cycle mode, the print-out is preceded by the printing of a C. The console-I/O printer then spaces and prints out the contents of the instruction address register, A- and B-address registers, Op-registers, Op-modifier register, A-data register, B-channel contents, assembly channel output, and the unit select and unit number registers for channel 1 and channel 2. The second operation of the start key causes the execution of that instruction (called the execution phase), and then system operation stops. Another C print-out operation occurs exactly as previously described. Subsequent operation of the start key results in the system going through alternate instruction and execution cycles. Exceptions are branch and I/O operations, which may not always follow the above description. #### Address Set This setting of the mode switch is used to start a program at a specific place in storage. Pressing the stop key or turning the mode switch to the ADDRESS SET position causes a normal stop print-out operation. The start key is then pressed, and a B-character is printed on the console-I/O printer. (See Note in Figure 42.) The printer then takes a single vertical space. The address that is then entered (by operating the console printer keys) enters the I-address register and is followed by an automatic carrier return and vertical-space operation. The mode switch may then be positioned at either the RUN setting or the I/E CYCLE setting. Pressing the start key starts the program with the instruction located at the entered address. This switch setting, when used with the address entry switch on the console CE panel, permits altering the contents of the A-, B-, C-, D-, E-, or F-register, depending on the setting of the switch. With this switch in the NORMAL position, the contents of the I-address register are altered. If any address register is altered, other than the I-address register, the address entry switch must be returned to the NORMAL position before pressing the start key. Pressing the start key starts the program at the unaltered address in the I-address register. ### Run When the mode switch is set to RUN, pressing the start key causes the system to run continuously under control of the stored program. A display operation must precede an alter operation. Resetting the mode switch to RUN or I/E CYCLE, and pressing the start key, lets the program proceed at the address in the I-address register. #### Display Any portion of storage may be displayed on the console-I/O printer log sheet by using the DISPLAY setting of the mode switch. The display may be of any length, from one field to a multiple line print-out. *Operation:* During a display operation, this sequence takes place: - 1. The system is stopped by operating the stop key or setting the mode switch to display. - 2. With the mode switch set to DISPLAY, operating the start key results in printing a character D, followed by a space and the unlocking of the keyboard. - 3. The high-order address of the field to be displayed is manually entered on the console-I/o printer by operating the appropriate keys. - 4. An automatic keyboard-lock, carrier-return, and vertical-space operation takes place following the printing of the fifth address character. - 5. A character D is automatically printed, followed by a space. - 6. The contents of storage, starting at the high-order position previously printed, are printed until a word mark is recognized. The word mark and its associated character are printed (first character of the adjacent field). The adjacent field can be displayed if the start key is pressed again. A continuous display results from holding the start key in its operated position. The display operation can be ended at any time by pressing the stop key. The display operation is momentarily held up if an end-of-printing-line signal is encountered. An automatic carrier return and vertical-space operation takes place, followed by a resumption of the display operation. No Wraparound on Display – 10K Core Storage Only: When the last character in storage is printed, the display operation ends and the carrier returns. Wraparound on Display – 20K, 40K, 60K, 80K Core Storage: When the last character in storage is printed and has no word mark, the display operation continues and the next character printed will come from storage location 00000. The display continues to the next word mark encountered. If the last character in storage is printed and has a word mark, the display operation ends, but may be resumed by pressing the start key again. Error Conditions: Characters with invalid parity in storage are underscored on the console-I/o print-out. Channel errors are ignored. The carrier returns when the stop key is pressed or the error is reset. #### Alter By using the ALTER setting of the mode switch, in combination with the console-I/O printer, it is possible to alter the information in any storage location. However, a display operation of the specific storage location must be completed before an alter operation can be performed. This display operation prerequisite ensures having a record of the storage location contents before the alteration takes place. After the display operation, the alter operation is started by rotating the mode switch from display to alter and pressing the start key. The character A is printed, signifying an alter operation, followed by a space and the unlocking of the keyboard. Unlocking the keyboard allows the manual-alter printing operation to proceed. If one or more fields (but less than a full line) were previously displayed, only the first displayed field can be altered. Only the first line from a multiple-line display can be altered. The correct characters are printed and replace the previously-displayed incorrect data. Correct data are kept by reprinting all the correct characters. Any previously displayed word mark must be re-entered into storage. Valid blanks are entered in storage by operating the space bar, or the blank-character key (b). The alter operation continues until a work mark is sensed if one or more fields (but less than one line) were displayed. An alter operation ends when the end-of-line condition is sensed if a multi-line display preceded the alter operation. Either one of these conditions locks the keyboard and initiates a carrier-return and vertical-space operation. If an error other than a data error occurs, the alter routine ends and the carrier returns. No Wraparound on Alter – 10K Core Storage Only: When a character is entered into the last location of storage, the alter operation stops. The carrier is not returned, and the operator is able to continue typing characters; however, these additional characters are not entered into storage. Wraparound on Alter – 20K, 40K, 60K, 80K Core Storage: When a character is entered into the last location of storage, the alter operation continues and the next location altered is 00000, unless: - 1. The last character in storage is printed at the end of a line, or - 2. The last character in storage contains a word mark and the previous operation ended at a word mark. Conditions 1 and 2 are normal; whenever either exists, the alter operation stops and the carrier returns. #### **Control Keys** Control keys (Figure 48) include start, stop, and program reset. # Start Key With the mode switch set to RUN the operation of the start key resets the parity check circuits and causes the system to begin executing instructions at the address Figure 48. Control Keys contained in the I-address register. Also, the start key initiates the operation when the mode switch is set to I/E CYCLE, DISPLAY, or ALTER. It is also active in some Customer Engineering operating modes. #### Stop Key Operation of the stop key, while the program is running, stops the program after execution of the current instruction. The character S is printed, followed by a space and then a print-out (Figure 42) of the contents of the following: IAR, (space), AAR, (space), BAR, (space), Op register, Op-modifier register, (space), A-channel, B-channel, assembly channel, (space), unit select register for channel 1, unit number register for channel 2, and unit number register for channel 2. #### **Program Reset Key** Operating this key resets the check circuits, resets the program to 00001, and resets the A- and B-data registers, Op register, Op-modifier register, and console inquiry latch. ### Indicator Light Panel ### **CPU Control Indicator Lights** See Figure 49. | | CENTRAL PROCESSING UNIT | | | | | | | | | |-------|-------------------------|--------|-------|-------------|-------|--------------|--|--|--| | I RII | ٧G | A RING | CLOCK | SCAN | CYCLE | ARITH | | | | | OP | | 1 | Α | N | Α | CARRY | | | | | 1 | 6 | 2 | В | 1 | В | IN | | | | | 2 | 7 | 3 | С | 2 | С | CARRY<br>OUT | | | | | 3 | 8 | 4 | D | 3 | D | А | | | | | 4 | 9 | 5 | E | | Ε | COMPL | | | | | 5 | 10 | 6 | F | SUB<br>SCAN | F | B<br>COMPL | | | | | | 11 | | G | U | | COMPL | | | | | | 12 | | н | В | 1 | | | | | | | | | J | Ε | × | | | | | | | | | К | MQ | | | | | | Figure 49. CPU Control Indicator Lights #### I Ring These lights show the 13 steps of the instruction ring (op and 1-12). ### A Ring These lights show the six steps of the A ring (1-6). #### Clock These lights show the ten steps of the main clock (A-K). #### Scan These lights show what type of address modification is taking place. The N light shows that a storage location is operating in a +0 modification cycle. The 1 Light shows that the CPU is operating in a -1 address-modification cycle. The 2 Light shows that the CPU is operating in a +1 address-modification cycle. The 3 Light shows that storage is being re-addressed and the CPU is operating in a -1 address modification cycle. #### Sub Scan These lights show what portion of a field is being addressed during arithmetic operations and certain other system executions. *U* (*Units*) shows that the units position of the field is being addressed. *B* (*Body*) shows that the body of the field (excluding units position of the field) is being addressed. *E* (*Extension*) shows that the extension portion of the field is being addressed. MQ (Multiplier-Quotient) shows that the multiplier or quotient is being addressed during a multiply or divide operation. It is also used to indicate special conditions during an edit operation. #### Cycle These lights show the eight types of cycles in which the CPU can operate (A, B, C, D, E, F, I, X). ### **Arithmetic Lights** Carry In shows that the carry latch has been set on. Carry Out shows that the adder has a carry output. $A\ Comple(A\ Complement)$ shows that channel A data are being complemented. *B Compl (B Complement)* shows that channel B data are being complemented. #### Status Lights See Figure 50. Figure 50. Status Indicator Lights #### B < A This light shows that the B-field is less than the A-field. A computer reset operation or a power-on reset operation turns the light on. The light remains on until the condition is reset by a program operation. #### B = A This light shows that the B-field is equal to the A-field. The light remains on until the condition is reset by a program operation, a computer reset operation, or a power-on reset operation. #### B > A This light shows that the B-field is greater than the A-field. The light remains on until the condition is reset by a program operation, a computer reset operation, or a power-on reset operation. #### Overflow This light shows that an arithmetic-overflow condition has been detected. The overflow condition can be detected only during an add or subtract operation, and not during a zero and add, zero and subtract, multiply or divide operation. The light remains on until the condition is reset off by a programmed test operation, a computer reset operation, or a power-on reset operation. ### **Divide Overflow** This light shows the occurrence of a divide-overflow condition. The light remains on until the condition is reset off by a programmed test operation, a computer reset operation, or a power-on reset operation. #### Zero Balance When on, this light shows the occurrence of a zerobalance condition. It is set by the result (which is zero) of any add, subtract, zero and add, zero and subtract, or multiply operation. The light remains on until the condition is reset by the computer reset, or poweron reset. It is also reset by the result (which is not zero) of any add, subtract, zero and add, zero and subtract or multiply operation. ### I/O Channel Control There are two sets of 1/0 channel control lights (Figure 51). One set shows channel 1; the other set shows channel 2, if channel 2 is present. The description applies to both channels, except that the Op code for channel 2 is $\check{X}$ instead of $\check{R}$ . | 1/O CHANNEL CONTROL | | | | | | |---------------------|------------------|--|--|--|--| | CH 1 | CH 2 | | | | | | INTERLOCK | INTERLOCK | | | | | | RBC<br>INTERLOCK | RBC<br>INTERLOCK | | | | | | READ | READ<br>· | | | | | | WRITE | WRITE | | | | | | OVERLAP<br>IN | OVERLAP<br>IN | | | | | | PROCESS | PROCESS | | | | | | NOT<br>OVERLAP | NOT<br>OVERLAP | | | | | | IN PROCESS | IN PROCESS | | | | | Figure 51. 1/0 Channel Control Indicator Lights ### Interlock This light shows that either an 1/0 read or write operation has been called for. The light is turned off when the status test is satisfied following a read or write operation. The status test is satisfied if either: - 1. A branch if any 1/0 channel status indicator on instruction $\mathring{R}$ (I) $\rightleftharpoons$ is given before encountering the next 1/0 unit instruction on the same channel, or; - 2. A specific Ř (I) d instruction (see Figure 36) is given, which results in a branch before encountering the next 1/0 unit instruction. If the status test is not satisfied before the next I/O instruction for that particular channel is called for, the system is interlocked and the interlock light remains on. #### RBC Interlock (Read Back Check Interlock) This light shows that the system has completed a successful write operation, but has not called for a readback check (write disk check) operation. A write operation must be followed by a write disk check when an IBM 1405 Disk Storage is installed but this is not required for the IBM 1301, 1302, or 1311 Disk Storage. ### Read This light shows that an I/O read operation is in process. #### Write This light shows that an I/O write operation is in process. #### **Overlap in Process** This light is turned on at the beginning of any I/O operation that is performed in the overlap mode. If the system stops because of an error during the I/O operation, the light remains on to indicate what type of I/O operation was in process when the error occurred. When no error occurs, the light turns off at the end of the data transfer. # Not Overlap in Process This light turns on at the beginning of any 1/0 operation that is not performed in the overlap mode. It is turned off at the end of the data transfer. The light signifies what type of 1/0 operation was in process when the system stopped because of an error. ### I/O Channel Status Indicator Lights The 1/0 channel status indicator lights (Figure 52) indicate the setting of their associated indicators. The indicators were set as a result of the last 1/0 operation on that particular 1/0 unit. Whenever the not ready, busy, data check, condition, wrong-length record, or no transfer 1/0 channel status indicator is set on, the corresponding indicator light is also turned on. One set of indicator lights is associated with channel 1; another set of identical lights is available for use with the channel 2 special feature. Figures 45 and 46 show the conditions that set the indicators on and turn on their associated lights during a console printer read or write operation. See also Figures 62, 63, 90, 91, and 99 for the specific conditions in other 1/0 units that will turn on these same indicator lights. | I/O CHANNEL STATUS | | | | | | | | |--------------------|-----------|--|--|--|--|--|--| | CH 1 | CH 2 | | | | | | | | NOT | NOT | | | | | | | | READY | READY | | | | | | | | BUSY | BUSY | | | | | | | | DATA | DATA | | | | | | | | CHECK | CHECK | | | | | | | | CONDITION | CONDITION | | | | | | | | WRONG | WRONG | | | | | | | | LENGTH | LENGTH | | | | | | | | RECORD | RECORD | | | | | | | | NO | NO | | | | | | | | TRANSFER | TRANSFER | | | | | | | Figure 52. 1/0 Channel Status Indicator Lights #### **Not Ready** The not-ready light shows that one of the input or output units on that channel is not capable of taking a cycle. Refer to the individual 1/0 unit write-up for specific conditions that turn on the not-ready light. #### Busy The busy light shows that one of the input or output units on that channel has not completed a previous operation. Refer to the individual I/O unit write-up for specific conditions that turn on the busy light. #### **Data Check** The data check light, when on, shows that one of the input or output units on that channel has detected a data parity condition. Refer to the individual I/O unit write-up for specific conditions that turn on the data check light. #### Condition The condition light shows that one of the input or output units on that channel has encountered an end-of-file condition or a data-transfer control error condition relating to that unit. Refer to the individual 1/0 unit write-up for specific conditions that turn on the condition light. # Wrong Length Record The wrong-length record light shows that one of the input or output units on that channel has encountered or sent a wrong-length record. Refer to the individual I/O unit write-up for specific conditions that turn on the wrong-length record light. #### No Transfer The no-transfer light shows that an operation of one of the input or output units on that channel has resulted in a no-transfer condition. Refer to the individual I/O unit write-up for specific conditions that turn on the no-transfer light. #### **System Check Indicator Lights** See Figure 53. # **Process Lights** A Channel shows that an A-channel parity error has been detected. B Channel shows that a B-channel error has been detected. Assembly Channel indicates an error at the assembly output or an error when merging zones, numeric information, and word marks during any operation. Address Channel shows that a validity error has been detected on the channel that supplies data to the address registers. | S | YSTEM CHEC | K | |---------------------|--------------------------|----------------------| | PRO | CESS | PROGRAM | | A<br>CHANNEL | A<br>REGISTER<br>SET | I/O<br>INTERLOCK | | B<br>CHANNEL | B<br>REGISTER<br>SET | ADDRESS<br>CHECK | | ASSEMBLY<br>CHANNEL | OP<br>REGISTER<br>SET | RBC<br>INTERLOCK | | ADDRESS<br>CHANNEL | OP<br>MODIFIER<br>SET | INSTRUCTION<br>CHECK | | ADDRESS<br>EXIT | A<br>CHARACTER<br>SELECT | | | | B<br>CHARACTER<br>SELECT | | Figure 53. System Check Indicator Lights Address Exit is only active during an indexing or store address register operation, and shows that a validity error has been detected at the address register exit channel. - A Register Set shows that the A-data register has failed to reset. - B Register Set shows that the B-data register has failed to reset. - Op Register Set shows that the Op register has failed to set. - Op Modifier Set shows that the Op-modifier register has failed to set. - A Character Select shows that no character is, or extra characters are, gated on the A-channel. - B Character Select shows that a malfunction in the storage-character selection and regeneration circuitries has been detected. ### **Program Lights** I/O Interlock shows that the program has failed to test the I/O channel status indicators before the next I/O instruction on that channel. Address Check shows that an incorrect storage address has been given by the program or that an operation goes beyond the limits of core storage (see "Addressing"). RBC Interlock (Read-Back Check Interlock) shows that the read-back check (write disk check) operation had not been completed before another operation of that disk storage channel was called for (a requirement for the IBM 1405 Disk Storage only). Instruction Check shows that an incorrect instruction has been given by the program. #### **Power Indicator Lights** See Figure 54. Figure 54. Power Indicator Lights #### I/O Off-Line This light shows that: - 1. The off-line switch on the 1414 Model 3, 4, 5, or 8 is on. - 2. Power is removed from the 1414 Model 3, 4, 5, or 8. #### **Thermal** When the internal temperature of the system exceeds the allowable limit or a blower circuit breaker trips, power turns off and the light turns on. ### CB Trip (Circuit-Breaker Trip) When one of the circuit breakers in the system trips, all dc power turns off and the light turns on. #### Tape Off-Line This light shows that: - 1. Either one or both tape transmission channels are operating off-line (ce use only). - 2. Power is shut down for either one or both tape transmission channels. - 3. The stop-on-error switch on the 1414 Model 1, 2, or 7 ce panel is on. ### Disk Off-Line This light shows that: - 1. The off-line switch on a disk storage CE panel is not in RUN position. - 2. Power is shut down for either one or both disk transmission channels. ### System Controls Indicator Lights See Figure 55. Figure 55. System Controls Indicator Lights #### 1401 Compatibility Light This light shows that the system is in the 1401 mode of operation (capable of running IBM 1401 programs). It is turned on when the compatibility switch is in the 1401 (ON) position. #### Off Normal Light This light shows that certain CE switches on the console are not in the correct position for normal operation. The light is on if: - 1. Print-out control switch is set to INHIBITED. - 2. Asterisk insert switch is set off. - 3. Cycle control switch is not set OFF. - 4. Check control switch is not set to STOP NORMAL. - 5. Storage scan switch is not set off and mode switch is at CE. - 6. Address entry switch is not set to NORMAL. ### Stop This light, when on, shows that the system has stopped and that operator intervention is required to start a new operation. #### **Priority Alert** This light, when on, shows that the system is operating in the priority alert mode and is ready for an interruption (priority feature must be installed). ### IBM 1415 Console CE Test Panel The IBM 1415 Console Customer Engineering test panel (Figure 56) is provided primarily for Customer Engineering use in diagnostic testing and performing preventive maintenance routines. However, certain functions of the panel can be used advantageously by customer personnel when checking new program routines. Only the switches and functions of use to the customer are described in this section of the manual. # **Console CE Controls Having Customer Uses** #### **Check Control Switch** The check control switch is a three-position rotary switch. When it is set to STOP NORMAL, any CPU error or input parity error, with the asterisk-insert switch set OFF, results in an immediate stop and an error print-out operation. For normal operation, this switch is set to the STOP NORMAL position, with the asterisk insert switch on. When the check control switch is set to RESTART, any of the previously mentioned errors also results in an immediate stop. Following the error print-out operation, the program is restarted automatically. If the error print-out is bypassed (print-out control switch), the program is restarted immediately following the stop. When the check control switch is set to RESET AND RESTART, any of the previously mentioned errors also results in an immediate stop in the same manner as for the RESTART setting. An error print-out operation is followed by a computer reset operation. When the computer reset operation is completed, the program is restarted. If the error print-out is bypassed (print-out control switch), computer reset and the program start follow the stop. ### **Print-Out Control Switch** This toggle switch controls all stop print-out operations, including error print-out. When this switch is set to NORMAL, the print-out takes place. (See Figure 42.) When the switch is set to INHIBITED, the print-out does not take place. #### Start Print-Out Switch This switch is used with the print-out control switch. Pressing this switch, with the print-out control switch on NORMAL, results in a stop print-out operation. Printing the contents of the various registers aids in determining the cause of failure. This switch can also be used to initiate occasional print-outs while single cycling. ### Asterisk Insert Switch This toggle switch, when set to on, converts any input unit character of incorrect parity to an asterisk, and enters it into storage in place of the invalid character. When the toggle switch is set to off, a wrong-parity character from any input unit stops the operation and initates an error print-out operation, unless inhibited by the print-out control switch. If the asterisk insert switch is off and the check control switch is set on stop normal, the data transfer stops. If the asterisk insert switch is off and the check control switch is set on restart (and the print-out control switch is set on inhibited), the full record can be entered into storage and used for diagnostic purposes or for the reconstruction of the incorrect record. ### **Cycle Control Switch** This is a rotary three-position switch used with any setting of the mode switch. When the cycle control switch is set to OFF, system operation is not controlled by this switch. When the cycle control switch is set to STORAGE CYCLE, pressing the start key advances the program by single storage cycles. A print-out operation, as describe in the "I/E CYCLE" mode switch setting, occurs at the end of each cycle, unless inhibited. Figure 56. Console CE Test Panel When the cycle control switch is set to LOGIC STEP, pressing the start key advances the program by single logic steps. #### Address Entry Switch This is a seven-position rotary switch (A, B, C, D, E, F, and NORMAL). This switch enables a console-printed address to enter the selected address register (A, B, C, D, E, F, or IAR if the switch is set to the NORMAL position). To activate this switch, the console mode switch must be positioned to the ADDRESS SET setting. For normal system operation, the switch must be set to NORMAL. # Disk Write Switch The disk-write switch, an optional feature, facilitates testing programs on an IBM 1410 system containing disk storage. It prevents writing test data on permanent records in disk storage. When this switch is set to off, normal disk storage operations can be performed. When the switch is set to inhibit, all disk storage instructions, except write disk and write disk with word marks, are performed normally. When these two instructions are encountered, data are transferred from core storage to disk storage and parity and record length are checked; however, no data are written on the surface of the disk. Automatic comparison of the record address in core storage and the address on the disk record is performed, however, and the unequal-address compare indicator turns on if an unequal condition occurs. When the disk write switch is on INHIBIT, a write operation results in an error condition because no data were written on the disk. # **Tape Density Switches** The tape density switches, one for each channel in use, are an optional feature for selecting the high or low recording density combinations desired for any 729 v or 729 vI tape units on the designated channel. # Storage Scan Switch (Clear Core Function) The REGEN +1 and REGEN 0 settings of the storage scan switch (Figure 56) are used by Customer Engineers for system testing. However, the LOAD +1 and LOAD 0 settings are of use to the operator; in particular, the LOAD +1 is needed to perform a core clear operation, as follows: - 1. Place the mode switch (Figure 47) at ce. - 2. Place the storage scan switch at LOAD +1 (see Note). - 3. All positions of core storage can easily be loaded with the same character by using the sense-bit switches (Figure 56). To clear all core storage, position the sense-bit switches to prepare for writing blanks (C bits). - 4. Press the start key. - 5. At the console-1/o printer, type any valid address. After the fifth character is typed, blanks will be loaded into every position of core storage starting with the address typed and increasing to the highest address, then wrapping around to the lower addresses. - 6. Press the stop key. Because of the speed of core storage, it is not necessary to pause between typing the fifth character and pressing the stop switch for all positions of core storage to be affected. Note: If the storage scan switch is set at load + 0, only the address typed in step 5 is cleared or otherwise affected. ### Sense-Bit Switches (Sense or Bit) The sense-bit switches, used as bit switches, select the character to be loaded into core storage during a cemode storage load operation, as described above under "Storage Scan Switch." The sense-bit switches are active as sense switches (A through G) only when operation is in the 1401 mode. As sense switches, they are tested by the program, and when on, they can cause a branch in the program. ### **Compatibility Controls** #### **Compatibility Switch** The compatibility switch (Figure 56), when at the 1401 setting, makes it possible to run IBM 1401 programs on the 1410. Ordinarily, the switch should be in the 1410 setting. ### I/O Check Stop Switch This switch is operative only when the 1410 is operating in 1401 mode. The 1/0 check stop switch, when set to on, stops programming at the completion of an 1/0 operation if the error occurs during that operation. Error conditions that can cause this are: hole count check in the card reader or card punch, validity error in the card reader, print check, or any one of a number of control errors. The program controls the system in the event of an I/O error when this switch is in the OFF position. # 1401 I/O Check-Reset Switch This switch is operative only when the 1410 is in 1401 mode and is used with the 1/0 check stop switch. Operating this momentary switch resets those error conditions than can be bypassed when the 1/0 check stop switch is set off. (The switch is primarily used by Customer Engineers for diagnostic testing.) The IBM 1402 Card Read Punch, Model 2 (Figures 57 and 58), is used with most, if not all, installations of the IBM 1410 Data Processing System. The card reader section of the 1402-2 enters data into the 1410 system through an 80-position read buffer, and the card punch section receives data from the system through an 80-position punch buffer. (The two buffers are located in an associated IBM 1414 Input-Output Synchronizer. See Figure 39, or, for further details, see IBM 1410 Configurator, Form A22-6688.) #### Reader The card reader has a feed rate of up to 800 cards per minute, as governed by the program. The card reader is equipped with a file feed that can be loaded with as many as 3,000 cards. Cards pass through the 1402-2 read feed face down, 9-edge first, from right to left, past two sets of reading brushes and a stacker-select station (Figure 59). The read-check brushes read the card to establish a hole-count check. The read brushes also read the entire card for a hole-count check (comparison of the same card as read by the read-check brushes and the read brushes), and direct the data into the read buffer for later transmission to storage. #### Punch The card punch has a feed rate of up to 250 cards per minute, as governed by the program. Cards pass through the 1402-2 punch feed face down, 12-edge first, from left to right, past a blank station, the punch station, the punch-check brushes, and a stacker-select station (Figure 59). The punch-check brushes read the entire card to establish a hole-count check (comparison of the same card as read by the punch-check brushes against the impulses received by the punch magnets). Figure 57. Card-Oriented івм 1410 System Figure 58. IBM 1402 Model 2 Card Read Punch #### **Stackers** The IBM 1402 Card Read Punch, Model 2, is equipped with five radial-type stackers (Figure 58), with a capacity of 1,000 cards each. Cards from each feed can be directed, under program control, to three of the five pockets. The cards in the card reader can be directed to the 0 (normal read) pocket, the 1 pocket, or the 8/2 pocket. The cards in the card punch can be directed to the 0 (normal punch) pocket, the 4 pocket, or the 8/2 pocket. Note: Cards, in either the punch or reader, which result in validity errors or a hole-count check are automatically stacked in the NP or NR pocket. ### **Card Read Punch Lights** Several lights on the IBM 1402 Card Read Punch, Model 2, refer to the entire 1402 rather than only to the reader or punch. These lights (Figure 60) are: Stacker shows that one or more pockets are full. Both the reader and the punch units stop. *Fuse* shows that a fuse has blown in the reader or punch unit. *Power* shows that power is being supplied to the 1402. Transport shows that a card jam has occurred in the stacker area. Card feeding is stopped in the rest of the 1402 until the jam is removed. # Reader Keys and Lights Card reader keys and lights (Figure 60) are: Reader Start: Operating this key feeds three cards into the read feed, fills the reader buffer with the contents of the first card, and turns on the reader-ready light. When the reader has been stopped, pressing the start key turns on the reader-ready light, and allows the cards to continue feeding under program control. When the cards are removed from the read feed hop- Figure 59. IBM 1402, Card Transport Schematic Figure 60. Keys and Lights on 1402-2 per and the end-of-file key is not operated, pressing the start key moves the remaining two or three cards, unprocessed, to the stacker area. Reader Stop: Operating this key stops the reader and turns off the reader-ready light. End-of-File: Operating this key activates circuits that signal a last-card condition in the central processing unit. The last-card condition can be used by the program to initiate an end-of-file routine. The end-of-file latch is turned on following the data transfer of the last card. The next card-read instruction is interpreted as a NO OP. The end-of-file key, which can be pressed at any time, causes the card reader to operate in one of these ways: - 1. With four or more cards in the read hopper, all cards are processed and run into a stacker. Operating the stop key or processing the last card causes the end-of-file condition to be reset. - 2. With three cards remaining in the feed, a card read or card-feed instruction before operation of the end-of-file key causes the program to set the not-ready I/O channel status indicator. Pressing the end-of-file key and then the start key allows the last three cards to be processed and run into a stacker. Operating the stop key or processing the last card causes the end-of-file condition to be reset. - 3. With the one, two, or three cards to be processed in the read hopper, pressing the end-of-file key and then the start key feeds the card or cards and turns on the reader-ready light after the first card passes the second read station. The card or cards are processed and run into a stacker. Operating the stop key or processing the last card causes the end-of-file condition to be reset. Reader Ready (light) shows that the reader is under program control. Validity (light) shows that an invalid character has been detected during a feed operation. The light remains on until the next feed instruction is started. During the read instruction, the invalid character is transferred from buffer to storage. Reader Stop (light) shows a feed failure or card jam during a feed operation. This error stops the reader and turns off the reader-ready light. Reader Check (light) shows the detection of a hole-count error, parity error, or buffer-timing error during a feed operation. The light remains on until the next feed instruction is started. During the read instruction, the data are transferred from buffer to storage, and the CPU sets the data check I/O channel status indicator on and the program can test it. ### **Punch Unit Keys and Lights** Card punch keys and lights (Figure 60) are: Punch Start: Operating this key feeds two cards into the punch feed and turns on the punch-ready light. When the punch has been stopped, pressing the start key turns on the punch-ready light, and allows card punching to resume under program control. When the cards have been removed from the punch feed hopper, pressing the start key moves the three cards remaining in the punch feed to the normal-punch pocket. The first card that enters the normal-punch pocket is unchecked. *Punch Stop:* Operating this key stops the punch and turns off the punch-ready light. *Punch Ready* (light) shows that the punch is under program control. *Punch Stop* (light) indicates a feed failure or card jam during a punch operation. This error stops the punch and turns off the punch-ready light. *Punch Check* (light) shows the detection of a holecount error, parity error, or buffer timing error during a punch operation. Chips: This light shows that the chip receptacle is full or not in place. ### **Operation Codes for 1402** See Figure 61. Note: To avoid stopping the system, one of the branch if 1/0 channel status indicator on instructions (Figure 36) must be given between any instruction for the 1402 and the next 1/0 instruction on the same channel. See "Results of Omitting the Status Test." Figures 62 and 63 show the 1/0 channel status indicators that may be set (turned on) during 1402 operations. | READER<br>OR<br>PUNCH | MNE-<br>MONIC | OP<br>CODE | X-CTRL<br>FIELD | DESCRIP-<br>TION | d-CHAR-<br>ACTER | OPERATION | NOTES | |-----------------------|--------------------------------------|------------|------------------------------------------------------|------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------| | | R or R1<br>(CH 1)<br>R2 (CH 2) | ň | %10 (Ch 1)<br>□10 (Ch 2)<br>%11 (Ch 1)<br>□11 (Ch 2) | Read a Card,<br>Stack in | | Initiate feed cycle. Transfer 80 characters<br>from read buffer to core storage. Read card<br>into read buffer. Stack card in pocket 0.<br>Same as above, except card is stacked in | word separators are<br>read into storage as | | READER | RW or R1W<br>(Ch 1) | ř | %12 (Ch 1)<br>□12 (Ch 2) | or 2 | R pocket 1. Same as above, except card is stacked pocket 2. | following character. | | | | R2W (CH 2) | | %19 (Ch 1)<br>□19 (Ch 2) | Read a Card,<br>No Stack or<br>Feed Opr. | | Transfer 80 characters from read buffer to core storage. THERE IS NO CARD FEED AND STACKER SELECT OPERATION. | | | | SSF or<br>SSF1 (Ch 1)<br>SSF2 (Ch 2) | | None | Select Stacker<br>0, 1, or 2<br>and Feed | 0<br>1<br>2 | Initiate feed cycle. Read card into read buffer. Stack card in the designated pocket. | Should be used only after a Read-a-Card instruction having a 9 in the units position of the x-control field. | | PUNCH | P or P1<br>(Ch 1)<br>P2 (Ch 2) | ň | %40 (Ch 1)<br>□40 (Ch 2)<br>%44 (Ch 1) | Punch a Card,<br>Stack in | w | Transfer 80 characters from core storage to punch buffer. Punch a card. Stack card in pocket 0. | If L op code is used,<br>word marks are trans-<br>lated to word sep- | | (Ch 1 | PW or P1W<br>(Ch 1)<br>P2W (Ch 2) | ĭ | ' ' | Pocket 0, 4,<br>or 8 | | Same as above, except card is stacked in pocket 4. Same as above, except card is stacked in pocket 8. | arators and each is<br>punched ahead of its<br>associated character. | Figure 61. Instructions for 1402-2 Card Read Punch # Read a Card Instruction Form: | | OP | X-CONTRO | )L | | |------------------|------|-------------------|-----------|-------------| | MNEMONIC | CODE | FIELD | B-ADDRESS | d-character | | R or R1 (Ch 1) | М | $\% 1x^{3}$ | bbbbb | R | | R2 (Ch 2) | М | $\Box 1x^{8}$ | bbbbb | R | | RW or R1W (Ch 1) | Ļ | % 1x <sup>8</sup> | bbbbb | R | | R2W (Ch 2) | Ľ | $\Box 1x^{3}$ | bbbbb | ${f R}$ | Timing: T = 49.5 + I/O. (See "Timing Considerations for 1402.") Address Registers after Operation: Function: This instruction causes the transfer of 80 characters from the card-read buffer to core storage. The hundreds position of the x-control field identifies the channel (% is channel 1), and the 1 in $x^2$ position specifies the card reader (Figure 107). If the units $(x^3)$ position of the x-control field is 0, 1, or 2, the card associated with the data just transferred to core storage is directed to pocket 0 (NR), 1, or 2 (8/2). Another card is fed, refilling the card-read buffer, and that card is positioned at the select station. Operation differs if the $x^3$ position contains a 9. The contents of the card-read buffer are transferred to core storage as described, but no stacker selection is made and the next card is not fed; thus the buffer still contains the image transferred to core storage. The B-address specifies the leftmost (starting) position of the data record in core storage, and characters are transferred to core storage serially from left to right. The operation is stopped by the first group-mark — word-mark sensed in core storage. Word Marks: A group-mark—word-mark must appear in the core-storage position to the immediate right of the data record. If the L Op code is used, word separators are read into storage as word marks. The character in the following card column is also stored in the core storage position that contains the word mark. This combination of word marks and their associated characters reduces the record length. The programmer must determine in advance and set the correct field length for each card to be processed. If the $\stackrel{\checkmark}{=}$ is incorrectly positioned, the wrong-length record channel status indicator will turn on. #### Select Stacker and Feed Instruction Form: | MNEMONIC | OP CODE | d-character | |-------------|---------------------------------------------------------------------------------------------------|-------------| | SSF or SSF1 | $ \overset{\mathbf{K}}{4} (\operatorname{Ch} 1) \\ \overset{\mathbf{d}}{4} (\operatorname{Ch} 2)$ | 0, 1, or 2 | | SSF2 | 4 (Ch 2) | 0, 1, or 2 | Timing: T = 13.5 + I/O. (See "Timing Considerations for 1402") Address Registers after Operation: I-ADDRESS REG A-ADI NSI A-ADDRESS REG Ap B-ADDRESS REG Function: This instruction is used after a read a card instruction that had a 9 in the $x^3$ position. It causes the card that was read to be sent to pocket 0 (NR), 1, or 2 (8/2), depending on the d-character of 0, 1, or 2. Another card is fed, refilling the card-read buffer, and that card is positioned at the select station. Word Marks: Word marks are not affected. #### **Punch a Card** Instruction Form: | | OP | X-CONTRO | | | |------------------|------|------------------------------|------------------|--------------| | MNEMONIC | CODE | FIELD | <b>B-ADDRESS</b> | d-character | | P or P1 (Ch 1) | Ň | $\% 4x^{8}$ | bbbbb | $\mathbf{W}$ | | P2 (Ch 2) | Ň | □4x <sup>8</sup> | bbbbb | W | | PW or P1W (Ch 1) | Ľ | $\sqrt[n]{4}$ x <sup>3</sup> | bbbbb | W | | P2W (Ch 2) | Ľ | □4x <sup>8</sup> | bbbbb | W | | INDICATOR<br>TESTED | d-CHARACTER | CONDITION | | |------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Not Ready | 1 | Card jam Reader out of cards (not EOF) Reader not on line Reader power off Reader stacker full Cover interlock open Feed clutch failure (clutch chk) Joggle switch open (file feed door) Input/Output Synchronizer off line Input/Output Synchronizer power o | | | Busy | 2 | Read buffer being filled<br>Card being stacked | | | Data Check | 4 | Hole count check Input/Output Synchronizer detects parity error Input/Output Synchronizer detects timing error Processing Unit detects parity error Never set on Select Stacker and Feed Instruction | | | Condition | 8 | EOF (last card has been stacked) (EOF latch turned off as this indi-<br>cator turned on) | | | | | Never set on Select Stacker and<br>Feed Instruction | | | Wrong Length<br>Record | — (B-bit) | Wrong length record<br>Never set on Select Stacker and<br>Feed Instruction | | | No Transfer | 名 (A-bit) | Card has been transferred previously. This indicator will be set ON if two Select Stacker and Feed Instructions are given without an intervening Read a Card Instruction with a 9 in the units position (x³) of the X-control field. It will also be set ON if two Read a Card Instructions with a 9 in the units position of the X-control field are given without an intervening Select Stacker and Feed Instruction. | | Figure 62. 1/0 Channel Status Tests After Read a Card (Also After Select Stacker and Feed) Timing: T = 49.5 + I/O. (See "Timing Considerations for 1402") Address Registers after Operation: I-ADDRESS REG NSI A-ADDRESS REG Ap B-ADDRESS REG B + LB + 1 Function: This instruction causes the transfer of 80 characters in core storage to the punch buffer. The hundreds position of the x-control field identifies the channel (% is channel 1), and the 4 in the $x^2$ position specifies the card punch (Figure 107). The units ( $x^3$ ) position of the x-control field must contain 0, 4, or 8, thus sending the card to the 0 (NP), 4, or 8 (8/2) pocket. The B-address specifies the leftmost (starting) position of the data record in core storage, and characters are transferred to the card-punch buffer serially from left to right. The operation is stopped by the first groupmark — word-mark sensed in core storage. At the end of the data transfer, the punch is started and punches a card with the data just transferred. Word Marks: A group-mark — word-mark must appear in the core storage position to the immediate right of the data record. If the L Op code is used, word marks are translated to word separators for punching. Use of the load mode causes the word separator to be punched ahead of its associated character and increases the resultant field length. The programmer must determine in advance and set the correct field length for each card to be processed. If the $\stackrel{\checkmark}{=}$ is incorrectly positioned, the wrong-length record 1/0 channel status indicator will turn on. | INDICATOR<br>TESTED | d-CHARACTER | CONDITION | | |------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|--| | Not Ready | 1 | Card jam Punch out of cards Punch stacker full Punch power off Punch not on line Chip basket full or not in place Cover interlock open | | | Busy | 2 | Previous card still being punched | | | Data Check | 4 | Input/Output Synchronizer detects parity error (card not punched) | | | Condition | 8 | Parity error detected during punch-<br>ing or hole-count check. Error<br>card goes to 0 pocket. | | | Wrong Length<br>Record | — (B-bit) | Wrong length record (this card not punched) | | | No Transfer | も (A-bit) | Never set | | Figure 63. 1/o Channel Status Tests After Punch a Card Figure 64. Interchangeable 51-Column Read Feed # **Timing Considerations for 1402** The I/O units are "busy" transferring data to or from their input-output buffers for these times: 1. Read a card instruction, when the units position of the x-control field is 0, 1, or 2. I/O = 0-75,000 $\mu$ s (access time) + 880 $\mu$ s (time needed by buffer to accept 80 positions of data at 11 microseconds per position) + 65,000 $\mu$ s (read cycle). 2. Read a card instruction, when the units position of the x-control field is 9. I/O = 880 $\mu$ s (time needed by buffer to accept 80 positions of data at 11 microseconds per position). 3. Select stacker and feed instruction. $I/O = 0.75,000 \,\mu s$ (access time) + 65,000 $\mu s$ (read cycle). 4. Punch a card instruction. $I/O = 0-60,000 \,\mu s$ (access time) + 880 $\mu s$ (time needed by buffer to accept 80 positions of data at 11 microseconds per position) + 217,000 $\mu s$ (punch cycle). # Special Feature — Interchangeable 51-Column Read Feed The interchangeable 51-column read feed (including file feed) permits feeding either 51-column cards or standard 80-column cards in the read feed of the IBM 1402 Card Read Punch, Model 2. Modifying the read file feed and stackers readily adapts the IBM 1402-2 for processing 51-column cards. The 51-column card is used for charge sales slips, postal money-order forms, installment payments, inventory cards, and many other applications. Using an interchangeable feed allows direct entry to the data processing system from the stub card. This eliminates the need for reproducing 51-column cards on standard 80-column cards. To adapt the read feed for 51-column-card operation, the operator installs a tray and hopper side plates on the read file feed, and adjusts the stackers on the read side. Normal operations of the IBM 1402 Card Read Punch, Model 2, can be performed with 51-column cards in the read feed. For example, a file of 51-column cards can be processed in the read feed while the results are punched in 80-column cards in the punch feed. However, when the stackers are adjusted to accept 51-column cards, no cards from the read feed can be selected into stacker 8/2. #### Modifying the File Feed An adapter tray (Figure 64), placed on the file-feed magazine, accommodates the 51-column cards. A mod- Figure 65. 51-Column Adjustable Stackers ified card weight enables feeding the last cards from the hopper. Inserting two hopper side plates (Figure 64) positions the 51-column cards at the center of the feed. Thumbscrews fasten the side plates to the hopper. Jogglers align the cards in the hoppers, as in standard operation. In 51-column-card operation, the first column of the card corresponds to column 15 of an 80-column card, and is therefore read by brush 15; the last column corresponds to column 65 and is read by brush 65. A factor of 14 relates the card column to the reading brush. A switch for regulating the storing of information from a 51-column card is physically located in the 1402-2. It is automatically turned on when the stacker guide is pulled forward for stacking of 51-column cards. When the switch is on, the information from a 51 column card is read into positions 15 through 65 of the read buffer. Positions 1-14 and 66-80 of the read buffer are filled with valid blanks. To check for proper transfer of the data from the read buffer to core storage, a group-mark — word-mark must be inserted in the 52nd position of the core storage read-in area. The 51 active positions, but not the blanks, are transferred from the read buffer to core storage. ### **Adjusting the Stackers** The operator adjusts the stacker guide (Figures 65 and 66) at the rear of stackers NR and 1 to accommodate 51-column cards. A finger hole permits pulling the guide forward to reduce the depth of the stacker. A spring latch holds the guide securely in either the 51-or 80-column-card position. A pivot-plate assembly (Figures 65 and 66) adapts the front of stackers NR and 1 for stacking either 51- or 80-column cards. The 51-column pivot plate with card retaining levers swings down and fastens to the stacker separators. This assembly provides a lower pivot for properly stacking the 51-column cards. For standard 80-column operation, the operator pulls each auxiliary pivot-plate assembly forward and then places it under the cover. Modified card-deck supports (Figures 65 and 66) for stackers NR and 1 permit stacking 51-column cards, standard cards, and the scored cards processed by the machine. The capacity of each of these stackers is 800 cards. #### **Setup Operation** To set up the IBM 1402 Card Read Punch, Model 2, to feed 51-column cards in the read feed: - 1. Position the side plates in the hopper, and fasten firmly by turning the knurled thumbscrews. Be careful not to interfere with the card lifters. - 2. Place the 51-column-card tray over the file-feed magazine. - 3. Reach into stackers NR and 1 and, using the finger hole, pull the guide forward until it latches. - 4. Raise the cover over the auxiliary pivot-plate assemblies, lower one assembly partially, and then slide the main pivot-plate to the rear until it latches. - 5. Swing the auxiliary pivot-plate assembly down until it latches to the stacker separators. (Repeat steps 4 and 5 for the other pivot-plate assembly.) Reverse this procedure to return to standard card feeding. NOTE: Handle and store the adapter tray and hopper side plates carefully to avoid damaging them. Figure 66. 51-Column Stacker Schematic The IBM 1403 Printer (Figure 67) is an output device considered basic, though it is not required, for the IBM 1410 Data Processing System. The printer is available in three models, with the following differences in operating characteristics: | Length of Printing Line | MODEL 1<br>100<br>positions | MODEL 2<br>132<br>positions | MODEL 3<br>132<br>positions | |--------------------------------------------------------------------------|-----------------------------|-----------------------------|-----------------------------| | Maximum Alphameric Lines<br>Printed Per Minute | 600 | 600 | 1,100 | | Maximum Numeric-Only Lines Printed Per Minute With Numeric Print Feature | 1,285 | 1,285 | | Note: Information on the numeric print feature, available for Models 1 and 2 only, is given under "Special Features" at the end of this section. Model 1 has a print-line length of 100 positions; Model 2 is created by the addition of a special-feature 32 positions. Model 3 has 132 positions as a standard feature. In all models, ten characters are printed per inch. Each position can be printed with one of 48 different characters: the 26 alphabetic, the 10 numeric, and 12 special characters (Figure 2). The printer receives print data from the system through a 100- or 132-position print buffer. The buffer is technically called a synchronizer storage feature and is located in an associated IBM 1414 Input-Output Synchronizer. (See Figure 39, or for further details the *IBM 1410 Configurator*, Form A22-6688.) #### **Method of Printing** For Models 1 and 2, all characters are serially assembled in a closed chain that revolves horizontally (Figure 68). A magnet-driven hammer taps the paper form against the chain as the moving type characters correspond in position with the characters to be printed. (Operation is similar for Model 3's type train, which, however, has no connecting band between characters and moves at a velocity of more than double that of the chain. Timing and minor operating differences of the Model 3 are described in *IBM 1403 Printer, Model 3, with IBM 1410 and 7010 Systems*, Form A22-0535.) As each character is printed, it is checked against the corresponding position in the print buffer to ensure that printed output is accurate. The machine also checks to ensure that the character is printed in the Figure 67. IBM 1403 Printer Figure 68. Printer Mechanism, Schematic correct print position, that only valid characters are printed, and that over-printing does not occur. # **Printer Keys and Lights** These keys and lights are shown in Figures 69 and 70. *Print Start (Front and Back):* Operating this key turns on the ready light. Figure 69. IBM 1403 Printer, Operating Keys and Lights Print Stop (Front and Back): Operating the stop key turns off the ready light. If the program attempts to execute a print instruction, the program automatically sets on the not-ready I/O channel status indicator in the 1411 and turns on its associated light in the 1415. Check Reset (key) resets a printer error indication. The print-start key is then pressed to resume operation. *Print Ready* (light) shows that the printer is ready to print. *End-of-Forms* (light) indicates an end-of-forms condition and the machine stops. Forms Check (light) shows there is paper-feed trouble in the forms tractor or that the carriage stop has been used. This light must be turned off by the check reset key before the print-start key is effective. *Print Check* (light) indicates a print error. Sync Check (Synchronism Check) (light) comes on to show that the chain was not in synchronism at all times with the compare counter for the printer. The timing is automatically corrected. The light is turned out by pressing the printer start key. Figure 70. Printer Keys (Rear) ### **IBM 1403 Carriage Controls** The carriage controls are shown in Figure 69. Carriage Restore: Pressing this key positions the carriage at channel 1 (home position). If the carriage feed clutch is disengaged, the form does not move. If it is engaged, the form moves in synchronization with the control tape. Carriage Stop: Pressing this key causes skipping to stop immediately, and turns on the forms-check light, placing the printer in the not-ready status. Pressing the check-reset key restores the ready condition. Carriage Space: Each time it is pressed, this key causes carriage tape and the form to advance one space. Single Cycle: This key causes the printer to operate for one print cycle on each pressing of the key when the end-of-form light is on and no paper jam exists. This allows printing of the last line of a form. # IBM 1403 Manual Controls The manual controls are shown in Figure 71. Feed Clutch controls the carriage-tape drive and form-feeding mechanism. If it is set to neutral, automatic form-feeding cannot take place. It is also used to select six- or eight-lines-to-the-inch spacing. *Paper-Advance Knob* positions the form vertically. It can be used only when the feed clutch is disengaged. Vertical-Print Adjustment makes possible fine spacing adjustments of forms at the print line. Carriage tape is not affected by this knob. Lateral-Print Vernier provides fine horizontal positioning. Figure 71. Carriage Controls Print-Density Control Lever: As many as six forms can be printed at one time, and the print hammer unit is designed to adjust automatically for different thicknesses of forms. However, to provide a vernier control for print impression, a print-density control lever is used. When this lever is set at position E, print impression is lightest. When set at position A, print impression is darkest. Between these two settings are intermediate settings. Position C is considered the normal setting. This lever moves the type chain closer to or farther from the hammer unit. The setting of this lever must be considered, together with the forms thickness, to determine the normal setting of the print-timing dial (Figure 72). A chart is provided to determine the normal setting (Figure 73). Figure 72. Print-Timing Dial and Print Unit Release Lever Print-Timing Dial: A movable dial set to a fixed indicator. Numbers around the dial provide a means of setting the print timing for a specific operation. The setting of the print-density control lever must be set before the print timing dial is set. The nominal setting is read from a chart. The chart (Figure 73) should give the correct setting of the print timing dial. However, this setting can be checked (by rotating the dial slowly in each direction from the normal setting) to determine the limits of good print quality. *Print-Unit Release Lever* permits access to the form transport area (see Figure 72). Print-Line Indicator and Ribbon Shield: The lower ribbon shield is also used as a print-line indicator. It pivots along with the ribbon mechanism. The front side of this shield is marked to show print position Figure 73. Print-Timing Dial Chart Figure 74. Print-Line Indicator and Ribbon Shield location (Figure 74). When used as a print-line indicator, the shield indicates where the lower edge of characters will print. When the printer frame is open, the indicator pivots against the forms so that the print line may be set with respect to the forms. Horizontal Adjustment: (Figure 71) positions the printing mechanism horizontally. When the lever is raised, the print mechanism unlocks and can be positioned horizontally within its 2.4-inch travel. R. H. Tractor Vernier (Figure 71) allows for fine adjustments in paper tension. It can be used for adjustments of up to one-half inch. Tractor Slide Bar: Two tractor slide bars, upper and lower (Figure 74), serve as mountings for the forms tractors. The forms tractors are movable, and notches in the tractor slide bar facilitate this movement. A procedure for proper adjustment of these notches, according to the form being used, is given for the upper tractor slide bar. The description would be the same for the lower slide bar. The left tractor is locked in place by a spring-loaded latch in one of the nine notches located one inch apart on the tractor slide bar. The third notch from the left end is the normal location for most applications. The first notch is used for forms from 5½ to 18¾ inches wide. When this notch is used, the print unit's lateral movement is limited to .4 inch. The second notch is used for forms from 4½ to 17¾ inches in width. When this notch is used, the print unit's lateral movement is limited to 1.4 inch. The third notch is used for forms from 3½ to 16¾ inches wide. When this notch or notches 4 through 9 are used, full lateral print unit movement (2.4 inches) is possible. The ninth (last) notch can be used for forms from $3\frac{1}{2}$ to $10\frac{3}{4}$ inches wide. When this notch is used, the first usable print position is 38. The right-hand tractor is locked in place by springloaded pins snapped into any one of 27 holes, located one-half inch apart on the tractor slide bar. The movement of the tractor slide bar, in which the holes are located, is controlled by the right-hand tractor vernier. Movement of up to ½ inch can be made by using the vernier knob. ### **Indicator Panel Lights** Gate Interlock turns on when the print unit is not locked in position (Figure 75). Figure 75. Printer Indicator Panel *Brush Interlock* is on if the carriage tape brushes are not latched in position for operation. Shift Interlock turns on to show that the manual feed clutch is not properly positioned. Thermal Interlock shows that a temperature above the operating limit has been sensed in the hammer unit or chain-drive unit; the light remains on until the temperature drops to an acceptable level. The 1403 is interlocked during this time. *High-Speed Start* turns on when a high-speed skip has been initiated. Low-Speed Start turns on when a low-speed skip or line spacing has been initiated. *High-Speed Stop* turns on to show that high-speed skipping is to be stopped. Low-Speed Stop turns on to show that a low-speed skip stop has been initiated. It is on when the carriage is not in motion. # **Tape-Controlled Carriage** The tape-controlled carriage (Figure 76) controls high-speed feeding and spacing of continuous forms. The carriage is controlled by punched holes in a paper tape that corresponds in length to the length of one or more forms. Holes punched in the tape stop the form when it reaches any predetermined position. Carriage skip channels 1-12 are standard. The tape circuits initiate special signals that are sent to the CPU when channels 9-12 are sensed. Program testing of carriage channels 9 and 12 is standard. Figure 76. Tape-Controlled Carriage Vertical spacing and skipping are initiated by the program. Horizontal spacing is 10 characters to the inch. Vertical spacing of either six or eight lines to the inch can be manually selected by the operator. Forms skip at the rate of 33 inches per second. With the dual-speed carriage, distances of eight lines or less are skipped at 33 inches per second, and those of more than eight lines at 75 inches per second. The last eight spaces skipped in a high-speed skip are skipped at 33 inches per second. The carriage accomodates continuous forms, to a maximum of 22 inches in length (at 6 lines per inch) or 16½ inches (at 8 lines per inch). The minimum length is 1 inch. For efficient stacking of forms, the recommended maximum forms length is 17 inches. The width of the form can vary from a recommended minimum of 3½ inches to a maximum of 18¾ inches, including punched margins. Forms can be designed to permit printing in practically any desired arrangement. Skipping to different sections of the form can be controlled by the program and by holes punched in the carriage tape. ### **Control Tape** The control tape (see Figure 76) has 12 columnar positions indicated by vertical lines. These positions are called channels. Holes can be punched in each channel throughout the length of the tape. A maximum of 132 lines can be used to control a form, although for convenience, the tape blanks are slightly longer. Horizontal lines are spaced six to the inch for the entire length of the tape. Round holes in the center of the tape are pre-punched for the pin-feed drive that advances the tape in synchronism with the movement of a printed form through the carriage. The effect is exactly the same as though the control holes were punched along the edge of each form. #### **Punching the Tape** Note: The total length of the carriage tape must not exceed 22 inches. (If the tape exceeds 22 inches, the printer may be damaged as the top cover is closed.) A small, compact punch (Figure 77) is provided for punching the tape. The tape is first marked in the channels in which the holes are to be punched. This can be done easily by laying the tape beside the left edge of the form it is to control, with the top line (immediately under the *glue* portion) even with the top edge of the form. A mark is then made in the first channel, on the line that corresponds to the first printing line of the form. Additional marks are made in the appropriate channels for each of the other skip stops, and for the overflow signal required for the form. Figure 77. Tape Punch The marking for one form should be repeated as many times as the usable length of the tape (22 inches) allows. With the tape thus controlling several forms in one revolution through the sensing mechanism, the life to the tape is increased. Finally, the line corresponding to the bottom edge of the last form should be marked for cutting after the tape is punched. The tape is inserted in the punch by placing the line to be punched over a guide line on the base of the punch and placing the center feed holes of the tape over the pins projecting from the base. The dial is then turned until the arrow points at the number of the channel to be punched. Pressing on the top of the punch, toward the back, cuts a rectangular hole at the intersection of a vertical and horizontal line in the required channel of the tape. The tape should never be punched in more than one channel on the same line. Holes in the same channel should not be spaced closer than eight lines apart. After the tape is punched, it is cut and looped into a belt. The bottom end is glued to the top section, marked CLUE, with the bottom line coinciding with the first line. Before the tape is glued, the glaze on the tape should be removed by an ink eraser; if this is not done, the tape ends may come apart. The center feed holes should coincide when the two ends of the tape are glued together. The last hole punched in the tape should be at least four lines from the cut edge, because approximately the last half inch of tape overlaps the GLUE section when the two ends are spliced. If it is necessary to punch a hole lower than four lines from the bottom of the form, the tape should be placed with the top line (immediately under the GLUE portion) four lines lower than the top edge of the form, before marking the channels. To compensate for the loss, the tape should then be cut four lines lower than the bottom edge of the form. ### 8-Lines-Per-Inch Spacing The control tape for 8-lines-per-inch spacing is punched as it would be for normal 6-lines-per-inch spacing. Each line on the tape always equals one line on the form, regardless of whether the latter be 6 or 8 lines-per-inch. In measuring a control tape for a document printed eight lines to the inch, every ½ inch on the form represents one line on the tape. #### **Carriage Tape Brushes** Two sets of reading brushes (Figure 78), mounted on the same frame, are used to sense holes in the carriage control tape. A small contact roll is used for each set of brushes. One set is called the slow brushes. The other set is called the stop brushes. Seven spaces, as measured by the control tape, separate the brush sets. The slow brushes are positioned ahead of the stop brushes. The slow brushes are used to control high-speed skipping. They regulate the speed of the last eight spaces of a high-speed skip. All carriage tape brushes can function to stop a carriage skip under control of the stored program. ### Inserting Control Tape in Carriage - 1. Raise the counter-balanced cover of the printer to gain access to the tape-reading mechanism. - 2. Turn the feed clutch to a disengaged (neutral) position (see Figure 71). - 3. Raise the brushes by moving to the left the latch located on the side of the brush holder. Figure 78. Carriage-Tape Brushes - 4. Place one end of the tape loop, held so that the printed captions can be read, over the pin-feed drive wheel so that the pins engage the center drive holes. - 5. Place the opposite end of the loop around the adjustable carriage control tape idler. - 6. Remove the excess slack from the tape by loosening the locking knob on the idler and moving the idler in its track. Tighten the knob when the desired tension is reached. The tape should be just tight enough so that it gives slightly when the top and bottom portions of the loop are pressed together (see Figure 76). If it fits too tightly, damage occurs to the pin-feed holes. - 7. Press the brushes down until they latch, and close the printer cover, when the tape is in position. - 8. Press the carriage restore key to bring the tape to its home position, and turn the feed clutch knob back to the engaged position. The carriage is ready to operate. #### **Ribbon Changing** To change the ribbon (Figure 79) on the IBM 1403 Printer: - 1. Turn off the power in the printer. - 2. Lift up the printer cover. - 3. Pull back and unlock the print unit release lever. Swing the print unit out. - 4. Open the top ribbon cover. - 5. Unlatch the print-line indicator ribbon shield and swing it against the form. Figure 79. Ribbon Mechanism - 6. Push the top ribbon roll to the right (hinged side of print unit), lift out the left end of the ribbon roll, and remove roll from the drive end of mechanism. - 7. Slip ribbon out from under correction roll. - 8. To remove the bottom roll, press the ribbon roll to the right, and lower the left end of the ribbon roll and remove it from the drive end of the mechanism. When replacing the ribbon in the machine, hand-tighten the ribbon to remove slack from in front of the printing mechanism. Ribbons are available in widths of 5, 8, and 11 inches in addition to the standard 14 inches. The ribbon width lever (Figure 80) can adjust the ribbon-feed mechanism to accommodate various ribbon widths. #### Forms Insertion 1. Raise the counterbalanced cover of the printer to gain access to the print and forms area. Figure 80. Printer Front Cover, Open - 2. Turn the feed clutch knob to a neutral position. - 3. Unlock and swing back the print unit by using the print unit release lever. - 4. Unlock the paper guide bars by pulling out on the raised handles (upper and lower). On some 1403 Printers, this step is skipped; see step 12. - 5. Open the upper and lower forms tractors (Figure 81). Figure 81. Forms Tractor - 6. Set the left forms tractors slightly to the left of the first unit position by pulling up or down in the tractor lock (upper and lower tractor). See Figure 74. - 7. Insert form on pins and close tractor cover. - 8. Pull out on right tractor pin and move tractor to desired location to line up the right side of form. The pin should latch in one of the recessions in the tractor slide bars. See Figure 74. - 9. Insert form on pins and close tractor covers. - 10. Use the tractor vernier knob to tighten the tension on the form. This knob is used for adjustments of up to one-half inch. - 11. Check the position and line where printing will occur, by swinging the ribbon shield against the form (it is marked with each print position). If the horizontal alignment is not correct, it can be adjusted by using the horizontal adjustment knob and/or the lateral print vernier knob for slight adjustments. The vertical adjustment can be made by using the paper advance knob and/or vertical print adjustment knob. - 12. Return the upper and lower paper guide bars to the closed positions (Figure 82). Some 1403 printers have the tractor-mounted jam detection device which, together with elimination of front "clip on" paper guides, eliminates the need for the upper and lower paper guide bars. The forms insertion procedure for a 1403 with the tractor mounted jam detection device instead of the upper and lower tape guides is the same except that steps 4 and 12 are skipped. - 13. Return the print unit to its normal position and lock it in place. - 14. Restore the carriage tape to the first printing position by pressing the carriage restore button. - 15. Return the feed-clutch knob to a drive position at either six or eight lines-per-inch, depending on the form to be printed. Figure 82. Paper Guide Bars 16. Close the outside cover of the printer. #### Paper Stacker The paper stacker provides a manual control for optimum stacking of paper at the rear of the printer. Two controls (Figure 83) permit the operator to set up the paper stacker for each individual run. The upper lever controls the position of the paper guide at the stacker. This lever is indexed (0-6) so that the setup position can be recorded for reference in the operator's procedures. The lower lever is a speed control that is set to keep light tension on the paper form feeding into the stacker. The speed control has five settings. The setting of this control is selected according to the carriage operation being used. For example, if the job is a listing operation with no long skips, the slow position is selected. However, this must also be conditioned by the kind of forms being used because of varying weight of the paper. ### Form Design Some of the customary rules for designing forms should be reconsidered in the light of the many new features introduced by the IBM 1403 Printer. Figure 83. Paper Stacker Controls - 1. The print unit contains 100 print positions in a 10.0-inch width or a maximum of 132 print positions (special feature) in a 13.2-inch width. Each print position can print any character. - 2. Editing, high-speed skipping, and other features are included in the system. One of the basic tools used in designing forms is the spacing chart shown in Figure 84. The numbers across the top from 0 to 13 represent the tens and hundreds positions of the print-position number, and the numbers directly beneath represent the units position of the print-position number. Print-position 42 can be located by referring first to the 4 column and then to the digit 2 within the 4 column. Print-position 9 can be located by referring to the 0 column and then to the digit 9 within that column. A facsimile of the carriage-control tape is shown at the left (in Figure 84) for marking the control punching for a specific form. Notations have been included relative to standard form-widths and form-depths, lateral movement of the carriage, and instructions to forms manufacturers. The IBM 1403 Printer carriage is designed to feed marginally-punched continuous forms satisfactorily under the conditions and specifications outlined in Figure 85. These specifications, if followed, give maximum operating efficiency when the 1403 carriage is used. They are not intended to be restrictive but are intended to permit customers to purchase their continuous forms from the manufacturer of their choice. #### Form Design as Affected by the Print Unit In view of the 100 or 132 print positions and the 13.2-inch print unit, these factors should be considered when designing forms to be used on the IBM 1403 Printer: - 1. The maximum form width is 18¾ inches, and the minimum is 3½ inches (see Figure 85). - 2. The maximum form length is 22 inches at sixlines-per-inch spacing, or 16½ inches at 8 lines per inch. For efficient stacking of forms, the recommended maximum forms length is 17 inches. - 3. Because all print positions can print all characters, form depth can be reduced, and carbon paper eliminated, by the use of side-by-side printing. For example, *sold to* and *ship to* names can be printed on the same line, one on the left side of the form and the other on the right. - 4. Forms can be designed for printing six or eight lines to the inch. Single-space, eight-lines-per-inch printing is not recommended when the registration between lines is critical. - 5. Forms can be designed for variable line spacing within a form by use of single-, double-, or selective-space control. Figure 84. Forms Spacing Chart - 6. It is possible to dispense with many vertical lines, because the system can be programmed to print commas, decimals, slashes, dashes, and other symbols. - 7. A vertical line should not be printed between two adjacent printing positions because there is an over-all maximum tolerance of only .013 inch between adjacent characters. - 8. The number of legible copies that can be produced depends on the weight of the paper used for each form, and on the carbon coating. Because the striking force of the print hammers is not adjustable, paper and carbon should be tested in conjunction with the print-density control lever and the print timing dial. - 9. The CR (credit symbol) prints from two print positions and the minus sign prints from one. For this reason the minus sign is recommended as a credit symbol instead of the CR symbol. - 10. The dollar symbol does not have to be preprinted on a check form, because this symbol can be programmed to print immediately to the left of significant digits. # Forms Specifications and Dimensions ### **Paper Characteristics** The paper used for continuous forms must be of sufficient weight and strength to prevent the holes from tearing out during feeding or ejecting the form. This is particularly important when single-part forms are being used. The paper must not be so stiff as to cause improper feeding or excessive bulging, particularly at the outfold. Paper must be as free from paper dust or lint as possible. ### Weight The number of legible copies required is a factor in determining the weight of the paper to be used in a multiple-part set. Best results on multiple-copy forms require a lightweight paper of 13 pounds or less, except for the last copy. Again, the number of copies, as well as the distance of the form away from the hammers (this distance can be varied by use of the print-density control-lever), affects the determination of paper weight. Feeding and legibility performance can best be determined by making test runs of sample sets of forms. #### Friction During the feeding operation, friction on marginallypunched continuous forms should be eliminated by the following means: 1. Place the pack of forms directly beneath the front of the printer on the forms stand, in a position that eliminates any abnormal drag on the forms. Figure 85. Form Specifications 2. Allow enough clearance between the hammers and the print chain, to permit the forms to be fed by the pins freely, and without interference. This can be accomplished by properly setting the print density control lever. #### **Perforated Lines** The perforations between forms should be deep enough to permit easy separation, but not so deep as to tear in ordinary handling or feeding through the machine. The perforated lines at the end of the form should always be located at 90 degrees to a vertical center line through the marginal holes. Cut and uncut portions should be uniformly accurate in length and spacing to insure proper and efficient tearing. Vertical perforations, at the margin for removal of the marginally punched strip, can vary, depending upon requirements. The distance from the edge of the form to the marginal perforations is usually ½ inch. #### **Marginal Holes** Continuous forms should have holes in both right and left margins, ½ inch in diameter, spaced vertically ½ inch apart from center to center, the full length of the form. The holes should be located this way on all copies of all sets throughout each pack of forms. It is possible, however, to use holes of any size, shape, and spacing that accomplish the equivalent feeding conditions. Vertical lines passing through the two vertical rows of pin holes must be parallel. It is recommended that the edges of the form be ¼ inch from the vertical center lines through the holes. A horizontal line passing through the center of any two marginal holes on the same line should be at a 90-degree angle to either vertical center lines through the marginal holes. Spacing between holes, center-to-center, must be such that the pins in the forms tractor, ½ inch in diameter and spaced ½ inch apart, enter and leave the holes in the paper, freely without tearing the paper. ### Width of Forms Although forms of any width within the extremes of those shown in Figure 85 can be used, it is recommended that form widths be confined to the standard sizes shown in Figure 86. ### Length of Forms Between Perforated Lines The 1403 accommodates marginally-punched continuous forms up to a maximum length of 22 inches, at 6-lines-per-inch. It is recommended, however, that form | OVER-ALL WIDTH (INCHES) | HOLE-TO-HOLE<br>(INCHES) | |-------------------------|--------------------------------| | 43/4 | 41/4 | | 5¾ | 51/4 | | 61/2 | 6 | | 8 | 71/2 | | 81/2 | 8 | | 91/2 | 9 | | 105⁄8 | 101/8 | | 11 | 101/2 | | 113/4 | 111/4 | | 12 | 11½ | | 1227/32 | 1211/32 | | 135/8 | 131/8 | | 147/8 | 14 <sup>3</sup> / <sub>8</sub> | | 151/2 | 15 | | 16 | 151/2 | | 163/4 | 161/4 | | 1725/32 | 17%2 | Figure 86. Standard-Size Forms lengths be confined to regular lengths, such as 3, $3\frac{1}{3}$ , $3\frac{1}{2}$ , $3\frac{2}{3}$ , 4, $4\frac{1}{4}$ , 5, $5\frac{1}{2}$ , 6, 7, 8, $8\frac{1}{2}$ , 10, 11, 12, 14, 16, and 17 inches. #### Line Spacing The forms tractor of the IBM 1403 can be set by the operator for single-space printing, 6- or 8-lines-perinch. For 6-lines-to-the-inch spacing, the length of the form must be evenly divisible by ½ inch for single spacing, by ½ inch for double spacing, and by ½ inch for triple spacing. Similarly, 8-lines-to-the-inch spacing requires that the length of the form be evenly divisible by ½ inch for single spacing, by ¼ inch for double spacing, and by ¾ inch for triple spacing. Single-space, 8-lines-per-inch printing on the 1403 is not recommended when the registration between lines is critical. ### **Multiple Copies** Multiple-copy forms consisting of more than four parts, and forms with the first part made of paper of more than 13-pound weight, should be tested under operating conditions to determine the suitability of feeding and legibility. If multiple-copy forms are not fastened together, the carbon paper must be kept in line with the form by an acceptable method. One such method is center carbon without pin holes, glued to the set, or fullwidth carbon paper punched with substantially larger marginal holes that are approximately centered with the corresponding holes in the form. Marginal holes in the carbon that are substantially larger than the corresponding holes in the forms make allowance for carbon shrinkage and provide the processing tolerance necessary for some of the commonly used form structures. One-time carbon paper or carbon-backed paper can be used. The carbon paper or coating should produce the required number of legible copies without excessive smudging. This can be determined best by making test runs with sample sets of forms containing different qualities of carbon papers. ### Fastening of Multiple-Copy Forms The width, length, and number of copies of the form determine the fastening requirements for satisfactory feeding through the forms tractor. For most efficient stacking, however, it is recommended that a suitable fastening method always be used with multiple copy forms. If the construction of the form is such that the parts are of different widths, the necessity for, and the method of, fastening the form should be determined by the width of the parts, the depth of the form (shown in Figure 87), and weight of paper. | FORM DEPTH<br>(Inches) | MAXIMUM DISTANCE BETWEEN FASTENINGS (Inches) | |------------------------|----------------------------------------------| | 1 to 5 | 5 | | 5-1/5 to 11 | 11 | | 11 to 14 | 7 | | 14 to 17 | 81/2 | | | | Figure 87. Fastening Requirements for Multiple-Copy Forms Forms of fanfold construction can be used on the IBM 1403 Printer. When card-tag or rag-content paper stock is used, a test of sample sets of forms should be made to determine the exact fastening requirements. The fastening may consist of any satisfactory method, such as stitching or gluing, that prevents the copies from shifting. It is essential, however, that whatever fastening medium is used should not impair the feeding or printing alignment of the form. #### **Registration of Forms** The assembly of multiple-copy forms should insure that the punching and printing of all copies of the form are in absolute registration with the material printed by the 1403. The following tolerances should be maintained. Vertical Lines: Vertical columns of print positions are spaced 1/10 inch apart. There are 50 printing spaces in 5 inches. Vertical rules printed on a form should be spaced in multiples of 1/10 inch. The center line of any one character, with reference to any other character on the same line, may have a plus or minus tolerance of .0065 inch, or a maximum over-all tolerance of .013 inch. From a forms viewpoint, it is practically impossible to guarantee that the cumulative tolerance of printing-plate shrinkage, paper shrinkage, and marginal-hole perforations does not exceed .0065 inch. This precludes the possibility of retaining satisfactory registration if vertical rules are spaced to split between print positions. Where vertical lines are required, such rules should split the respective print position, thereby assigning that particular position for the columnar field (dollars and cents, for example) separation. However, in view of the fact that the 1403 can print special characters such as period and comma in every print position, the use of these symbols as decimal points, etc., avoids the need for vertical lines for such separations. Vertical printed lines should parallel a vertical center line passing through the marginal holes. Horizontal Lines: Horizontal printed lines on the form should be at a 90-degree angle to the vertical center line passing through the paper-feed pin holes. The spacing should conform to the setting of the 1403 forms tractor — 6- or 8-lines-to-the-inch. Margins: It is recommended that no staples or other metal fasteners be used with multiple-copy forms. If such practice is unavoidable, the staples must not pass between the chain and a hammer; to avoid this, the margin containing the staples must be set to the right or left of the print hammer area. The print hammer area cannot be avoided at the right unless the forms are at least 8½ inches wide; thus, staples cannot be used in the right margins of narrower forms. ### **Operation Codes for 1403** See Figure 88. Note: To avoid stopping the system, one of the branch if 1/0 channel status indicator on instructions (Figure 36) must be given between any instruction for the 1403 and the next 1/0 instruction on the same channel. See "Results of Omitting the Status Test." Figures 89 and 91 show the 1/0 channel status indicators that may be set (turned on) during 1403 operations. | I/O UNIT | OP<br>CODE | X-CTRL<br>FIELD | DESCRIPTION | MNEMONIC | d-CHAR | OPERATION | NOTES | | |----------|---------------------|-----------------------------------|----------------------------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--| | | ň | %20 (Ch 1) | Write a line | W or W1 (Ch 1)<br>W2 (Ch 2) | w | Transfer 100 or 132 characters from storage to print buffer and print a line. | Word marks in storage area are not transferred. | | | | Ľ | 20 (Ch 2) | Write a line, word<br>marks create<br>blanks in printing | WW or W1W<br>(Ch 1)<br>W2W (Ch 2) | | | Word marks in storage area<br>transfer as word separators and<br>"print" as blanks ahead of asso-<br>ciated characters. | | | PRINTER | y □21 (Ch 2) as 1's | WM or WM1<br>(Ch 1)<br>WM2 (Ch 2) | •• | Transfer word marks from storage to print buffer and print as 1's. | Positions without word marks transfer and print as blanks. (With L op code, word marks transfer as word separators and also "print" as blanks; thus no printing results.) | | | | | CARRIAGE | F (Ch 1) | None | Carriage control | CC or CC1 | Soc Ei | S F | | | | CARRIAGE | y<br>2 (Ch 2) | | | CC2 | See Figure 90 for the list of d-characters and operations. | | | | Figure 88. Instructions for 1403 Printer # Write a Line (M) # Write a Line, Word Marks Create Blanks in Printing (Ľ) Instruction Form: | | OP | X-CONTRO | L | | |--------------------|--------|-----------|-------------|--------------| | MNEMONIC | CODE | FIELD | B-ADDRESS C | l-character | | W or W1 (Ch 1) | M | %20 | bbbbb | $\mathbf{W}$ | | W2 (Ch 2) | Ň<br>Ľ | □20 | bbbbb | W | | WW or W1W (Ch 1) | Ľ | %20 | bbbbb | W | | W2W (Ch 2) | Ľ | $\Box 20$ | bbbbb | $\mathbf{W}$ | | Timing: $T = 49.5$ | 5 + I | /O. | | | (See "Timing Considerations for 1403.") Address Registers after Operation: I-ADDRESS REG A-ADDRESS REG B-ADDRESS REG NSI AD B + LB + 1 Function: This instruction causes the transfer of 100 (or 132) characters in core storage to the print buffer. The hundreds position of the x-control field identifies the channel (% is channel 1), and the 2 in the tens ( $\mathbf{x}^2$ ) position specifies the printer (Figure 107). The units ( $\mathbf{x}^3$ ) position of the x-control field contains a 0. The B-address specifies the leftmost (starting) position of the data record in core storage, and characters are transferred to the print buffer serially from left to right. The operation is stopped by the first groupmark—word-mark sensed in core storage. At the end of the data transfer, the printer is started and prints a line with the data just transferred. If the L Op code is used, word marks are translated to word separators during the transfer to the print buffer. There is no character on the printing mechanism for a word separator, and the printed result is a blank space preceding each character associated in core storage with a word mark. Word Marks: A group-mark—word-mark must appear in the core storage position to the immediate right of the data record. Use of the load mode causes a blank space to precede each character associated in core storage with a word mark; this increases the resultant field length in the buffer, and may cause the loss of some of the field. #### Write Word Marks As 1's Instruction Form: (See "Timing Considerations for 1403.") Address Registers after Operation: Function: The form of this instruction differs from that of the write a line instructions by having a 1 in the $x^3$ position. This difference causes two radical differences in the function: (1) word marks in the data field are transferred to the print buffer as 1's, (2) positions without word marks are transferred to the print buffer as blanks. These are the only differences from the write a line instructions. (Thus, if the L Op code is used, no printing results.) Word Marks: A group-mark—word-mark must appear in the core-storage position to the immediate right of the data record. | INDICATOR<br>TESTED | d-CHARACTER | CONDITION | |------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------| | Not Ready | 1 | Printer not ready, Printer not on<br>line, Printer power off, Printer<br>out of forms | | Busy | 2 | Previous line still being printed | | Data Check | 4 | Print buffer detects parity error<br>(line is not printed) | | Condition | 8 | Print buffer detects timing error,<br>Print buffer detects hammer fire<br>check (line following error line<br>is not printed) | | Wrong Length<br>Record | — (B-bit) | Wrong length record (line is not printed) | | No Transfer | 杉 (A-bit) | Never set | Figure 89. I/O Channel Status Tests After Write a Line (Also After Write Word Marks as 1's) #### **Carriage Control** Instruction Form: $\begin{array}{cccc} \text{MNEMONIC} & & \text{OP CODE} & & \text{d-character} \\ \text{CC or CC1} & & \text{F (Ch 1)} & & \text{x} \\ \text{CC2} & & \text{2 (Ch 2)} & & \text{x} \\ \end{array}$ Timing: T = 13.5. (See "Timing Considerations for 1403.") Address Registers after Operation: Function: Depending on the specifications of its d-character (Figure 90), this instruction causes the printer to (1) skip to the specified control-tape channel, either immediately or after the next print operation, or (2) take one, two, or three spaces, either immediately or after the next print operation. The numeric portion of the d-character specifies the number of spaces to be taken or the tape channel hole that stops the skip, while the zone portion further defines the operation. (For example, d-characters of 3, C, L, and T all have a numeric-bit value of 3 and cause four different 3-factor operations.) | d | IMMEDIATE<br>SKIP TO | d | SKIP AFTER<br>PRINT TO | d | IMMEDIATE<br>SPACE | |---|----------------------|---|------------------------|---|--------------------| | 1 | Channel 1 | A | Channel 1 | J | 1 Space | | 2 | Channel 2 | В | Channel 2 | к | 2 Spaces | | 3 | Channel 3 | С | Channel 3 | L | 3 Spaces | | 4 | Channel 4 | D | Channel 4 | | | | 5 | Channel 5 | E | Channel 5 | | | | 6 | Channel 6 | F | Channel 6 | d | SPACE AFTER | | 7 | Channel 7 | G | Channel 7 | | PRINT | | 8 | Channel 8 | н | Channel 8 | / | 1 Space | | 9 | Channel 9 | 1 | Channel 9 | s | 2 Spaces | | 0 | Channel 10 | ? | Channel 10 | Т | 3 Spaces | | # | Channel 11 | • | Channel 11 | | | | @ | Channel 12 | 口 | Channel 12 | | | | | | | | | | Figure 90. d-Characters for Carriage Control Instructions After a line is printed, the form must be moved before the next line is printed. If it is not moved by a carriage control instruction (or by pressing the carriage space or carriage restore key on the 1403), it will be moved by an automatic single-space at the end of a data transfer from core print buffer to printer. An instruction that causes a skip to a channel at which the carriage tape is already positioned causes the carriage to move to the next punch of that same channel number. Word Marks: Word marks are not affected. | INDICATOR<br>TESTED | d-CHARACTER | CONDITION | |------------------------|-------------|---------------------------------------------------------------------------------------| | Not Ready | 1 | Printer not ready, Printer not on<br>line, Printer power off, Printer<br>out of forms | | Busy | 2 | Forms in motion, forms instruc-<br>tion waiting to be executed | | Data Check | 4 | 1 | | Condition | 8 | / | | Wrong Length<br>Record | — (B-bit) | Never set | | No Transfer | 右 (A-bit) | ) | Figure 91. I/o Channel Status Tests After Carriage Control # **Timing Considerations for 1403** The 1403, any model, provides a 3-millisecond overlap for successive forms movements. Successive print operations and forms movements are also overlapped 3 milliseconds if a carriage control instruction, such as a carriage control 1 space after print (F / or 2/), directly precedes the write a line instruction in the program. That combination of successive print and vertical space operations takes 100 milliseconds maximum per line (Figure 92), or 600 lines per minute. The time is composed of 81.585 milliseconds (rounded to 82 milliseconds) to print a line, and 18 milliseconds for the single space operation. An additional 3 milliseconds are required, however, for an automatic singlespace, or for isolated space operations that are not programmed to immediately follow a print or another vertical space operation. The transfer of data from core storage to the print buffer requires 11 microseconds per character for any 1403 model. Program compatibility between models, thus achieved, permits the use of processing overlap, in which about half the time required for each transfer of a character into the print buffer can be used to take processing cycles. The maximum character-transfer time for Model 1 is 1.1 milliseconds for the full 100 characters or, for Model 2, 1.452 milliseconds for the full 132 characters. The printer is not busy while data are being transferred from core storage to the print buffer; it becomes busy only upon the successful completion of that data transfer and the start of printer operation. Figure 92. Printing, Spacing, and Processing Time ### Special Features for 1403 #### **Numeric Print Feature** The numeric print feature, available for the 1403 Models 1 and 2, permits a step-up in line speed for jobs involving numeric-only printing. When the feature is installed, the speed-up is accomplished by merely changing the chain cartridge in the 1403. The numeric chain is made up of 15 character sets, with 16 characters in each set (digits 0 through 9, and \$ . , \* — $\square$ ). In the numeric mode, the 1403 can print 1,285 lines per minute — more than twice as fast as in the alphameric mode. This feature is recommended for customers having certain 1410 applications that require no alphabetic printing; for example, banks, insurance companies, and utilities prepare many reports with only numeric printing. Using the numeric print feature, the time required to produce such reports can be reduced by as much as 50 per cent. The manufacturing, wholesaling, and retailing levels of other industries can also use this feature for the many applications in which reports are (or can be) numerically coded. To change from one mode to another, an operator, using no special tools, removes one chain and replaces it with the other. Before locking the new cartridge in place, it is only necessary to move the chain enough to permit the chain drive to engage. When a chain cartridge is placed in the 1403, the corresponding mode is selected automatically. If the printer is in the numeric mode, characters other than the 16 specified for numeric printing cause a print check error. # Interchangeable Chain Cartridge Adapter Many scientific and commercial applications require distinctive type styles for particular printing jobs. This special feature for the IBM 1403 Printer allows chain cartridges to be interchanged. With this feature, an operator can insert an interchangeable chain cartridge with a different type font, type style, or special character arrangement. The procedure for changing a cartridge is: - 1. Turn off system power. - 2. Lift up the printer cover. - 3. Pull back and unlock the print unit release lever. - 4. Unlatch the ribbon shield and swing it against the paper. - 5. Open the ribbon cover and remove the lower ribbon spool. Slide ribbon from under the skew roll and store the lower ribbon spool on the ribbon cover. - 6. Grasp the cartridge handles and raise them to a vertical position. (This unlocks the cartridge from the T-casting.) - 7. Lift straight up on the handles and raise the cartridge until it clears its locating pins. At this point it is free from the machine. Place the cartridge on a surface that will tolerate oil and ink. (A container is provided for storing the cartridge that is not in use.) - 8. Grasp the handles of the second interchangeable cartridge and, raising them to a vertical position, lift the cartridge into position over the locating pin. (Check for foreign matter clinging to underside of cartridge.) - 9. Lower the cartridge gently into position over its guide pins and release the handles (do not force either handle down at this point). The 132-hammer end of the cartridge should settle fully down to the base. The 1-hammer end will not be down in position at this time. - 10. Rotate the chain in the normal printing direction (counterclockwise, as viewed from the top). The chain can be rotated by pressing your finger against a character on the chain. At the same time, apply pressure to the button (located between the printtiming dial and the cartridge) on the top cover. Rotate the chain slowly until the drive key drops into the drive slot. The chain will stop and the cartridge will - settle correctly into position on the 1-hammer end. - 11. Lower the cartridge handles to their horizontal position. Do not force. If force is required, the cartridge is not fully seated; repeat steps 8 to 10. - 12. Replace the ribbons; latch the ribbon shield into place; close the T-casting and the top cover; apply power to the system and resume printing. # **Magnetic Tape Units** Ten 729 or 7330 Magnetic Tape Units (Figure 93) can be attached to each data channel of the 1410 system. Four models of the 729 (Model II, IV, V, or VI) are available for 1410 use. Different 729 models can be intermixed and, if the Tape Intermix Feature is installed, 729's may be intermixed with 7330's (Figure 39). The 729 and 7330 operating principles are practically identical; Figure 94 shows the essential differences in operating characteristics. Details on the operating principles and physical controls for the 7330 and 729 are in the *IBM Magnetic Tape Units Reference Manual*, Form A22-6589. #### **Tape Characteristics** Data are recorded in a seven-bit code, in seven parallel channels along the tape. Figure 95 shows tape characters and their corresponding codes. Records are separated from each other by about 3/4 inch of blank (unrecorded) tape, called an interrecord gap. Each tape character is composed of an even number of magnetic bits. A check bit (labeled C in Figure 95) is written if the number of bits in the other six positions is odd. An even-parity check on each character ensures accuracy for tape-read and tape-write operations. #### Tape Checking The IBM 729 and 7330 tape units verify the validity of recorded information at the time it is written. The relative positions of the read and write gaps (Figure 96) are such that a character recorded by the write gap passes the corresponding read gap; thus, when each character of a record is written, it is read, and a parity check is applied. If an error is detected, the program receives a signal, and corrective action can be taken. Detection of a validity checks sets on a validity-check indicator, which sets on the data check 1/0 channel status indicator. The data check 1/0 channel status indicator can be interrogated by use of the d-character 4 in the instruction, branch if 1/0 unit data check. If a tape error is detected, the tape unit can be backspaced by programming, and the record can be re-read. If the error persists, the operator can intervene, or the program can branch to an error routine. Dust or damage to the magnetic tape is the most frequent cause of errors detected during write operations. Such imperfections are usually isolated. To skip the defective section, the 1410 has instructions to: (1) backspace over the area where the writing of the record was attempted, then (2) cause the tape to space forward about 3.5 inches when the next write oper- Figure 93. IBM 729 and 7330 Magnetic Tape Units | OPERATING<br>CHARACTERISTICS | 7330 | 729 II | 729 IV | 729 V | 729 VI | |--------------------------------------------|-----------------------|------------------------|------------------------|-------------------------|----------------------------------| | Characters Per Inch<br>(Recording Density) | 200<br>or<br>556 | 200<br>or<br>556 | 200<br>or<br>556 | 200 or<br>556 or<br>800 | 200 or<br>556 or<br>800 | | Inches Per Second | 36 | 75 | 112.5 | 75 | 112.5 | | Characters Per Second<br>(Data Rate) | 7,200<br>or<br>20,016 | 15,000<br>or<br>41,667 | 22,500<br>or<br>62,500 | 41,667 or | 22,500 or<br>62,500 or<br>90,000 | | High Speed Rewind,<br>Minutes | 2.2 | 1.2 | 0.9 | 1.2 | 0.9 | | Regular Rewind, Inches<br>Per Second | 36 | 75 | 112.5 | 75 | 112.5 | Figure 94. Tape Unit Characteristics Figure 95. Magnetic Tape Seven-Bit Coding (Even Parity) ation is initiated. During the space operation, this 3.5 inch area is erased so that extraneous data are not sensed during succeeding read operations. Writing on tape is enabled to continue after the skip is completed. During writing from load point, a space of 3.5 inches occurs before the record is written, and start time is increased by about 27 milliseconds. Figure 96. Read and Write Gap ### **Operation Codes for Magnetic Tape Units** These instructions control reading and writing magnetic tape (with or without word marks), backspacing tape, writing tape marks, rewinding tape reels, and skipping over defective areas. There are three types of magnetic tape control instructions — unit control, read and write tape, and read and write tape with word marks (Figure 97). In magnetic tape operation, the character in the hundreds position of the x-control field indicates the channel and overlap mode: %, Ch 1, non-overlap; @, Ch 1, overlap; □, Ch 2, non-overlap; \*, Ch 2, overlap. Note: To avoid stopping the system, one of the branch if 1/0 channel status indicator on instructions (Figure 36) must be given between any instruction for a magnetic tape unit and the next 1/0 instruction on the same channel. See "Results of Omitting the Status Test." Figure 99 shows the 1/0 channel status indicators that may be set (turned on) during magnetic tape unit operations. #### **Unit Control** Instruction Form: Function: This instruction causes the tape unit that is specified by the digit 0-9 in the units $(x^3)$ position of the x-control field to perform the operation specified by the d-character: | OPERATION | d-character | |--------------------------------------|-------------| | Backspace Tape | В | | Move Tape One Record Without Reading | | | (for CE use) | Α | | Rewind | R | | Rewind and Unload | U | | Skip and Blank Tape (Erase Forward) | ${f E}$ | | Write Tape Mark | M | The hundreds position of the x-control field identifies the channel (% is channel 1), and a U or B in the $x^2$ position specifies magnetic tape unit operation (Figure 107). The write tape mark instruction can be overlapped; see "Overlap Operational Considerations," point 4. Erasing Tape: In bypassing a defective section where tape writing has been attempted, the tape is backspaced one record and erased forward about 3½ inches; then the tape writing restarts. The following sequence of instructions must be used: | INSTRUCTION | , ACTUAL | MNEMONIC | |---------------------|-----------------------------------------------------------------------------------|--------------| | Backspace tape | $\dot{\mathbf{U}} \mathbf{x}^{5} \mathbf{x}^{2} \mathbf{x}^{8} \mathbf{B}$ | BSP | | Skip and blank tape | $\mathbf{\mathring{U}} \ \mathbf{x}^{5}\mathbf{x}^{2}\mathbf{x}^{8} \ \mathbf{E}$ | SKP | | Write tape | M or L x <sup>1</sup> x <sup>2</sup> x <sup>8</sup> bbbbb W | WT or WTW | | _ | ( or | (or WTEW, | | | X) | WTBO*, etc.) | | OP<br>CODE | DESCRIPTION | MNEMONIC | d-<br>CHARACTER | OPERATION | NOTES | |------------|----------------------------------------------|------------------|-----------------|------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | V | Backspace tape | BSP | В | Tape unit backspaces over one complete tape record. | A tape mark is considered a tape record. The 1410 is not interlocked during the operation. | | | Skip and blank tape<br>(Erase forward) | SKP | E | Erases 3.5 inches of tape before next tape-write. A tape-read or backspace-tape cancels the SKP operation. | The next instruction should be a tape-write operation for the same tape unit. | | | Write tape mark | WTM | М | A tape mark is written on tape as a single-character record. | The 1410 is interlocked during the operation. | | | Rewind | RWD | R | Tape unit rewinds, loads its tape, and positions itself at load point. | At the completion of the operation, the tape unit is in a ready status at load point. (Always low speed on 7330.) | | | Rewind and unload | RWU | U | Tape unit rewinds and unloads its tape. | At the completion of the operation, the tape unit is effectively disconnected. (High speed on 7330 requires manual reloading.) | | ň | Write tape RT or RTB Write tape WT or WTB | | R | A record is transferred from magnetic tape to core storage. | Reads to first ≠ or IRG. | | | | | w | A record is transferred from core storage to magnetic tape. | Writes to first $ \stackrel{\checkmark}{\sharp}$ . | | Ľ | Read tape with<br>word marks | RTW or<br>RTBW | R | A record with word marks is transferred from magnetic tape to core storage. | Reads to first $\stackrel{\vee}{=}$ or IRG. | | | Write tape with word marks | WTW or<br>WTBW | W | A record with word marks is transferred from core storage to magnetic tape. | Writes to first ¥ . | | Ň | Read tape | RTG or<br>RTBG | \$ | Read from magnetic tape to core stor- | Stop transfer when IRG is sensed or | | Ľ | Read tape with<br>word marks | RTGW or<br>RTBGW | \$ | age. Group mark—word-marks in core storage have no effect on operation. | last core-storage position is encoun-<br>tered. | | Ň | Write tape | WTE or<br>WTBE | x | Contents of core storage are written on tape. Group-mark — word-marks in | Stop transfer when last core-storage position is encountered. | | Ľ | Write tape with word marks | WTEW or<br>WTBEW | x | core storage have no effect on op-<br>eration. | position is encountered. | Note: B in mnemonic specifies odd-parity mode (binary). Figure 97. Instructions for Magnetic Tape Units $x^1 = \%, @, \Box, *$ Word Marks: Word marks are not affected. ### Read or Write Tape Instruction Form: $\begin{array}{cccc} & \text{OP} & \text{X-CONTROL} \\ & \text{MNEMONIC} & \text{CQDE} & \text{FIELD} & \text{B-ADDRESS d-CHARACTER} \\ \text{RT or WT} & \text{M} & \text{WUx}^{\text{B}} & \text{bbbbb} & \text{R or W} \\ \text{RTB or WTB} & \text{M} & \text{\% Bx}^{\text{S}} & \text{bbbbb} & \text{R or W} \\ \end{array}$ Timing: T = .0045 (L + 1) + Tm ms. (See "Timing Considerations for Tape Units") Address Registers after Operation: Function: These instructions cause the reading from tape into core storage (d-character of R or \$) or the writing on tape from core storage (d-character of W or X). The hundreds position of the x-control field identifies the channel (% is channel 1), and the U or $x^2 = U$ or B (even parity or odd parity) $x^3$ = Designated number of tape unit $x^5 = \%$ or $\square$ (Ch 1 or 2 non-overlap) <sup>\*</sup> Write a record on tape in the move mode, using odd parity and the overlap special feature. B in the $x^2$ position specifies magnetic tape unit operation in the even parity mode (U) or the odd parity mode (B). The odd parity mode is used for writing programs on tape (see "Read or Write Tape with Word Marks"). A digit 0-9 in the $x^3$ (units) position specifies the particular tape unit that performs the read or write operation. The B-address specifies the leftmost position of the core storage area reserved for the tape record(s) to be read or containing the tape record(s) to be written, and characters are transferred serially from left to right. A read tape operation with a d-character of R is stopped by the first inter-record gap on tape or group-mark — word-mark in core storage. If a group-mark — word-mark is sensed first, the data transfer stops but tape movement continues to the first inter-record gap. Group-mark—word-marks in core storage have no effect on a read tape to end of core operation (d-character of \$), which is stopped by the first inter-record gap on tape or by the filling of the highest-numbered position in core storage. A write tape operation with a d-character of W is stopped by the first group-mark — word-mark in core storage, and an inter-record gap is then produced on the tape. Group-mark — word-marks in core storage have no effect on a write tape to end of core operation (d-character of X), which is stopped only by the encountering of the highest-numbered position in core storage. Instructions using the R or W d-character can be overlapped. Instructions using the \$ or X d-character cannot be overlapped. Word Marks: Word marks do not affect tape operations having an Op code of M. The effects of groupmark — word-marks are described in preceding text. ### Read or Write Tape with Word Marks Instruction Form: | | OP | X-CONTROL | | | |----------------|-------|-------------------|-------------|-------------| | MNEMONIC | CODE | FIELD | B-ADDRESS C | d-character | | RTW or WTW | Ľ | %Ux8 | bbbbb | R or W | | RTBW or WTBW | Ľ | %Bx8 | bbbbb | R or W | | RTGW or WTEW | Ľ | %Ux <sup>3</sup> | bbbbb | \$ or X | | RTBGW or WTBEW | Ľ | % Bx <sup>3</sup> | bbbbb | \$ or X | | | 4- /- | | т. | | Timing: T = .0045 (L + 1) + Tm ms. (See "Timing Considerations for Tape Units.") Address Registers after Operation: $\begin{array}{cccc} \text{I-address rec} & \text{A-address reg} & \text{B-address reg} \\ \text{NSI} & \text{Ap} & \text{B} + \text{LB} + 1 \end{array}$ Function: The form of these instructions differs from that of the read or write tape instructions by having an L Op code. This difference causes word marks in core storage to be written on tape as word separators, and word separators on tape to be read into core stor- | 1410 core-storage<br>location | A | В | С | Write<br>A | |-------------------------------|-----|------|----|------------| | 1410 core-storage<br>code | C82 | 41W | 4 | | | 1410 meaning | 0 | 5 | 4 | | | Tape positions | A | В | С | D | | Tape code | 82 | A841 | 41 | C4 | - (A) Write Tape with Word Marks - (B) Read Tape with Word Marks | Tape positions | A | В | С | D | |-------------------------------|-----|------------|----|-----------| | Tape code | 82 | A841 | 41 | C4 | | 1410 meaning | 0 | y i<br>5 i | 4 | | | 1410 core-storage<br>location | A | В | С | | | 1410 core-storage<br>code | C82 | 41W | 4 | B<br>Read | Figure 98. Word Mark Translation for Tape age as word marks. A word separator is written on tape one position ahead of the associated character (Figure 98A). A word mark is associated with the next character read from tape (Figure 98B). The write tape with word marks instruction is used whenever word marks are to be indicated on tape. If the purpose of this is to write a program on tape, the odd parity mode should be used, for the reasons described in Figure 95 (but see the following note). The X d-character may also be used, as described in "Read or Write Tape," to prevent any group-mark—word-mark in the program from stopping the data transfer. The tape record that is written by means of the write tape with word marks instruction must be read with a read tape with word marks instruction if the word-mark indications are to be retained. Word Marks: Each word separator requires one tape character position. The effects of group-mark — word-marks are described under "Read or Write Tape." Note: If the x-control field contains $\%Bx^3$ , the magnetic-tape operation is performed in an odd-parity mode. A tape mark is always even parity. If a tape mark is encountered during an odd-parity operation, a data check and an end-of-file indication result. Depending on the position of the asterisk insert switch and other console controls, the tape mark ( $\lor$ ) is stored as either 8421 (no C), an unchanged and invalid character, or it is converted to and stored as an asterisk. (See "Asterisk Insert Switch" under "IBM 1415 Console CE Test Panel.") In even-parity mode (%Ux³), the tape mark enters storage as C8421 and no data check accompanies the end-of-file indication. | INDICATOR<br>TESTED | d-CHARACTER | | |---------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------| | READ(R), WRITE(W),<br>CONTROL UNIT(U) | | CONDITION | | Not Ready<br>(R-W-U) | 1 | Tape unit not ready<br>No such tope unit selected<br>Tape adapter unit not on line<br>Tape adapter unit power off | | Busy (R-W-U) | 2 | Tape unit rewinding<br>Tape adapter unit busy (back-<br>space or tape read-write not<br>finished) | | Data Check (R) | 4 | Processing unit received wrong<br>parity character<br>Tape adapter unit sent wrong<br>parity character<br>Tape mark read in odd parity | | (W) | | mode Tape adapter unit received wrong parity character Tape adapter unit detects rbc | | (U) | | parity error<br>Set if write tape mark in odd<br>parity | | Condition (R) | 8 | 1st character of record was tape mark | | (W)<br>(U) | | Foil strip detected<br>Never set (unless tape mark read) | | (R) | — (B-bit) | Wrong length record (usually set when d-character is \$) | | (W-U)<br>Wrong Length<br>Record | | Never set (unless record is of zero length and first character written is 🛓 ) | | No Transfer<br>(R-W-U) | ち (A-bit) | Never set | Figure 99. I/O Channel Status Tests After Read Tape, Write Tape, and Unit Control # **Timing Considerations for Tape Units** All tape units on a given channel in a 1410 system are under control of a tape adapter unit (TAU). TAU can control the operations of only one tape unit at a time. If one tape unit is busy, no other tape unit can be used until all operations (except rewinding) on the busy one have been completed. The execute times of IBM 1410 tape instructions vary according to the type and model of tape units used in the system (Figure 100). In the following formulas: C is the character rate in milliseconds (ms) based on the setting of the tape density switch. N is the number of characters in the record. CN is record time (number of characters in the record, times the character rate). ``` - Tape movement can be determined from the following: N = Number of characters in the record C = Character rate in milliseconds 729 II at 200 cpi = 0.067 ms at 556 \text{ cpi} = 0.024 \text{ ms} 729 IV at 200 cpi = 0.044 ms at 556 \text{ cpi} = 0.016 \text{ ms} 729 V at 200 cpi = 0.067 ms at 556 \text{ cpi} = 0.024 \text{ ms} at 800 cpi = 0.017 \text{ ms} 729 VI at 200 cpi = 0.044 ms at 556 \text{ cpi} = 0.016 \text{ ms} at 800 \text{ cpi} = 0.011 \text{ ms} 7330 at 200 cpi = 0.139 ms at 556 \text{ cpi} = 0.050 \text{ ms} 729 Models II, V: READ, 10.7 + CN ms with TAU and processing interlocked WRITE, 11.7 + CN ms with TAU and processing interlocked 729 Models IV, VI: READ, 7.1 + CN ms with TAU and processing interlocked WRITE, 7.8 + CN ms with TAU and processing interlocked 7330: READ, 20.5 + CN ms with TAU interlocked 10.8 + CN ms with processing interlocked WRITE, 20.3 + CN ms with TAU interlocked 13.8 + CN ms with processing interlocked Rewind 729 Models II, V = 1.2 minutes per reel 729 Models IV, VI = 0.9 minute per reel 7330 = 2.2 minutes per reel at high-speed Skip and Blank Tape (add to subsequent write time) 729 Models II, V = 40.5 ms 729 Models IV, VI = 27 7330 = 104 \text{ ms} Backspace (after READ) Backspace (after WRITE) 729 Models II, V = 46 + CN ms 729 Models II, V = 54 + CN ms 729 Models IV, VI = 33 + CN ms 729 Models IV, VI = 39 + CN ms 7330 = 428 + CN ms 7330 = 435 + CN ms ``` Figure 100. Tape Movement Specifications *Start time* is the time necessary for the tape unit to accelerate to operating speed. Stop Time is the time necessary for the tape unit to decelerate and stop. Record Check Time is the time necessary to read or write the check character. This time is based on the read-write head gap (the distance that separates the read and write heads) and the time it takes a single character written on tape to travel from the write head to the read head. ### IBM 729 II and V Tape Timings #### Read During a read operation, the tape adapter unit and the processing unit are interlocked for 10.7 + cn ms (Figure 101). This includes: ``` 10.5 ms — start time .2 ms — record check time for 556-cpi tape (.6 ms for 200-cpi tape; .15 ms for 800-cpi tape) CN ms — record time ``` #### READ OPERATION Note: Add 40.5 ms to start time if tape unit is at load point when writing. Figure 101. IBM 729 II and v Read-Write Tape Timing Therefore, in a tape read operation, processing can take place during 1.9 ms of stop time for 556-cpi tape, 1.5 ms for 200-cpi tape, or 1.95 ms for 800-cpi tape. #### Write During a write operation, the tape adapter unit and the processing unit are interlocked for 11.7 + cn ms (Figure 101). This includes: ``` \begin{array}{c} 7.5~\mathrm{ms-start\ time} \\ 4.2~\mathrm{ms-record\ check\ time\ for\ 556-cpi\ tape} \\ \qquad \qquad (4.6~\mathrm{ms\ for\ 200-cpi\ tape;\ 4.15\ ms\ for\ 800-cpi\ tape)} \\ \mathrm{CN\ ms-record\ time} \end{array} ``` Therefore, in a tape write operation, processing can take place during .9 ms of stop time for 556-cpi tape, .5 ms for 200-cpi tape, or .95 ms for 800-cpi tape. #### **Nominal Formula** For job timing estimates of tape read and write operations, the nominal formula 10.8 + cn ms can be used. ### IBM 729 IV and VI Tape Timings #### Read During a read operation, the tape adapter unit and the processing unit are interlocked for 7.14 + cn ms (Figure 102). This includes: ``` 7.0 ms — start time .14 ms — record check time for 556-cpi tape (.4 ms for 200-cpi tape; .1 ms for 800-cpi tape) CN ms — record time ``` Therefore, in a tape read operation, processing can take place during 1.96 ms of stop time for 556-cpi tape, 1.7 ms for 200-cpi tape, or 2.0 ms for 800-cpi tape. ### Write During a write operation, the tape adapter unit and the processing unit are interlocked for 7.8 + cn ms (Figure 102). This includes: ``` \begin{array}{l} 5.0~\text{ms} - \text{start time} \\ 2.8~\text{ms} - \text{record check time for 556-cpi and 800-cpi tape} \\ \text{(3.0 ms for 200-cpi tape)} \\ \text{CN ms} - \text{record time} \end{array} ``` Therefore, in a tape write operation, processing can take place during 1.3 ms of stop time for 556-cpi or 800-cpi tape, and 1.1 ms for 200-cpi tape. #### **Nominal Formula** For job timing estimates of tape read and write operations the nominal formula 7.3 + cn ms can be used. #### READ OPERATION #### WRITE OPERATION Figure 102. IBM 729 IV and VI Read-Write Tape Timing ### IBM 7330 Tape Timings #### Read During a 7330 read operation, the tape adapter unit is interlocked for 20.5 + cn ms (Figure 103). This includes: ``` 10.3 ms — start time 9.8 ms — stop time .4 ms — record check time for high-density tape (1.0 ms for low-density tape) CN ms — record time ``` During the same read operation, the processing unit is interlocked for 10.8 + cn ms. This includes: ``` 10.3 ms — start time .1 ms — stop time .4 ms — record check time for high-density tape (1.0 ms for low-density tape) CN ms — record time ``` Therefore, in a tape read operation, processing can take place during 9.7 ms of stop time for 556-cpi tape or 9.1 ms for 200-cpi tape. #### Write During a 7330 write operation, the tape adapter unit is interlocked for 20.3 + cn ms (Figure 103). This includes: ``` 5.0 ms — start time 6.6 ms — stop time 8.7 ms — record check time for high-density tape (9.3 ms for low-density tape) CN ms — record time ``` During the same write operation, the processing unit is interlocked for 13.8 + cn ms. This includes: ``` 5.0 ms — start time .1 ms — stop time 8.7 ms — record check time for high-density tape (9.3 ms for low-density tape) CN ms — record time ``` Therefore, in a tape write operation, processing can take place during 6.5 ms of stop time for 556-cpi tape or 5.9 ms for 200-cpi tape. #### **Nominal Formula** For job time estimates of tape read and write operations, the nominal formula 20.8 + cn ms can be used. Figure 103. IBM 7330 Read-Write Tape Timing # System Features #### **Data Channel 2** The IBM 1410 Data Processing System has one standard data channel (channel 1) for transmitting or receiving information from I/o devices. An additional channel (channel 2) is a special feature that enables a 1410 system to serve many more I/o or auxiliary storage devices with increased efficiency. All units served by either or both channels are shown in the IBM 1410 Configurator, Form A22-6688. A prerequisite for data channel 2 is installation of the processing overlap feature. ### **Processing Overlap** The basic IBM 1410 Data Processing System is interlocked whenever an input-output operation is being performed. No processing can occur because the core storage area is being used during the operation. However, an IBM 1410 having the processing overlap feature allows computing to occur in the system while part of the input-output operation is being performed. While the I/o unit is preparing to send or receive data, the system continues computing. The computing is interrupted only as each individual character is stored in, or sent from, core storage. ## **Processing Overlap Components** The overlap feature necessitates the addition of transmission and controlling circuitry for each affected data channel. Each channel has two single-character registers associated with it. These registers are used as an intermediate storage area during the character-by-character data transfers between the system and the input-output units. The channel 1 registers are called the E1 and E2 registers. The channel 2 registers are called the F1 and F2 registers (Figure 5). Each channel also has a five-character address register associated with it. This address register specifies the core storage location of the character being transferred. The channel 1 register is called the E-address register, and the channel 2 register is called the F-address register. The six I/O channel-status indicators (discussed under "Checking Execution of I/O Instructions") show conditions resulting from overlapped input-output operations, as well as non-overlapped operations. The six indicators on channel 1 are tested with an $\check{\mathbf{R}}$ (I) d instruction, and the six indicators on channel 2 are tested with an $\check{\mathbf{X}}$ (I) d instruction. Each channel has its own overlap-in-process indicator, which can be tested with a conditional branch instruction: $\check{J}$ (I) 1 to ascertain if overlap is in process on channel 1, or $\check{J}$ (I) 2 to ascertain if overlap is in process on channel 2. The indicator (and associated panel light) turn on at the beginning of an overlapped operation and turn off when the operation ends. The indicator is usually tested immediately after the overlapped I/O instruction is given, to ascertain that the operation has not failed to start, and again just before the branch if I/O channel status indicator on instruction is given, to ascertain that the operation has ended. (See "Overlap Operational Considerations.") ### **Overlap Versus Non-Overlap Operations** The operation of any 1/0 device is started by a specific 1/0 instruction, as previously described under "Instructions" and "Input-Output Instructions." The maximum-form 1/0 instruction (Figure 107) consists of 10 positions: an Op code, a B-address, a d-character, and the x-control field. The x-control field always consists of three positions, of which the hundreds (x¹) position specifies which channel will be used and whether the operation is to be executed in the overlap mode. The actual symbols used in the x¹ position, and the channel and overlap status they indicate, are: | SYMBOL | CHANNEL | OPERATION | |--------|-----------|------------------| | % | Channel 1 | non-overlap mode | | @ | Channel 1 | overlap mode | | | Channel 2 | non-overlap mode | | * | Channel 2 | overlap mode | The following exceptions are indicated in the "Alphabetic Listing of 1410 Instructions" (appendix) by the appearance of $x^4$ or $x^5$ in the hundreds position of the x-control field in place of the normal $x^1$ . - 1. Instructions that call for a read or write to end of core cannot be overlapped. If they are written for overlap, the processing overlap is performed, but the end-of-core instruction is automatically changed to a normal read or write; thus the end-of-core results expected are not obtained. (Indicated by $x^5$ .) - 2. Processing overlap does not apply to short-form I/O instructions such as carriage control for the printer or select-stacker for the card reader. It does not apply to the unit control instructions for tape, either, except for the write tape mark instruction. (Where the x-control field exists, indicated by x<sup>5</sup>.) - 3. Read or write console printer operations can be overlapped, but channel 2 is inapplicable. (Indicated by $x^4$ .) In summary, the instructions having an M or L Op code and an $x^1$ (or, for console printer, $x^4$ ) in the hundreds position of the x-control field can be overlapped with processing. These instructions can be readily picked off the list in the appendix. The same notational system is used for the 1410 Instruction Card, Form X22-6740, which includes all the instructions for all 1/0 devices that can be attached to the system. #### Non-Overlap Operation A non-overlapped operation is initated by using the specified symbol in the hundreds position of the x-control field (% for channel 1; $\square$ for channel 2) associated with the input-output instruction. If a non-overlapped tape read operation was being executed on channel 1, the instruction would be M or L %U1 01500 R (as one example) and would be executed as shown in Figure 104. Executing the instruction stops processing completely. Reading and checking a 100-character record from an IBM 729 II at 556 cpi takes 13.1 milliseconds (10.5 milliseconds tape start time + 2.4 milliseconds to read 100 characters + 0.2 millisecond record check time). If the processing of the record takes 15 milliseconds, then the tape is inactive until the record processing is complete. Only one operation can take place at any one time. ### **Overlap Operation** An overlap operation is initated by using the specified symbol in the hundreds position of the x-control field (@ for channel 1; \* for channel 2) associated with the input-output instruction. Once the execution of the overlapped 1/0 instruction is begun, the program is immediately restarted and the program advances to the next instruction in sequence. No other 1/0 unit can be addressed on that channel until the operating 1/0 unit has completed its operation. (See point 1 under "Overlap Error or Stop Conditions," following.) Tape Read Operation: If an overlapped tape-read operation was being executed on channel 1, the instruction would be M or L @U1 01500 R (example), and operation (Figure 105) would take place as follows: - 1. The B-address of 01500 is read into the E-address register and the tape movement starts. (The A- and B-address registers continue being used in the processing that overlaps the tape-read operation.) Processing continues during tape start time. - 2. As soon as the E1 register receives a character from tape, the character is transferred to the E2 register. - 3. At the end of the next processing cycle, processing is suspended for 4.5 microseconds, while the character is transferred from the E2 register to the core-storage position specified by the E-address register. (With the 24-microsecond character rate of the IBM 729 II at 556 cpi there is an average of 19.5 microseconds available for processing before each character is transferred.) - 4. The E-address register is increased by one during the 4.5-microsecond suspension of processing. After the 4.5-microsecond suspension, processing continues. During the reading of this tape record, it is possible to process a previously-read record. If 15 milliseconds of processing time is required, 10.5 milliseconds of processing time can be utilized during the tape start time. The remaining 4.5 milliseconds of required processing time is overlapped by 4.5 microseconds for tape-character transfer each time a character is read into core storage. Therefore, the available processing time during an overlap operation is reduced by N × 4.5 Figure 104. Non-Overlap Tape Read Operation Figure 105. Overlap Tape Read Operation total processing time during the 100 intervals (19.5 microseconds each) before the tape-character transfers is 1950 microseconds. (If the system has the 1410 Accelerator feature, read-in time is reduced to 4.0 microseconds; accordingly, the average interval before a character transfer increases to 20 microseconds.) At the end of the tape-record transfer, tape stop requires 2.1 milliseconds. Processing continues during all of tape stop time, including the record-check portion. At the end of tape stop time, 0.45 millisecond is still needed to finish processing the previous record. At the completion of the overlap operation, the E-address register contains the address that is two positions to the right of the last core-storage position into which a data character was read. (It is two, rather than one, because it is necessary to read out the next position in order to check for a group-mark — word-mark at the end of the record area in core storage. This check for a $\frac{\star}{4}$ causes EAR to step twice after the last character in the record is serviced.) Tape Write Operation: Overlapping a tape-write operation is similar to a tape-read operation. Processing is suspended 4.5 microseconds every time a character is transferred from core storage to the E register. (The E-address register contains the core-storage location of the character transferred.) The character is transferred from the E1 register to the E2 register and then to tape during processing. Each character read out of core storage requires a 4.5-microsecond cycle. Therefore, the available processing time during an overlap operation is reduced by N $\times$ 4.5 microseconds, where N is the number of characters transferred. Available processing time is further reduced by the suspension of processing (for tapewrite only) during record-check time. If the system has the 1410 Accelerator feature, processing is *not* suspended during record-check time; also, read-out time is reduced to 4.0 microseconds per character. At the end of the overlap operation, the E-address register contains the address that is two positions to the right of the last core-storage position out of which a data character was read. Tape Read and Write Operation: A combination tape-read and write operation (Figure 106) makes use of both channels, and permits the overlapping of reading, writing, and processing. Each channel operates independently, and operation of either channel requires suspension of processing as soon as the processing cycle has ended. Maximum processing delay before yielding control is 11.25 microseconds. Channel control alternates between the two channels. If both channels seek control at the same time, channel 1 automatically assumes priority. Note: The available processing time between each character transfer should be considered as utilized 100%, even though the time is not an exact multiple of a core storage cycle. For example, an overlapped channel 1 tape-read operation (Figure 105) had a process time between character transfers that averaged 19.5 microseconds. Because the average characters for IBM 729 II high-density tapes vary from 21-27 microseconds, the available overlapped process time then varies from 16.5-22.5 microseconds. A basic process cycle point is .75 microseconds, and a process cycle (4.5 microseconds in length = 6 cycle points $\times$ .75 microseconds) can begin immediately after a character transfer is completed. If the available process time is 15 microseconds, three complete process cycles are completed in 13.5 microseconds. Because the system has no indication that the next tape character will Figure 106. Overlap Tape Read and Write Operation be available in 1.5 microseconds, another process cycle is executed. This delays the next tape character transfer by 3 microseconds; however, because each tape character passes serially through the E1 and E2 registers, it gives the channel the facility to temporarily get a character behind during the data transfer. This 3-microsecond delay is regained by picking up 1.5 microseconds on the next two tape character transfer cycles. In this way, the available process time is fully utilized. Overlap Error or Stop Conditions: The error or stop conditions that can occur during an overlap operation are: - 1. An I/o instruction, encountered before the physical completion of a previous I/o operation on the same channel, causes (1) a system stop, if the intervening status test was not programmed, or (2) a failure of the second I/o instruction to be executed (Figure 40), if the status test was programmed but the status indications were ignored by the program. Only one I/O device can be operated per channel at any given time, whether or not the overlap mode is used. - 2. A processing unit error, occurring during an overlapped tape operation, causes a system stop. The transmission of data to or from the tape unit is stopped when the system stops, and an incomplete block will be written on tape, or less than an entire block will be read into core storage. 3. A programmed stop or a console stop, occurring during an overlapped input-output unit operation, causes processing to stop, but the I/O unit continues until the data transfer is completed. Any restart procedure that is used must include a branch if any I/O channel status indicator on instruction so that the status test is satisfied before the next I/O instruction is encountered. The status test can also be satisfied by an X-or Ř (I) d instruction that results in a branch. # **Overlap Operational Considerations** Operational considerations during an overlapped operation are: - 1. An overlapped I/O instruction executed on an IBM 1410 Data Processing System without the overlap feature causes the system to stop. - 2. The B-field of both an overlapped and a non-overlapped I/O instruction can be indexed. - 3. On a 1410 system equipped with both channels and the overlap feature, read/write/processing, read/read/processing, or write/write/processing is possible, except for 1/0 instructions containing d-characters of \$ or X, which must always be programmed in the non-overlap mode. (If programmed in the overlap mode, they will be executed as normal read or write instructions and stop at the first $\stackrel{\checkmark}{=}$ .) 4. Processing overlap does not apply to $\mathring{\mathbf{U}}\mathbf{x}^5\mathbf{x}^2\mathbf{x}^3\mathbf{d}$ instructions, or other short-form 1/0 instructions such as $\mathring{\mathbf{F}}$ d or $\mathring{\mathbf{4}}$ d, because no data processing is involved. The 1410 system is free to continue processing during the time required to execute such 1/0 control instructions, and the 1/0 device involved in the operation is released by the system as soon as the operation is under way. The status test is still required, however, and no two 1/0 devices can be operated simultaneously on the same channel. The write tape mark instruction, $\mathring{\mathbf{U}} x^1 x^2 x^3 M$ , is the only short-form I/O instruction that can be overlapped. No datum is transferred from core storage to tape, but a following $\mathring{\mathbf{J}}$ (I) 1 or 2 will, nevertheless, indicate that overlap is in process. The reason: the same circuits are set up for a write tape mark as for an $\mathring{\mathbf{M}}$ or $\mathring{\mathbf{L}}$ I/O instruction having a zero-length data field; thus, overlapping the $\mathring{\mathbf{U}}$ (X) M saves considerable program time by eliminating any interruption of processing during the tape start. If any other short-form I/O instruction is programmed for overlap mode, operation is the same as in non-overlap mode. - 5. If the console I/O printer is operated in the inquiry mode on channel 1, the operation is the same as in the non-overlapped mode except that the program continues to be overlapped with the inquiry operation. The channel 1 overlap-in-process indicator remains on until the operator presses either the cancel or the release key. - 6. In overlap operations, it is possible for the branch if I/O channel status indicator on instruction to be encountered in the program before the end of an associated 1/0 data transfer. In that case, processing is suspended until the associated 1/0 data transfer is complete. (If processing was not suspended, any 1/0 channel status indicator turned on after the R (I) d or X (I) d instruction was executed would not be detected before it was turned off by the next 1/0 operation. The processing is suspended, however, and the status test remains effective for any indicator turned on after the K or X instruction is encountered.) A fully overlapped 1/0 operation can be maintained if the R or X instruction is not issued until after the overlap-in-process indicator is tested with a J (I) 1 or J (I) 2 instruction. If a branch does not result from the branch if overlap in process instruction, the 1/o operation is proved to be complete and the K or X instruction may then be issued without risk of converting the remainder of that operation to non-overlap mode. The usual effect on the program of this overlap consideration (to which 1/o-device timing considerations must be added) is that the status test is made just prior to the next 1/0 instruction. - A J (I) 1 or J (I) 2 instruction can also be given immediately after the 1/0 instruction, to detect a failure of the 1/0 operation to begin (tape unit rewinding, previous line still being printed, buffer being filled from card reader, card punch out of cards, etc.). - 7. In overlapped tape-write operations, processing is suspended during the record-check time (see "Tape Timing Considerations") unless the 1410 Accelerator feature is installed. Processing continues, however, during the record-check time of any overlapped taperead operations. - 8. Both channels can operate in overlap mode, or both can operate in non-overlap mode, but one channel can not operate in overlap mode while the other is operating in non-overlap mode. If a non-overlap operation is initiated on one channel while the other channel is busy with an overlapped operation, the remainder of the overlapped operation is automatically converted to non-overlap mode. If an overlap operation is initiated while the other channel is busy with a non-overlapped operation, both operations are performed in non-overlap mode. #### 1410 Accelerator ADD (ONE FIELD) page 17 The 1410 Accelerator, an optional feature, increases the speed of the IBM 1410 Data Processing System by reducing the memory cycle from 4.5 microseconds to 4.0 microseconds and reducing the cycle length of data operations. Any 1410 system configuration adding this feature becomes significantly faster. The internal speed-up is about 23%, resulting in an increase of 15% to 23% in the data throughput. The acceleration of internal speed and throughput is accomplished by making changes in the 1411 Processing Unit. The accelerated system is otherwise identical to the unchanged system. All instructions and I/O devices operate the same; however, the feature creates the new timing formulas and improved timings that follow: ``` Timing: T = 4 (L + 1 + 2A). L = 1 or 6. ADD (TWO FIELDS) page 17 Timing: T = 4 (L + 1 + E + A + B + RB). When L = 1, E = 1; when L = 11, E = 0. BACKSPACE TAPE (See UNIT CONTROL) BRANCH CONDITIONALLY (ONE ADDRESS) page 36 Includes BRANCH IF ARITHMETIC OVERFLOW BRANCH IF CARRIAGE 9 BRANCH IF CARRIAGE BUSY BRANCH IF CARRIAGE OVERFLOW BRANCH IF COMPARE EQUAL (or high, low, unequal) BRANCH IF DIVIDE OVERFLOW BRANCH IF INQUIRY REQUEST ``` BRANCH IF OVERLAP IN PROCESS BRANCH IF TAPE INDICATOR (for CE use) BRANCH IF ZERO BALANCE Any one-address conditional branch instruction described in feature bulletins and other separate publications. Timing: T = 4 (L + 1 + C). BRANCH IF BIT EQUAL page 38 Timing: T = 4 (L + 2.5 + C). L = 1.6 or 12 BRANCH IF CHARACTER EQUAL page 38 Timing: T = 4 (L + 2.5 + C). L = 1, 6, or 12. BRANCH IF I/O CHANNEL STATUS INDICATOR ON page 37 Timing: T = 4 (L + 1 + C). L = 7. BRANCH IF WORD MARK PRESENT, OR ZONE EQUAL page 38 Timing: T = 4 (L + 2.5 + C). L = 1, 6, or 12. BRANCH UNCONDITIONALLY page 36 Timing: T = 4 (L + 2)L = 1 or 7. CARRIAGE CONTROL page 81 Timing: T = 12. CLEAR STORAGE page 23 Timing: T = 4 (L + 1 + B). L = 1 or 6. CLEAR STORAGE AND BRANCH page 23 Timing: T = 4 (L + 2 + B). L = 11. CLEAR WORD MARK page 22 Timing: T = 4 (L + 4). L = 1, 6, or 11. COMPARE page 28 Timing: T = 4 (L + 1 + A + B). L = 1, 6, or 11. DATA MOVE ( See MOVE DATA ) DIVIDE page 20 Timing: T = 4 [L + 1 + E + 6.5Q (2A + 2)].L = 1, 6, or 11. наст page 23 Timing: T = 4. HALT AND BRANCH page 23 Timing: T = 32. INDEXING OPERATIONS page 14 Timing: T = 30.67 for each single address indexed. LOOKUP - - - ( see TABLE LOOKUP ) MOVE CHARACTERS AND EDIT page 31 Timing: T = 4 (L + 1 + A + 1.5B + 1.5Z + 1.5D). L = 1, 6, or 11. MOVE CHARACTERS AND SUPPRESS ZEROS page 27 Timing: T = 4 (L + 1 + 4A). L = 1, 6, or 11. MOVE DATA page 25 Timing: T = 4 (L + 1 + A + B). L = 1, 6, or 12. MOVE TAPE ONE RECORD WITHOUT READING (see UNIT CONTROL) миллирых page 19 Timing: T = 4 [L + 1 + E + 2M + (2.5M + 1) (2A + 2)].L = 1, 6, or 11. NO OPERATION page 24 Timing: T = 4 (L + 1). $L = 1, 2, 3 \dots$ no limit. PUNCH A CARD\* page 63 Timing: T = 44 + I/O. READ A CARD\* page 62 Timing: T = 44 + I/O. READ CONSOLE PRINTER page 47 Timing: T = 44 + I/O. READ OR WRITE TAPE † page 86 Timing: T = .0040 (L + 1) + Tm ms. read or write tape with word marks† page 87 Timing: T = .0040 (L + 1) + Tm ms. REWIND (see UNIT CONTROL) REWIND AND UNLOAD (see UNIT CONTROL) SCAN DATA ( See MOVE DATA ) SELECT STACKER AND FEED\* page 62 Timing: T = 12 + I/O. SET WORD MARK page 22 Timing: T = 4 (L + 4). L = 1, 6, or 11. SKIP AND BLANK TAPE ( See UNIT CONTROL ) STORE ADDRESS REGISTER page 22 Timing: T = 4 (L + 8.5) = 62 microseconds. Note: This instruction cannot be indexed. SUBTRACT (ONE FIELD) page 18 Timing: T = 4 (L + 1 + 2A). SUBTRACT (TWO FIELDS) page 17 Timing: T = 4 (L + 1 + E + A + B + RB). When L = 1, E = 1; when L = 11, E = 0. TABLE LOOKUP page 30 Timing: T = 4 (L + 1 + B + NA). $\hat{L} = 1, 6, \text{ or } 12.$ UNIT CONTROL† page 85 Timing: T = .0040 (L + 1) + Tm ms. WRITE A LINE (1403) page 80 Timing: T = 44 + I/O. WRITE A LINE, WM CREATE BLANKS IN PRINTING (see write a line) WRITE CONSOLE PRINTER page 47 Timing: T = 44 + I/O. WRITE TAPE ( see READ OR WRITE TAPE ) WRITE TAPE MARK (see UNIT CONTROL) WRITE WORD MARKS AS 1's page 80 Timing: T = 44 + I/O. ZERO AND ADD (ONE FIELD) page 18 Timing: T = 4 (L + 1 + 2A). L = 1 or 6.ZERO AND ADD (TWO FIELDS) page 18 Timing: T = 4 (L + 1 + E + A + B). When L = 1, E = 1; when L = 11, E = 0. ZERO AND SUBTRACT (ONE FIELD) page 19 Timing: T = 4 (L + 1 + 2A). L = 1 or 6.ZERO AND SUBTRACT (TWO FIELDS) page 18 Timing: T = 4 (L + 1 + E + A + B). When L = 1, E = 1; when L = 11, E = 0. \* For I/O see "Timing Considerations for 1402." † For Tm ms see "Timing Considerations for Tape Units." ‡ For I/O see "Timing Considerations for 1403." ## IBM 1401-1410 Compatibility The IBM 1410 Data Processing System will run many programs originally written for the IBM 1401 Data Processing System. Standard 1401 system units (1401, 1402, 1403, 1405, 729, 7330) and many 1401 system special features are fully utilized by a 1410 system operating in the 1401 mode. These 1401 features are: - 1. Additional Storage (10K 1410 system operates as an 8K 1401 system; all other 1410 systems operate as a 16K 1401 system) - 2. Multiply-Divide - 3. Expanded Print Edit - 4. Advanced Programming (includes Indexing, Store Address Register, and Move Record) - 5. Print Storage - 6. High-Low-Equal Compare - 7. Read-Punch Release - 8. Sense Switches Differences in 1401 and 1410 system operation may entail some 1401 program modification before 1401 programs can be run on the 1410 system. The extent of program compatibility can best be defined by noting the differences between the two systems. ### **Special Features** The 1410 is not compatible with a 1401 program that makes use of the following special features: - 1. Column Binary Feature - 2. Compressed Tape Feature - 3. Punch Feed Read Feature - 4. Serial 1/0 Adapter, including provisions for attaching the following units: - а. івм 1009 Data Transmission Unit - b. IBM 1011 Paper Tape Reader - с. IBM 1012 Paper Tape Punch - d. IBM 1412 Magnetic Character Reader - е. вым 1418 Optical Character Reader - f. вым 1419 Magnetic Character Reader - 5. Process Overlap Feature - 6. Selective Tape Listing Feature - 7. Space Suppression Feature ### **Processing** # **Input Characters Having Incorrect Parity** The 1401 system corrects any input character of incorrect parity by adding or removing the C bit, forcing the character valid. The 1410 system inserts an asterisk (\*) in core storage in place of all input characters having incorrect parity. ### **Quotient Blanks** On a 1401 system divide operation, if the B field initially contained blanks, and if the resulting quotient is zero, the blanks remain in the quotient. A 1410 system operating in the 1401 mode converts all blanks of this type to zeros. #### **Magnetic Tape Operations** #### Loading Tape Units On the 1401, it is possible to load a tape reel by pressing the reset, load rewind, and start keys in rapid succession. The program can then be started immediately (though this is not recommended); if it addresses the tape unit before tape loading has been completed, the program will wait until the tape is fully loaded and then proceed. On the 1410 operating in 1401 mode, the identical procedure, and premature tape addressing, will prevent the tape drive from starting. Operations cannot continue until the console stop key is pressed, an address-set is made on the instruction to that tape unit, and the console start key is pressed. To avoid this condition, simply do not press the tape unit start key until the loading operation has been completed. Also, no problem will occur if the program is halted at a halt instruction and the program is not started, by pressing the console start key, until the tape load operation is completed. #### Read and Write Tape with Word Marks When writing on tape in the load mode, if a word separator is encountered in core storage, the 1401 will write one word separator on tape, but the 1410 will write two word separators on tape. When reading tape in the load mode on the 1401, any number (one or more) of word separators read in succession from tape are eliminated and a word mark is placed over the first non-word separator character that follows the word separators. When reading tape in the load mode on the 1410, a pair of adjacent word separators on tape are read into core storage as one word separator and no word mark is placed over the next non-word separator character. ### **Card and Print Operations** ### **B-Address Register** At the completion of a card or print operation, the setting of the B-address register will be different on a 1401 than on a 1410 operating in the 1401 mode. The following chart shows a comparison of the B-address register contents at the completion of the specified operation: | | B-ADDRESS REGISTER | B-ADDRESS REGISTER | |---------------------|--------------------|---------------------| | 1401 OP CODE | or 1401 | of 1410 (1401 mode) | | 1 (Read) | 081 | 082 | | 2 (Print) | 333* | 335 | | 3 (Read and Print) | 081 | 082 | | 4 (Punch) | 181 | 183 | | 5 (Read and Punch) | 181 | 183 | | 6 (Print and Punch) | 181 | 183 | | 7 (Read, Print, and | | | | Punch) | 181 | 183 | <sup>\*335</sup> for an unbuffered printer. ### **Card Read-Punch Character Set** The 1410 system punches on A bit in core storage (b, formerly ¢) as an 8-2 combination in a card column and reads an 8-2 combination in a card column as an A bit. The 1401 system punches an A bit in core storage as a zero in a card column and reads an 8-2 combination in a card column as an invalid character. A no-charge RPQ (898148) makes the 1401 operate as described for the 1410. #### **Card Read-Punch Operations** The 1401 puts a "set-up" character in core storage after a read or punch instruction. A punch instruction leaves a zero in core storage position 100 and any read instruction leaves an ampersand (&) in core storage position 000. A 1410 system operating in the 1401 mode does not do this. Cards punched with an MLP (multiple line printing) code can be read by the 1401 system but cause a validity check in the 1402 Card Read Punch used with the 1410 system. The effect depends on the mode: in the 1401 mode, the validity check is recognized as a reader check by the 1411; in the 1410 mode, the validity check sets the data check channel status indicator. The 1401 resets the "end of file" condition on the 1402, when a new deck of cards is run in. The 1410 does *not* reset the "end of file" condition on the 1402, when a new deck of cards is run in. The only way to reset the "end of file" condition on a 1410 operating in 1401 mode is with a Computer Reset. Because of the read buffer in the 1414, the card image read into core storage by a read instruction always lags a card cycle behind the one being read at the 1402. The validity and reader check lights at the 1402, if turned on to indicate an error, are turned off as the next feed starts; and that feed starts automatically, just after the buffer is emptied. The 1/0 check stop switch, if turned on, causes an error stop on an invalid data transfer to core storage, but not on the previous cycle when the data were fed from the 1402 into the buffer. Together, the preceding facts mean that, in 1401 mode, the operator cannot tell by looking at the lights on the card reader, as he can with the 1401 system, whether an error in card reading initiated the error stop. If the 1402 lights turned on, the data check (1/0 channel status) indicator at the 1415 console will turn on as the card image is transferred to core storage by the next read a card instruction; however, by that time the 1402 lights will have been turned out (assuming that the next card fed was valid). The operator must check the stop-on-error typeout to learn that the card reader was selected at the time of the error. The error card is always the top card in the NR pocket (for punch, NP pocket). If the operator wants to rerun the error card (or to substitute a corrected card) in its original sequence and thus avoid processing any information read in error, the procedure is: - 1. Run out the cards in the 1402 and place them on top of the stack in the read hopper, with the repeated (or corrected) card uppermost. - 2. Operate and release the 1401 1/0 check-reset switch. - 3. Press the start key on the 1402. - 4. Restart the program at the read instruction that resulted in the error stop. (See "Address Set.") #### **Card Movement and Position** Because the 1410 makes use of a buffer on data transfers between core storage and the card reader or punch, the 1401 read release and punch release instructions do not cause actual card-feed motion on the 1410 system operating in the 1401 mode. Following a system stop operation, the position of the cards in the hoppers and stackers of an IBM 1402 may not be the same in a 1410 system as they are in a 1401 system. #### **Card Stacker Selection** In a 1401 system, about 10 milliseconds of computer time are available at the end of a card read for starting a stacker select operation. For a 1410 operating in the 1401 mode, the amount of time available to start a stacker select operation may vary from 8 to 82 milliseconds. No incompatibilities arise unless: - 1. The program between the read and stack instructions takes longer (up to 2 milliseconds possible) than the time available on the 1410 system. This results in a stack instruction that is effective on a 1401 system but is too late to be effective on a 1410 system. Because of the faster internal processing of a 1410, this result is unlikely. - 2. A stack instruction in a 1401 program is effective on a 1410 system but is too late to be effective on a 1401 system. Because the 1410 has faster internal processing and usually has a longer available time to start a stack instruction, this problem may result if 1401 programs are tested and debugged on a 1410 system in 1401 mode. In a 1401 system, a stacker can be selected even after a reader error. With a 1410 operating in the 1401 mode, a stacker cannot be selected after a reader error. #### 51-Column Cards When the 51-column read feed feature is installed on the 1402, and 51-column cards are being read in either the move or load mode, the card data are always read into core storage locations 15 through 65. The 1401 leaves the storage locations 1 through 14 and 66 through 80 undisturbed. In the 1401 mode of the 1410 system, however, the positions 1 through 14 and 66 through 80 in the read buffer are filled with valid blanks, and these blanks are transferred\* as blanks to the same core storage positions. Consequently, the program must not place data in those locations, or must move it elsewhere in core storage before a card is read. #### **Printer Carriage Controls** A 1401 system will not execute an immediate skip to channel X when the carriage is already at that channel, but a 1410 operating in the 1401 mode will execute the instruction by moving to the next punch of that same channel number. When the end-of-forms light on the 1403 is on, the 1410, in either mode, prints a line each time the single-cycle key on the 1403 is pressed. The 1401 operates the same way, except that the 1403 interlocks as soon as a 1 punch is sensed in the carriage tape. If the 1401 is running, it stops when the single-cycle key is pressed; then it prints a line each time the key is pressed again. If the 1410 is running, in either mode, the single-cycle key is disabled. To print single lines with the 1410 system, first press the stop key at the console; then the 1410 prints a line each time the single-cycle key is pressed. #### Single Character Edit If the specified A-field in an edit operation contains a word mark in the units position (a single-character field), the 1401 system will not transfer this single-character field to the B-field. The 1410 will transfer and edit the single-character field. # **Disk Storage Operation** At the end of an IBM 1311 Disk Storage operation that is done on the 1410 in 1401 mode, the address in BAR is at least one greater than at the end of the same operation performed on the 1401 system. <sup>\*</sup>In the 1410 mode, only the 51 active positions are transferred from buffer to storage, and a \( \begin{array}{l} \ is needed in the 52nd position of the read-in area. In the 1401 mode, all 80 positions, including blanks, are transferred, and no \( \begin{array}{l} \ is required. \end{array} # Alphabetic Listing of Instructions in This Manual (Indexed) Note: Any special symbols under Autocoder and ACTUAL columns are explained in Figure 107. | INSTRUCTION | AUTOCODER | ACTUAL | PAGE | |-----------------------------------------------------------------------------------------------------------|------------|--------------------------------------------------------------------------------|------| | Add (One Field) | A a | Å (A) | 17 | | Add (Two Fields) | | × (A) (B) | 17 | | Add (Two Floras) | | V | | | Backspace Tape | BSP cu | $\overset{V}{\mathbf{U}} \mathbf{x}^5 \mathbf{x}^2 \mathbf{x}^3 \mathbf{B}$ | 85 | | Branch if Arithmetic Overflow | BAV i | j (I) Z | 36 | | Branch if Bit Equal (any bit in b matches a bit in d) | BBE i,b,d | W (I) (B) x | 38 | | Branch if Carriage Busy (Ch 1) | BPCB(#) i | Ϋ́ (I) R | 36 | | Branch if Carriage Busy (Ch 2) | BPCB2 i | j (I) L | 36 | | Branch if Carriage 9 (Ch 1) | BC9(#) i | j (I) 9 | 36 | | Branch if Carriage 9 (Ch 2) | BC92 i | <u>j</u> (I) ! | 36 | | Branch if Carriage Overflow, 12 (Ch 1) | BCV(#) i | ў (I) @ | 36 | | Branch if Carriage Overflow, 12 (Ch 2) | BCV2 i | Ĵ(I) □ | 36 | | Branch if Any 1/0 Channel Status Indicator On (Ch 1) | BA1 i | Ř (I) ‡ | 37 | | Branch if Any 1/0 Channel Status Indicator On (Ch 2) | BA2 i | X (I) ≢ | 37 | | Branch if I/O Unit Not Ready (Ch 1 or 2) | BNR# i | $\check{\mathbf{R}}$ or $\check{\mathbf{X}}$ (I) 1 | 37 | | Branch if 1/0 Unit Busy (Ch 1 or 2) | BCB# i | $\ddot{\mathbf{R}}$ or $\ddot{\mathbf{X}}$ (I) 2 | 37 | | Branch if I/O Unit Data Check (Ch 1 or 2) | BER# i | $\overset{\mathbf{V}}{\mathbf{R}}$ or $\overset{\mathbf{V}}{\mathbf{X}}$ (I) 4 | 37 | | Branch if 1/0 Unit Condition (Ch 1 or 2) | | $\overset{V}{\mathbf{R}}$ or $\overset{V}{\mathbf{X}}$ (I) 8 | 37 | | Branch if 1/0 Wrong Length Record (Ch 1 or 2) | BWL# i | Ř or X (I) – | 37 | | Branch if 1/0 Unit No Transfer (Ch 1 or 2) | BNT# i | Ř or X (I) B | 37 | | Branch if Any On in Plural Indicator Test (by d-char of more than one but less than all bits, such as ##) | BEX# i,d | $reve{R}$ or $reve{X}$ (I) x | 37 | | Branch if Character Equal (b = d) | BCE i,b,d | $\overset{V}{\mathbf{B}}$ (I) (B) x | 38 | | Branch if Compare Equal | | Ϋ́ (I) S | 36 | | Branch if Compare High (B greater than A) | | Ϋ́ (Ι) U | 36 | | Branch if Compare Low (B less than A) | | Ϋ́ (Ι) Τ | 36 | | Branch if Compare Unequal | | ў (I) / | 36 | | Branch if Divide Overflow | | Ϋ́ (Ι) W | 36 | | Branch if Inquiry Request (Ch 1) | BNQ(#) i | Ϋ́(I) Q | 36 | | Branch if Inquiry Request (Ch 2) | BNQ2 i | ў(I) * | 36 | | Branch if Overlap in Process (Ch 1) | BOL1 i | ў (I) 1 | 36 | | Branch if Overlap in Process (Ch 2) | BOL2 i | J (I) 2 | 36 | | Branch if Tape Indicator (for ce use) | | j̈(Ι) Κ | 36 | | Branch if Zero Balance | BZ i | Ϋ́(Ι) V | 36 | | Branch if wm Present | | <b>V</b> (I) (B) 1 | 39 | | Branch if wm Present, or Zone Bits Absent | BWZ i,b | <b>v</b> (I) (B) 3 | 39 | | Branch if wm Present, or Zone Equal A | BWZ i,b,A | ў (I) (В) Т | 39 | | Branch if wm Present, or Zone Equal AB | BWZ i,b,AB | $\overset{\mathbf{v}}{\mathbf{V}}$ (I) (B) C | 39 | | Branch if wm Present, or Zone Equal B | BWZ i,b,B | V (I) (B) L | 39 | | Branch if Zone Bits Absent | BZN i,b | <b>V</b> (I) (B) 2 | 39 | | INSTRUCTION | AUTOCODER | ACTUAL | PAGE | |--------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------|------| | Branch if Zone Equal A | BZN ib A | У (I) (В) S | 20 | | Branch if one Equal AB | | V (I) (B) B | 39 | | Branch if Zone Equal B | BZN ibB | V (1) (B) B<br>V (1) (B) K | 39 | | Branch Unconditionally | B : | V | 39 | | | | J (I) blank | 36 | | Carriage Control Immediate Skip to 1(Ch 1 or 2) | CC(#) 1 | $\overset{v}{F}$ or $\overset{v}{2}$ 1 | 81 | | Carriage Control Immediate Skip to 2 (Ch 1 or 2) | | $\overset{v}{\mathrm{F}}$ or $\overset{v}{2}$ 2 | 81 | | Carriage Control Immediate Skip to (3-10) (Ch 1 or 2) | CC(#) (3-0) | $\overset{v}{\mathbf{F}}$ or $\overset{v}{2}$ 3-0 | 81 | | Carriage Control Immediate Skip to 11 (Ch 1 or 2) | CC(#) # | Forž# | 81 | | Carriage Control Immediate Skip to 12 (Ch 1 or 2) | CC(#) @ | $\overset{v}{\mathrm{F}} \text{ or } \overset{v}{2} \overset{"}{@}$ | 81 | | Carriage Control Immediate 1 Space (Ch 1 or 2) | CC(#) J | F or Ž J | 81 | | Carriage Control Immediate 2 Spaces (Ch 1 or 2) | CC(#) K | řorž K | 81 | | Carriage Control Immediate 3 Spaces (Ch 1 or 2) | | F or Ž L | 81 | | Carriage Control Skip After Print to (1-5) (Ch 1 or 2) | | F or 2 A-E | 81 | | Carriage Control Skip After Print to (6-7) (Ch 1 or 2) | CC(#) (F-G) | F or Ž F-G | 81 | | Carriage Control Skip After Print to (8-9) (Ch 1 or 2) | CC(#) (H-I) | For 2 H-I | 81 | | Carriage Control Skip After Print to 10 (Ch 1 or 2) | | $\overset{\circ}{F}$ or $\overset{\circ}{2}$ ? | 81 | | Carriage Control Skip After Print to 11 (Ch 1 or 2) | | $\overset{\circ}{F}$ or $\overset{\circ}{2}$ . | 81 | | Carriage Control Skip After Print to 12 (Ch 1 or 2) | | For Ž □ | | | Carriage Control 1 Space After Print (Ch 1 or 2) | CC(#) / | For 2 / | 81 | | Carriage Control 2 Spaces After Print (Ch 1 or 2) | CC(#) \$ | For 2 S | 81 | | Carriage Control 3 Spaces After Print (Ch 1 or 2) | CC(#) T | For 2 T | 81 | | Clear Storage | CS b | Y (B) | 81 | | Clear Storage and Branch | | /(В)<br>/(I)(В) | 23 | | Clear Word Mark (One Address) | CW o | V | 23 | | Clear Word Mark (Two Addresses) | CW ab | □ (A)<br>□ (A) (B) | 22 | | Compare (b to a) | | $\Box (A) (B)$ | 22 | | | C a,b | C(A)(B) | 28 | | Data Move (see Move) | Mxxxx a,b | Ď (А) (В) х | 25 | | Divide (a into b) | D a,b | % (A) (B) | 20 | | | | | | | Erase Forward (Skip and Blank Tape) | SKP cu | $\overset{\mathbf{V}}{\mathbf{U}} \ \mathbf{x}^{5}\mathbf{x}^{2}\mathbf{x}^{3} \ \mathbf{E}$ | 85 | | Halt | 11 | · | | | Halt and Branch | H | • | 23 | | | пі | <b>'</b> (I) | 23 | | Lookup Equal | LE a,b | <b>Y</b> (A) (B) 2 | 30 | | Lookup Equal or High | LEH a,b | Ť (A) (B) 6 | 30 | | Lookup High | LH a,b | Ť (A) (B) 4 | 30 | | Lookup Low | LL a,b | Ť (A) (B) 1 | 30 | | Lookup Low or Equal | LLE a,b | Ť (A) (B) 3 | 30 | | Lookup Low or High | LLH a,b | Ť (A) (B) 5 | 30 | | Lookup to Any | | Ť (A) (B) 7 | 30 | | Lookup to End | | Ť (A) (B) blank | 30 | | | | v | | | | MCE a,b | <b>E</b> (A) (B) | 31 | | Move Left Characters and Suppress Zeros | | Ž (A) (B) | 28 | | Move Left Characters and wm Single Position | MLCWS a,b | Ď (A) (B) 7 | 25 | | Move Left Characters and wm thru 1st A-Field wm | MLCWA a,b | Ď (A) (B) X | 25 | | Move Left Characters and wm thru 1st B-Field wm | MLCWB a,b | Ď (A) (B) P | 25 | | INSTRUCTION | AUTOCODER | ACTUAL | PAGE | |------------------------------------------------------------------------------------|----------------------|-------------------------------------------------------------------|----------| | Move Left Characters and wm thru 1st wm | MLCW a,b | $\overset{V}{\mathrm{D}}$ (A) (B) G | 25 | | Move Left Characters Single Position | MLCS a,b | Ď (A) (B) 3 | 25 | | Move Left Characters thu 1st A-Field wm | MLCA a,b | Ď (A) (B) T | 25 | | Move Left Characters thru 1st B-Field wm | MLCB a,b | $\overset{v}{\mathrm{D}}$ (A) (B) L | 25 | | Move Left Characters thru 1st wm | MLC a,b | $\overset{v}{\mathbf{D}}$ (A) (B) C | 25 | | Move Left Numeric and wm Single Position | MLNWS a,b | Ď(A)(B)5 | 25 | | Move Left Numeric and wm thru 1st A-Field wm | MLNWA a,b | Ď (A) (B) V | 25 | | Move Left Numeric and wm thru 1st B-Field wm | MLNWB a,b | Ď (A) (B) N | 25 | | Move Left Numeric and wm thru 1st wm | | ў (A) (В) Е | 25 | | Move Left Numeric Single Position | | Ď (A) (B) 1 | 25 | | Move Left Numeric thru 1st A-Field wm | | Ď (A) (B) / | 25 | | Move Left Numeric thru 1st B-Field wm | | Ď (A) (B) J | 25 | | Move Left Numeric thru 1st wm | | Ď (A) (B) A | 25 | | Move Left wm Single Position | • | Ď (A) (B) 4 | 25 | | Move Left wm thru 1st A-Field wm | _ | $\overset{\circ}{\mathrm{D}}$ (A) (B) U | 25 | | Move Left wm thru 1st B-Field wm | , | $\overset{\circ}{\mathrm{D}}$ (A) (B) M | 25 | | Move Left wm thru 1st wm | | $\overset{\circ}{D}(A)(B)D$ | 25 | | Move Left Zones and wm Single Position | • | Ď (A) (B) 6 | 25<br>25 | | Move Left Zones and wm Shigle Fosition Move Left Zones and wm thru 1st A-Field wm | | $\overset{\checkmark}{D}(A)(B)W$ | 25 | | Move Left Zones and wm thru 1st A-Field wm | | $\overset{\circ}{\mathrm{D}}$ (A) (B) O | 25<br>25 | | | _ ' | $\overset{\circ}{\mathrm{D}}(\mathrm{A})(\mathrm{B})\mathrm{F}$ | 25<br>25 | | Move Left Zones and wm thru 1st wm | MLZW a,b<br>MLZS a,b | $\overset{\vee}{\mathrm{D}}$ (A) (B) 2 | 25<br>25 | | Move Left Zones Single Position. | | $\overset{\vee}{\mathrm{D}}$ (A) (B) S | 25<br>25 | | Move Left Zones thru 1st A-Field wm | | v | | | Move Left Zones thru 1st B-Field wm | , | $\dot{D}(A)(B)K$ | 25 | | Move Left Zones thru 1st wm | | $\dot{D}(A)(B)B$ | 25 | | Move Right Characters and wm thru 1st A-Field ‡ | | $\dot{\mathbf{D}}(\mathbf{A})(\mathbf{B}) \Delta$ | 25 | | Move Right Characters and wm thru 1st A-Field ‡ | | Ď (A) (B) ## | 25 | | Move Right Characters and wm thru 1st A-Field ‡ or ‡ | | $\dot{\mathbf{D}}(\mathbf{A})(\mathbf{B}) \neq \ddot{\mathbf{A}}$ | 25 | | Move Right Characters and wm thru 1st wm | | $\dot{\mathbf{D}}$ (A) (B) $\vee$ | 25 | | Move Right Characters thru 1st A-Field # | | $\overset{\circ}{D}(A)(B)$ \$ | 25 | | Move Right Characters thru 1st A-Field ‡ | | $\overset{\bullet}{D}(A)(B),$ | 25 | | Move Right Characters thru 1st A-Field ‡ or ‡ | MRCM a,b | Ď (A) (B). | 25 | | Move Right Characters thru 1st wm | MRC a,b | Ď (A) (B) # | 25 | | Move Right Numeric and wm thru 1st A-Field ‡ | | D(A)(B) | 25 | | Move Right Numeric and wm thru 1st A-Field ‡ | | $\dot{\mathbf{D}}(\mathbf{A})(\mathbf{B})$ | 25 | | Move Right Numeric and wm thru 1st A-Field $\ddagger$ or $\ddagger$ | | Ď (A) (B) [ | 25 | | Move Right Numeric and wm thru 1st wm | | D (A) (B): | 25 | | Move Right Numeric thru 1st A-Field # | MRNG a,b | Ď (A) (B) R | 25 | | Move Right Numeric thru 1st A-Field ‡ | MRNR a,b | Ď (A) (B) Z | 25 | | Move Right Numeric thru 1st A-Field ‡ or ‡ | MRNM a,b | Ď (A) (B) I | 25 | | Move Right Numeric thru 1st wm | MRN a,b | Ď (A) (B) 9 | 25 | | Move Right wм thru 1st A-Field ‡ | MRWG a,b | Ď (A) (B) * | 25 | | Move Right wm thru 1st A-Field ‡ | | Ď (A) (B) % | 25 | | Move Right wм thru 1st A-Field ‡ or $\stackrel{\vee}{\sharp}$ | MRWM a,b | Ď (A) (B) □ | 25 | | Move Right wm thru 1st wm | MRW a,b | Ď (A) (B) @ | 25 | | Move Right Zones and wм thru 1st A-Field ‡ | MRZWG a,b | Ď(A)(B); | 25 | | Move Right Zones and wm thru 1st A-Field ‡ | | Ď (A) (B) 🔪 | 25 | | Move Right Zones and w™ thru 1st A-Field ‡ or ‡ | | $\overset{\mathbf{v}}{\mathrm{D}}(\mathrm{A})(\mathrm{B}) <$ | 25 | | Move Right Zones and wm thru 1st wm | MRZW a,b | $\dot{D}(A)(B) >$ | 25 | | | | | | | INSTRUCTION | AUTOCODER | ACTUAL | PAGE | |---------------------------------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | Move Right Zones thru 1st A-Field ‡ | | v<br>D (А) (В)! | 25 | | Move Right Zones thru 1st A-Field ‡ | MRZR a,b | Ď(A)(B)‡ | 25 | | Move Right Zones thru 1st A-Field ‡ or ‡ | MRZM a,b | Ď (A) (B)? | 25 | | Move Right Zones thru 1st wm | MRZ a,b | Ď(A)(B)0 | 25 | | Move Tape One Record Without Reading (for ce use) | | $\overset{v}{\mathbf{U}} \; \mathbf{x}^5 \mathbf{x}^2 \mathbf{x}^3 \; \mathbf{A}$ | 82 | | Multiply | | <b>@</b> (A) (B) | 19 | | No Operation | NOP | v<br>N | 24 | | Punch a Card, Stack in Pocket 0 (wo/w wm) | P(#)w° 0,b | $\dot{M}$ or $\dot{L}$ $x^{1}40$ (B) W | 63 | | Punch a Card, Stack in Pocket 4 (wo/w wm) | | $\stackrel{\vee}{\mathrm{M}}$ or $\stackrel{\vee}{\mathrm{L}}$ x <sup>1</sup> 44 (B) W | 63 | | Punch a Card, Stack in Pocket 8 (wo/w wm) | P(#)w° 8,b | $\stackrel{\vee}{\mathrm{M}}$ or $\stackrel{\vee}{\mathrm{L}}$ $\mathrm{x}^{1}48$ (B) W | 63 | | Read a Card, Stack in Pocket 0 (wo/w $w_M$ ) | $R(\#)w^{\circ}$ 0,b | $\stackrel{\vee}{M}$ or $\stackrel{\vee}{L}$ x <sup>1</sup> 10 (B) R | 62 | | Read a Card, Stack in Pocket 1 (wo/w wm) | $R(\#)w^{\circ}$ 1,b | $\stackrel{\vee}{M}$ or $\stackrel{\vee}{L}$ x <sup>1</sup> 11 (B) R | 62 | | Read a Card, Stack in Pocket 2 (wo/w wm) | | M or L x <sup>1</sup> 12 (B) R | 62 | | Read a Card, No Stack or Feed Operation (wo/w wm) | | M or L x119 (B) R | 62 | | Read Console Printer (wo/w wm) | | M or L x <sup>4</sup> T0 (B) R | 47 | | Read Tape (wo/w wm) | | $\stackrel{\checkmark}{\text{M}}$ or $\stackrel{\checkmark}{\text{L}}$ $x^{1}\text{U}x^{3}$ (B) R | 86 | | Read Tape to IRG or End of Core (wo/w wm) | | $\stackrel{\vee}{\text{M}}$ or $\stackrel{\vee}{\text{L}}$ $x^5\text{U}x^3$ (B) \$ | 86 | | Read Tape Binary (odd parity) wo/w wm | | $\stackrel{\vee}{M}$ or $\stackrel{\vee}{L}$ $x^1Bx^3$ (B) R | 86 | | Read Tape Binary (odd parity) to IRG or End of Core (wo/w wm) | | $\stackrel{M}{\overset{O}{\overset{D}{\overset{D}{\overset{A}{\overset{C}{\overset{D}{\overset{A}{\overset{C}{\overset{D}{\overset{A}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}{\overset{C}}{\overset{C}{\overset{C}}{\overset{C}{\overset{C}{\overset{C}}{\overset{C}{\overset{C}}{\overset{C}{\overset{C}}{\overset{C}}{\overset{C}{\overset{C}{\overset{C}}{\overset{C}}{\overset{C}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}}}$ | 86 | | Rewind | | $\overset{\mathbf{M}}{\overset{\mathbf{O}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}}}{\overset{\mathbf{C}}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}{\overset{\mathbf{C}}}{\overset{C}}}}{\overset{\mathbf{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}}}{\overset{C}}}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}{\overset{C}}{\overset{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}{\overset{C}}}{\overset{C}}}{\overset{C}}$ | | | Rewind and Unload | | $U x^5x^2x^3 U$ | 85<br>85 | | | | | | | Scan Left Single Position | | Ď (A) (B) blank | 26 | | Scan Left thru 1st A-Field wm | | Ď (A) (B) 6 | 26 | | Scan Left thru 1st B-Field wm | | $\overset{\mathbf{v}}{\mathbf{D}}(\mathbf{A})(\mathbf{B})$ – | 26 | | Scan Left thru 1st wm | | Ď(A)(B)& | 26 | | Scan Right thru 1st A-Field ‡ | | $\overset{\mathbf{v}}{\mathbf{D}}$ (A) (B) Q | 26 | | Scan Right thru 1st A-Field ‡ | | Ď (A) (B) Y | 26 | | Scan Right thru 1st A-Field ‡ or ‡ | SCNRM a,b | V<br>D (А) (В) Н | 26 | | Scan Right thru 1st wm | SCNR a,b | v<br>D (А) (В) 8 | 26 | | Select Stacker 0 and Feed (Ch 1 or 2) | SSF(#) 0/bl | $\overset{v}{\mathrm{K}}$ or $\overset{v}{4}$ 0 | 62 | | Select Stacker 1 and Feed (Ch 1 or 2) | SSF(#) 1 | K or 4 1 | 62 | | Select Stacker 2 and Feed (Ch 1 or 2) | SSF(#) 2 | $\overset{\vee}{\mathrm{K}}$ or $\overset{\vee}{\mathrm{4}}$ 2 | 62 | | Set Word Mark (One Address) | SW a | , (A) | 22 | | Set Word Mark (Two Addresses) | SW a,b | <b>y</b> (A) (B) | 22 | | Skip and Blank Tape | | $\overset{\checkmark}{U} x^5 x^2 x^3 \mathbf{E}$ | 85 | | Store A-address Register | | Ğ (C) A | 22 | | Store B-address Register | | Ğ (C) B | 22 | | Store E-address Register | | Ğ(C)E | 22 | | Store F-address Register | | Ğ (C) E<br>Ğ (C) F | 22 | | Subtract (One Field) | | Š (A) | 18 | | Subtract (Two Fields) | | S (A) (B) | 17 | | Table Lookup (see Lookup) | Lxx a,b | <b>ř</b> (A) (B) x | 30 | | Unit Control (see Backspace Skip, Write V, Rewind, Move Tape) | xxx cu | <b>U</b> x x²x³ x | 85 | | | W(#)° b | V | | | INSTRUCTION | AUTOCODER | ACTUAL | PAGE | |-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------| | Write a line, wm Create Blanks in Printing | . W(#)W° b | $\overset{v}{\mathbf{L}}$ x <sup>1</sup> 20 (B) W | 80 | | Write Console Printer (wo/w wm) | | $\stackrel{v}{\mathrm{M}}$ or $\stackrel{v}{\mathrm{L}}$ x <sup>4</sup> T0 (B) W | 47 | | Write Printer (see Write a Line) | | $\stackrel{\vee}{\mathrm{M}}$ or $\stackrel{\vee}{\mathrm{L}}$ x <sup>1</sup> 20 (B) W | 80 | | Write Tape (wo/w wm) | | $\stackrel{\vee}{\mathrm{M}}$ or $\stackrel{\vee}{\mathrm{L}}$ $\mathrm{x}^{\scriptscriptstyle{1}}\mathrm{U}\mathrm{x}^{\scriptscriptstyle{3}}$ (B) W | 87 | | Write Tape to End of Core (wo/w wm) | | $\stackrel{\vee}{\mathrm{M}}$ or $\stackrel{\vee}{\mathrm{L}}$ $\mathrm{x}^{\mathrm{5}}\mathrm{U}\mathrm{x}^{\mathrm{3}}$ (B) X | 87 | | Write Tape Binary (odd parity) wo/w wm | | $\stackrel{\vee}{\mathrm{M}}$ or $\stackrel{\vee}{\mathrm{L}}$ $\mathrm{x}^{1}\mathrm{B}\mathrm{x}^{3}$ (B) W | 87 | | Write Tape Binary (odd parity) to End of Core (wo/w wm) | | $\stackrel{V}{\mathbf{M}}$ or $\stackrel{V}{\mathbf{L}}$ $\mathbf{x}^5\mathbf{B}\mathbf{x}^8$ (B) X | 87 | | Write Tape Mark | . WTM° cu | $\overset{\mathbf{v}}{\mathbf{U}} \mathbf{x}^{1}\mathbf{x}^{2}\mathbf{x}^{8} \mathbf{M}$ | 85 | | Write Word Marks As 1's | . WM(#)° b | $\dot{M} x^{1}21 (B) W$ | 80 | | Zero and Add (One Field) | . ZA a | Y (A) Y (A) (B) | 18 | | Zero and Add (Two Fields) | . ZA a,b | ? (A) (B) | 18 | | Zero and Subtract (One Field) | ZS a | ! (A) | 19 | | Zero and Subtract (Two Fields) | ZS a,b | ! (A) (B) | 18 | | ACTUAL-LANGUAGE FOOTNOTES | | | | | Mode M (move) or L (load) | T ( 1/0 11-3 | | | | | Type of I/O Unit 1= Card Reader (1402) | 1 | | | Ch 1 Only Non-Overlap Only Code Alternate | 2 = Printer (1403)<br>4 = Card Punch (1402) | | | | Tomy Train Standy S.m., | B = Magnetic Tape Ur<br>T = Console - I/O Pri | nit odd parity | | | = x <sup>4</sup> | U= Magnetic Tape Ur | nit even parity | | | @ - Ch 1 Overlap — = ) | (For other I/O device<br>IBM 1410 Instruction | | | | x <sup>5</sup> Д - Ch 2 Non-Overlap = ' | Form X22 - 6740.) | | | | * -Ch 2 Overlap * | | | | | * = Cl 2 O (cliup) */ | . I/O Unit No. or Specif | ic Operation | | | | 0-9 = Magnetic To<br>0,1,2 = 1402 Pocket | ape Unit (unit No.) | | | | 0,4,8 = 1402 Pocket | | | | | ation (read) 0,1 = Specific Prin | | | | NOTE: x <sup>4</sup> or x <sup>5</sup> , when present, occupies x <sup>1</sup> position | 0 = No Meaning | , but satisfies | | | | Console-I/C | | | | | | | | | Five-position B-address identifying the high-order (leftmost) position of data field | | | | | d-character (definer) operation modifier | | | | | $L = L \times $ | | | | | | | | | | AUTOCODER FOOTNOTES | | | | | Mnemonic Op-Code Suffixes # — 1 or 2 for Ch Examples: $P(\#) w^{\circ}$ 0,b is written at | POWO O has number ours | | | | (#)—- 1 or 2 for Ch, but the in the channel 2 1402, using the | ne load and overlap modes, | | | | $w - W $ if WM (load mode) tion is $L * 40 (B) W_{\bullet}$ | | | | | ° — O if overlap $P(\theta)_M$ ° 0,b is written simply at $x$ — Undefined and referenced card in the channel 1 1402, us | ing the move and non-over- | | | | lap modes, and stack in pocke uage instruction is M %40 (B) | W.) | | | | a A-address | | | | | a — A-address (AAR does not step) b — B-address | | | | | i — I-address d — d-character | | | | | a —— a-character<br>c —— 1 or 2 for Ch<br>u —— 1/O unit No. | | | | | cu— Ch and unit No. | | | | | 0/bl— Either 0 or blank (All other characters actual) | | | | | Eigen 107 Featnetes from Appendix | | | | Figure 107. Footnotes from Appendix # Index | 1401 1410 C | | |---------------------------------------------------|--------------------------------------------| | 1401 – 1410 Compatibility | Card Stacker Selection | | 1402 Card Read Punch, Model 2 59 | Carriage Control Instruction | | 1402 Operation Codes 61 | Carriage Controls, 1403 6 | | 1402 Timing Considerations 64 | Carriage Restore Key, 1403 6 | | 1403 Carriage Controls 68 | Carriage Space Key, 1403 6 | | 1403 Manual Controls 68 | Carriage Stop Key, 1403 6 | | 1403 Operation Codes 79 | Carriage Stop Rey, 1405 | | 1403 Printer | Carriage Tape Brushes, 1403 | | 1403 Printer | CE Setting (Mode Sw), 1415 | | 1403 Timing Considerations 81 | CE Panel Power Local-Remote Switch | | 1410 Accelerator 96 | Cartridge Changing Procedure, 1403 | | 1411 Processing Unit | Chaining Instructions | | 1414 Input-Output Synchronizer | Channel Status Indicators 37, 42, 5 | | 1415 Console | Channel 2 | | 1415 Console, Test Panel 56 | Character Coding 5, | | 729 Operation Codes | Characters Printable on 1403 6, 6 | | 729 Tape Timings 88 | Characters I finable on 1403 | | 729 Tape Unit | Check Bit | | 7330 Operation Codes 85 | Check Control Switch, 1415 Test Panel 56 | | 7000 Tea Transfer St | Checking the Execution of 1/0 Instructions | | 7330 Tape Timings 89 | Check Reset Key, 1403 | | 7330 Tape Unit | Chips Light | | Accelerator, 1410 Special Feature | Clear Storage | | A Ring Lights, 1415 | Clear Storage and Branch 23 | | A Address | Clear Storage, Program Loop 23 | | A-Address 10 | Clear Word Mark | | A-Address Register 8 | Clock Lights, 1415 | | A-Data Register | Compare | | Add Cycles | Compare | | Address Check Light, 1415 | Compare Examples 28, 29 | | Address Entry Switch, 1415 Test Panel 57 | Compare Indicators | | Address Modification, Indexing | Compatibility98 | | Address Registers 8 | Compatibility Controls, 1415 Test Panel 58 | | Address Set Setting (Mode Sw), 1415 50 | Compatibility Light, 1401 (1415) | | Addressing 8 | Compatibility Switch, 1415 Test Panel 58 | | Addressing Evennle | Complement Add | | Addressing Example 10 | Computer Reset, 1415 | | Add (One Field) 17 | Condition Light, 1415 | | Add (Two Fields) 17 | Conditional Propel | | Algebraic Subtraction 16 | Conditional Branch 36 | | Alter Setting (Mode Sw) 1415 | Console | | Arithmetic Lights, 1415 | Console CE Controls Having Customer Uses | | Arithmetic Operation Codes 17 | Console 1/o Printer | | Arithmetic Overflow Indicator 17 52 | Console Load Read and Write Operations | | Asterisk-Insert Switch, 1415 Test Panel 50 | Console Printer Control Keys and Levers 46 | | Asterisk Protection 32 | Console Printer Typeout Wraparound | | Autocoder 11 | Console Print-Out | | A 11 | Console Reply Routine 48 | | B-Address | Console Write Instruction 47, 49 | | 3-Address Register 8 | Control Carriage Instruction 81 | | 3-Data Register 9 | Control Field, Editing 31 | | $3 < A \text{ (Low) Light, } 1415 \dots $ | Control Varia 1415 | | $\beta = A \text{ (Equal) Light, } 1415 \dots 53$ | Control Keys, 1415 | | 3 > A (High) Light, 1415 | Control Tape, 1403 72 | | Backspace Tape 85 | Control Tape, Insertion into Carriage 72 | | | "Core Clear" Operation | | Branch Codes 36 | Core Storage 5 | | Branch Conditionally (One Add and | CPU Control Indicator Lights, 1415 | | Branch Conditionally (One Address) | Cycle Lights, 1415 | | Branch if Bit Equal | Cycle Control Switch, 1415 Test Panel 56 | | Branch if Character Equal | D-Address Register 9 | | Branch if 1/0 Channel Status Indicator On 37 | d-Character | | Branch on Word Mark or Zone Equal | d-Character 11 | | Granch Unconditionally | Data Channel 2 92 | | rush Interlock Light, 1403 | Data Check Light, 1415 | | Susy Light, 1415 | Data Field, Editing | | Addman Daniel | Data Flow | | And Read Instruction Charles at L. E. | Data Moving | | Card Read Instruction, Checking the Execution 41 | Data Operations | | ard Read Punch Lights 61 | DC Off Kev. 1415 | | | | | 0.4 | |-----------------------------------------------------|-------------------|---------------------------------------------------------------------------------|----------| | Decimal Control | 33 | Inter-record Gap (IRG) | 84 | | Disk Off-Line Light, 1415 | 55 | Interlock Light, 1415 | 55 | | Disk Write Switch, 1415 Test Panel | 57 | Invalid Bit Parity Print-Out | 45 | | Display Setting (Mode Sw), 1415 | 51 | Inverted Circumflex (V) | 7 | | Display Setting (Mode Sw), 1410 | 20 | IRG (Inter-record Gap) | 84 | | Divide | 14 | The (Inter record sup) | 68 | | Divide Overflow Condition | 14 | Lateral-Print Vernier, 1403 | 40 | | Divide Overflow Light, 1415 | | Line Space (Vertical Space, Index), Console Printer 45, | 49 | | E-Address Register | 93 | Load Mode | 41 | | E1 Register | 93 | | 36 | | E2 Register | 93 | Low Indicator | 53 | | Editing | 31 | Low-Speed Start Light, 1403 | 71 | | Editing Specifications | 31 | Low-Speed Stop Light, 1403 | 71 | | Emergency Power Off Switch, 1415 | 50 | Magnetic Core Storage | 5 | | Emergency Power Off Switch, 1415 | 61 | Magnetic Core Storage | 8/ | | End-of-File Key, 1402 | 01 | Magnetic Tape Units | 85 | | End-of-Forms Light, 1403 | 00 | Magnetic Tape Control Instructions | 00<br>07 | | Equal Indicator | , 53 | Method of Printing, 1403 | 50 | | Erasing Tape | 85 | Mode Switch, 1415 | 50 | | Even (Vertical) Parity Check | 84 | Move Characters and Suppress Zeros | 27 | | F-Address Register | 92 | Move Characters and Suppress Zeros, Multiple Field | 28 | | F1 Register | 92 | Move Characters and Edit | 31 | | F2 Register | 92 | Move Instructions | 25 | | Features | 92 | Move Mode | 41 | | reatures | 68 | Multiply | 19 | | Feed Clutch, 1403 | E0 | Multiply Concept | 19 | | File Feed Device, 1402 | 29 | | | | Floating Dollar Sign | 02<br>75 | Next Sequential Instruction (NSI) | , 13 | | Form Design for 1403 | 75 | No Operation | 24 | | Forms Check Light, 1403 | 68 | No Transfer Light, 1415 | 54 | | Forms Insertion, 1403 | 73 | Not Overlap in Process Light, 1415 | 54 | | Forms Specifications and Dimensions, 1403 | 76 | Not Ready Light, 1415 | 54 | | Function (Table Lookup) | 29 | NSI (Next Sequential Instruction) | , 13 | | Fuse Light, 1402 | 60 | Numeric Print Feature, 1403 | 82 | | Gate Interlock Light, 1403 | | Off Normal Light, 1415 | | | | | Off Normal Light, 1415 | 10 | | Halt | | Op Code | 101 | | Halt and Branch | 23 | Op Code Index | 0 | | High Indicator | 5, 53 | Op-Modifier Register | o o | | High-Speed Start Light, 1403 | 71 | Op-Register | 61 | | High-Speed Stop Light, 1403 | 71 | Operation Codes for 1402 | 70 | | Hole-Count Check | 60 | Operation Codes for 1403 | 15 | | Horizontal Adjustment, 1403 | | Operation Codes for Console-1/o Printer | 43<br>02 | | I Ring Lights, 1415 | 52 | Operation Codes for Tape Units | 17 | | I-Address | - 11 | Overflow | 17 | | I-Address Register | 8 | Overflow Light, 1415 | 93<br>05 | | I/E Cycle Setting (Mode Sw), 1415 | 52 | Overlap Error or Stop Conditions | 95 | | Indexing | 14 | Overlap-In-Process Light, 1415 | 54 | | Indexing Examples | . 15 | Overlap-In-Process Indicator | , 92 | | Index Factor | ´14 | Overlap Operation | 93 | | Index of 1410 Operation Codes | 101 | Overlap Operational Considerations | 95 | | Index (Vertical Space, Line Space), Console Printer | 49 | Overlap Tape Read Operation | 93 | | Index Register | 14 | Overlap Tape Read and Write Operation | 94 | | Indicator Lights, 1415 | 52 | Overlap Tape Write Operation | 94 | | Indicator Panel Lights, 1403 | 71 | Paper-Advance Knob, 1403 | | | Input-Output Instructions | 41 | Paper Stacker, 1403 | 75 | | Input-Output Operations | 40 | Parity | 5 | | Input-Output Operations Input-Output Synchronizers | 40 | Parity Checking | 5 | | 1/0 Channel Control Lights, 1415 | | Power Keys, Lights, and Switches – 1415 | 49 | | | | Power Light, 1402 | 60 | | 1/o Channel Select Register | . 9 | Power Lights, 1415 | 55 | | 1/o Channel Status Indicator Lights, 1415 | 2, 34 | Power-On Reset Operation | 49 | | 1/o Check Stop Switch, 1415 Test Panel | . 50 | Print Check Light, 1403 | 68 | | 1/o Check-Reset Switch, 1401 (1415 Test Panel) | . 50<br>EE | Print-Out Control Switch, 1415 Test Panel | 56 | | I/O Interlock Light, 1415 | . 55<br>EE | Print Ready Light, 1403 | 68 | | 1/o Off-Line Light, 1415 | . 00<br>AE | Print Start (Front and Back) Key, 1403 | 68 | | I/o Printer | . 4:0<br>7 /0 | Print Start (Front and Back) Key, 1403 | 68 | | Inquiry Keys, Console Printer | 1, <del>1</del> 0 | Print Stop (Front and Back) Rey, 1403 | 69 | | Inquiry Status Latch | . 40 | Print-Density Control Lever, 1403 Print-Line Indicator and Ribbon Shield, 1403 | 69 | | Instruction Check Light, 1415 | | Print-Line Indicator and Ribbon Shield, 1403 | 69 | | Instruction Descriptions | | Print-Timing Dial, 1403 Print-Unit Release Lever, 1403 | 69 | | Instruction Form | . 11 | Print-Unit Release Lever, 1403 | . 68 | | Instruction Length Validity | . 11 | Printer Keys and Lights Printer Timing Considerations | . 81 | | Instruction List | . 101 | Printer Timing Considerations Priority Alert Light, 1415 | 56 | | Instruction Sequence | . 11 | Priority Alert Light, 1415 Process Lights, 1415 | 54 | | Instruction Timing | 12 | Process Lights, 1410 | . 54 | | Processing | 5 | Stop Light, 1415 | 56 | |--------------------------------------------------------|-------------|-----------------------------------------------------------|----------| | Processing Control Operations | 22 | Stop Key, 1415 | 50 | | Processing Overlap Feature | 92 | Storage Address Register | 10 | | Program-Reset Key, 1415 | 52 | Storage Scan Switch, 1415 Test Panel | 58 | | Program Lights, 1415 | 55 | Store Address Register | 22 | | Punch a Card | 63 | Sub Scan Lights, 1415 | 52 | | Punch-Check Brushes | 59 | Subtract (One Field) | 15 | | Punch Check Light, 1402 | 61 | Subtract (Two Fields) | 17 | | Punching the Control Tape, 1403 | 72 | Symbols | 19 | | Punch Ready Light, 1402 | 61 | Sync Check Light, 1403 | 68 | | Punch Start Key, 1402 | 61 | System Control Indicator Lights, 1415 | 55 | | Punch Stop Key, 1402 | 61 | System Features | 99 | | Punch Stop Light, 1402 | 61 | System Check Indicator Lights, 1415 | 54 | | Punch Keys and Lights | 61 | Table Argument | | | RBC Interlock 1/0 Channel Control Light, 1415 | 53 | Table Lookup Discussion | 20 | | RBC Interlock Program Light, 1415 | 55 | Table Lookup Instruction | 20 | | Read-Write Gaps | 84 | Tagging, Indexing | 14 | | Read a Card | 62 | Tape Adapter Unit (TAU) | 00 | | Read a Card, Checking the Execution | 41 | Tape-Controlled Carriage, 1403 | 71 | | Read-Check Brushes | 59 | Tape Characteristics | 0.4 | | Read Console Printer Instruction 46 | 47 | Tape Checking | 04 | | Read Feed — Interchangeable 51-Column, Special Feature | 64 | Tape Density Switches, 1415 Test Panel | 04 | | Read Light, 1415 | 53 | Tape Mark Parity | 90 | | Read or Write Tape | 86 | Tape Movement Specifications | 00 | | Read or Write Tape with Word Marks 87 | 99 | Tape Off-Line Light, 1415 | 55 | | Reader Check Light, 1402 | 61 | Tape Timing Considerations | 90 | | Reader Keys and Lights | 60 | TAU (Tape Adapter Unit) | 22 | | Reader Ready Light, 1402 | 61 | Testing the 1/0 Channel Status Indicators | 49 | | Reader Start Key, 1402 | 60 | Thermal Interlock Light, 1403 | 71 | | Reader Stop Light, 1402 | 61 | Timing Considerations for 1402 | 61 | | Reader Stop Key, 1402 | 61 | Timing Considerations for 1403 | 21<br>21 | | Ready Light, 1415 | 50 | Timing Considerations for 729 | 88 | | Record Check Time | 88 | Timing Considerations for 7330 | 89 | | Rewind | 85 | Timing Formula Symbols | 12 | | Rewind and Unload | 85 | Tractor Slide Bar, 1403 | 70 | | Ribbon Changing, 1403 | 73 | Transport Light, 1402 | ദവ | | R.H. Tractor Vernier, 1403 | 70<br>70 | True Add | 16 | | Run Setting (Mode Sw), 1415 | 50 | Two-Gap Head, Magnetic Tape Unit | 84 | | Scan Lights, 1415 | 52 | Unconditional Branch | 36 | | Scanning | 27 | Unit Control Instructions, Tape Units | 85 | | Search Argument | | Unit Number Register (Channel 1 and 2) | 10 | | Search Argument Select Stacker and Feed | 29 | Unit Select Register (Channel 1 and 2) | 10 | | Sense-Bit Switches, 1415 Test Panel | | Valid Storage Addresses | 15 | | Set Word Mark | 98<br>99 | Validity Light, 1402 | 10<br>21 | | Shift Interlock Light, 1403 | 22<br>71 | Vertical-Print Adjustment, 1403 | S O | | Sign Change or Development | ( L | Vertical Space (Line Space, Index), Console Printer 45, 4 | 70<br>10 | | Sign Control Left | | | | | ingle-Character Registers | | Word Mark | 37 | | Single Cycle Key, 1403 | 3<br>38 | Word Separator | 37 | | Skip and Blank Tape | | Wraparound of Console Printer Typeout | 51 | | low Brushes, 1403 Carriage Tape | | Write a Line, 1403 | 30 | | pacing Chart, 1403 | 76 | Write Light, 1415 | 54 | | pacing, 8-Lines-per-Inch, 1403 | 74 | Write Tape Mark 8 Write Word Marks, 1403 8 | 35 | | pecial Features | 92. | Wrong-Length Record Light, 1415 | 50 | | peed Control, 1403 | <i>7</i> 9. | | | | tacker Light, 1402 | 30 | X-Control Field 1 | 1 | | tackers, 1402 | 30 | Zero and Add (One Field) 1 | ıΩ | | tandard BCD Interchange Code | 7 | Zero and Add (Two Fields) | .U | | tart Key, 1415 5 | 51 | Zero and Subtract (One Field) | 19 | | tart Print-Out Switch, 1415 Test Panel | 66 | Zero and Subtract (Two Fields) | 8 | | tatus Lights, 1415 | 52 | Zero Balance | 7 | | tatus Test | 12 | Zero Balance Indicator | 53 | | top Brushes, 1403 Carriage Tape 7 | 2 | Zero Suppression 3 | 32 | | | | | | # COMMENT SHEET # IBM 1410 PRINCIPLES OF OPERATION SYSTEMS REFERENCE LIBRARY FORM A22-0526-2 | | FROM | |------|---------------------------------------------------------------------------------------------------------------| | | NAME | | FOLD | OFFICE OR ADDRESS | | | Suggested addition (Page , Timing Chart, Drawing, Procedure, etc.) Suggested deletion (Page ) ERROR (Page ) | | | EXPLANATION | FOLD FOLD FOLD FOLD FOLD FOLD BUSINESS REPLY MAIL NO POSTAGE STAMP NECESSARY IF MAILED IN U. S. A. IBM CORPORATION P.O. BOX 390 POUGHKEEPSIE, N.Y. 12602 ATTN: CUSTOMER MANUALS, DEPARTMENT B98 FIRST CLASS PERMIT NO. 81 POUGHKEEPSIE, N.Y. FOLD STAPLE STAPLE IBM International Business Machines Corporation Data Processing Division 112 East Post Road, White Plains, N.Y. 10601 [USA Only] IBM World Trade Corporation 821 United Nations Plaza, New York, New York 10017 [International]