## PC-2 Assembly language ### Articles by Bruce Elliott from TRS-80 Microcomputer News - March 1983 - April 1983 - May 1983 - September 1983 - October 1983 - February 1984 www. PC-1500 INFO #### Magazines from: http://www.colorcomputerarchive.com/coco/Documents/Magazines/TRS-80%20Microcomputer%20News/ ## PC-2 Assembly Language Article by Bruce Elliott This is the first in a series of articles which will describe the MPU (microprocessor unit) used in the Radio Shack PC-2 pocket computer. It is our intention to include specific information about the 8-bit CMOS microprocessor, the machine code used by the microprocessor, as well as information about the PC-2 memory map and certain ROM calls which are available. Please realize that much of what we are talking about refers to the overall capabilities of the MPU and does not imply that all of these things can be done with a PC-2. Some known precautions when working with the PC-2 include: - Po—This signal is not supplied to an external output pin on the PC-2. - TI—The Timer Interrupt service routine is not available on the PC-2. If a Timer Interrupt occurs, an RTI is immediately executed. - NMI—The Non-Maskable Interrupt is not available to the programmer on the PC-2. - The MPU signals BRQ and BAK are not supplied to the external output pins. - Though MEO is available as an output from the MPU, DMEO (from one of the support chips) performs a similar function and should be used. Please understand that the information provided in these articles is the only information which is available. We will try to clarify any ambiguities which occur in the articles, but can not reply to questions outside the scope of these articles. Further, published copies of *TRS-80 Microcomputer News* are the only source of this information, and we will not be maintaining back-issues. #### PC-2 BLOCK DIAGRAM #### **OUTLINE OF THE 8-BIT CMOS MPU** The 8-bit MPU chip (LH5801) uses CMOS static technol- ogy. This gives the MPU the low power dissipation inherent to CMOS technology. The MPU incorporates the LCD backplane signal generator, input port, external latch clock and the timer. The MPU features: - 16 bit address bus - · 8 bit data bus - 8 bit input port - DMA and multiprocessor capabilities - Contains a WAIT function for memory access control - LCD backplane control - · Clock frequency of 2.6 MHz. - a. Internal machine cycle of 1.3MHz. - b. Minimum instruction execution time of 1.3 microseconds. In the PC-2, the MPU performs the following functions: - · Key input routine - Acknowledges remaining program lines - Interprets program execution statements - Interprets cassette control statements - Interprets printer control statements - Interprets command statements - Display processing routineArithmetic routines - Print routine - Instructs I/O chip to perform serial communications, sound buzzer, and control counter/timer #### **MPU SIGNALS** - $\Phi D-$ Output disable signal, when this signal is active, the data bus is in the output mode. - ΦOS—This clock signal is in phase with the internal basic clock and is supplied to the outside system. 2MHz of the clock frequency is supplied when a 4MHz crystal is being used between XL0 and XL1. Since PC-2 uses a 2.6MHz chip, the clock frequency is 1.3MHz. - AD0-AD15—Address bus. The address bus is tri-state and goes into the high impedance state when a Bus Request, BRQ, is issued. MPU Internal Registers and Flip-flops BAK—The BAK output is synchronized with the internal clock. When BAK goes high, the Address Bus, Data Bus, ME0, ME1, R/W, and ΦD all turn to the high impedance state Not used in PC-2. BFO, BFI—BFO is an output of the BF flip-flop and BFI is an input to the BF flip-flop. The BF flip-flop is normally used for the memory backup system. In the PC-2, BFI is connected to the <BREAK key, and goes "high" when the <BREAK key is depressed. BFO, in the PC-2, is connected to the Chip Select Circuit and the Expansion Port. BRQ—Bus Request. The MPU responds to the BRQ by turning BAK (Bus Acknowledge) high. Not used in PC-2. Tied to GND. D0-D7 — Bidirectional data bus through which data is written to or read from external memory. DISP—A flip-flop which is used to control the on and off action of the L.C.D. Instructions are provided to set and reset this flip-flop. GND-Ground H0-H7-These are the LCD backplane signals. HA—Output of the MPU internal driver Divider output of 625 Hz in the PC-2. Used by the display chips. HIN—LCD backplane signal and an input to the counter that generates H0-H7. This is connected to HA in the PC-2 IN0-IN7—This is the input port which the MPU uses to bring 8-bit data into the internal accumulator. Internal pull-up resistance is present. In the PC-2, the input port is connected to the keyboard. ME0, ME1—The Memory Enable signals used by the MPU to directly access a maximum of 128K bytes in external memory. In the PC-2, ME0 is connected to the chip select circuit and to the ME1 input of the I/O chip. In the PC-2, ME1 is connected to the ME0 input of the I/O chip and the expansion port. MI—The Maskable Interrupt Input signal. The MPU will respond to this interrupt request when the Interrupt Enable flag (IE) is on. Interrupt processing will begin at the address indicated by FFF8 and FFF9. In the PC-2 this is connected to the INT output of the I/O Chip. NMI—The Non-Maskable Interrupt Input. The MPU will respond unconditionally, and interrupt processing will begin at the address indicated by the contents of FFFC and FFFD. Not used in the PC-2, tied to GND. OPF—Operation Code Fetch. Allows the MPU to fetch an operation (instruction) code. OPF appears when an instruction code is fetched, during address data and immediate data operations, and when the second byte of a two step instruction is being fetched. Not used in the PC-2. PΦ—External latch clock. The contents of the accumulator is transferred on the data bus when this clock is in the high state, and can be used as an output port when an external latch IC is present. Not used in the PC-2. PU, PV—These are MPU internal flip-flops. Set and reset instructions are provided for both PU and PV. In the PC-2, both PU and PV are connected to the expansion port. PU is one of the enable signals for the printer ROM. R/W-Memory Read/Write Signal RESET—MPU reset input which causes the MPU to reset when a high signal is received. Program execution begins at the memory address pointed to by the contents of FFFE (low order) and FFFF (high order.) Execution begins at the indicated address when the RESET input changes from a high to a low state. On the PC-2 this is connected to the All Reset Switch. VA.—Power Supply to the LCD. High voltage for segment signals, 1.2—2.2 volts. VB—Power Supply to the LCD. Low voltage for segment signals, 2—1 2 volts. Vcc-+4.7 volts VDIS-Power Supply to the LCD. +3.7 volts. Vgg-+4.7 volts VM—Power Supply to the LCD. An intermediate voltage used for the common and segment signals. .8—1.6 volts. WAIT—When the MPU receives a high signal at the WAIT input, the MPU internal clock is halted to stop microprogram execution inside the MPU. WA is an internal flip-flop which accepts the WAIT input at the falling edge of the clock oOS and stops the MPU clock when it is in a high state. Connected to the WAIT output of the I/O chip in the PC-2. This informs the CPU when memory or an I/O device is not ready. XL0, XL1—Crystal connection pins PC-2 uses a 2.6MHz crystal which operates the MPU at a 1.3MHz clock frequency. XL0—Input, XL1— Output #### MPU DESIGNATIONS - A: "A" represents the 8-bit register (accumulator) used for retention of arithmetical results or for data transfer with external (non-MPU) memory. DISP: LCD display on/off control - P: "P" represents the 16-bit register (program counter) that indicates the next address that follows the currently executing instruction, and is automatically incremented by one when the next instruction is fetched. The maximum 64K bytes addressed by ME0 is addressable by P and constitutes the program area. PH: High order 8 bits of the program counter PL: Low order 8 bits of the program counter PU: General purpose flip-flop PV: General purpose flip-flop - R: represents any one of the X, Y, or U 16-bit registers. These registers can also be used as data pointers. When X, Y, or U are used as data pointers, it becomes possible to issue Memory Enable signals, ME0 and ME1, independently. A maximum of 128K bytes of memory area is available to X, Y, and U (a maximum of 64K bytes in the memory area accessed by ME0 and another 64K bytes in the memory area accessed by ME1.) - RH: represents any one of the high order XH, YH, or UH 8-bit registers RL: represents any one of the low order XL, YL, or UL 8-bit registers. S: "S" represents the 16-bit register (stack pointer) that indicates the next available stack address for the push-down or pop-up stack in memory. The maximum 64K bytes addressed by ME0 is available as the stack area. SH: High order 8 bits of the stack pointer SL: Low order 8 bits of the stack pointer T: "T" represents the 5-bit register (status register or flags) designed to hold status information such as: carry (C), borrow (H), zero (Z), overflow (V), and interrupt enable (IE). The flags (C, H, Z, V), other than the interrupt enable, can be tested by the conditional branch or conditional subroutine jump instructions TM: "TM" is the 9-bit polynomial counter (timer counter) U: 16-bit register UH. High order 8 bits of register U UL: Low order 8 bits of register U X . 16-bit register XH: High order 8 bits of register X. XL. Low order 8 bits of register X Y 16-bit register YH: High order 8 bits of register Y YL: Low order 8 bits of register Y #### **OPERATIONAL SYMBOLS** → : Signal or data flow ← : Signal or data flow Logical AND v : Logical OR ⊕ : Exclusive OR + : Arithmetic addition Arithmetic subtraction #### MEMORY AND ADDRESS REPRESENTATION Since the Memory Enable signals, ME0 and ME1, are output from the MPU, the PC-2 microprocessor can directly access any area within 128K bytes. ME0 takes care of one 64K byte memory area and ME1 another 64K byte memory area. However, ME0 is dedicated to program or data areas and ME1 to data area only. Memory Area accessible by MPU (R): The contents of the ME0 accessible memory that can be specified by the register R #(R). The contents of the ME1 accessible memory that can be specified by the register R. (ab): "a" is a number that represents the high order 8 bits of the address and "b" low order 8 bits of the address. Together, they indicate the contents of the memory that can be represented by the 16 combined bits of a and b (MEO accessible). #(ab): Same as the above, except that it can be accessed by ME1 ab used in defining the conditional jumps and subroutine calls to designate the two hex digits which comprise a single byte immediate value "i". #### STATUS FLAGS The status flags, C, V, H, Z, and IE are contained in the 5-bit status register. The contents of C, V, H, and Z may change upon completion of an arithmetic instruction. Assume that the added results of each bit of the 9-bit full adder are as follows: $\Sigma$ 7, $\Sigma$ 6, $\Sigma$ 5, $\Sigma$ 4, $\Sigma$ 3, $\Sigma$ 2, $\Sigma$ 1, $\Sigma$ 0, with carry of C7, C6, C5, C4, C3, C2, C1, C0. The input conditions for each of flags shall be as described below: (1) Carry flag C—The carry flag C is either set or reset depending on the presence of a carry in C7 (8th bit). (2) Half carry flag H—The half carry flag H is either set or reset depending on the presence of a carry in C3. (3) Zero flag Z—The zero flag Z is dependent on the arithmetic results, it will be set when the result is zero, otherwise, it will be reset. (4) Overflow flag V — The overflow flag V is set when the arithmetic results of one byte is in overflow, provided that the 8th bit is used for a sign with rest of the 7 bits for used for numeric representation. #### I/O PORT CHIP Contains - two 8 bit bi-directional ports, labeled PA and PB. Each bit in these two ports can be programmed as either an input or an output. The CPU can access PA or PB as one location in memory. PA is used for the keyboard strobe and PB is used for cassette, counter/timer, and as an interrupt input. - one 8 bit output port labeled PC, PC can be accessed as one location in memory and is used for counter/timer control and to sound the buzzer. - Two interrupt request inputs, used with (BREAK) and IRQ inputs from the expansion port · one interrupt request output connected to the CPU. CPU WAIT control output. Outputs two memory enable signals, DME0 and DME1, which are used with memories that have slow access times. Controls serial communications. The two wait input lines, W0 and W1, are used in serial communications. #### LCD DISPLAY CHIPS Four display chips used for displaying information on the LCD, and as memory space for fixed memories E\$ - Z\$. Display chips 1 and 3 are used for the LCD display, indicators, and fixed memories E\$ - O\$. Display chips 2 and 4 are used for the LCD display and for fixed memories P\$ - Z\$. #### OTHER PARTS OF THE PC-2 SYSTEM · Chip Select Decoder Circuit • 16K System ROM 1K System RAM (two 5514 RAM chips). This RAM is used for fixed memories A\$ - D\$, fixed memories A - Z, stack space, the 80 character input buffer, and is used by FOR-NEXT statements. 2K User RAM (one 6116 RAM chip). This RAM is used for fixed memories A27 or A\$27 and above as well as being used for Reserve, Program and Variable memory. Buzzer circuit · Counter/Timer circuit Module port Expansion port Keyboard ``` 79EB - 79EF 79F0 Printer Text/Graphic mode 79F1 79F2 Printer ROTATE value 79F3 Printer pen color 79F4 Printer CSIZE 7400 - 7407 Numeric Plats Buffer or SI Memory Map: 0000 - 3FFF Module ROM - 16K 4000 - 47FF User RAM - 2K 4000 - 4007 Reserve Memory pointers 4008 - 4021 Menu 1 4008 - 4021 Menu 1 4022 - 4038 Menu 2 403C - 4055 Menu 3 4056 - 4002 Function Key Definitions 40C4 0 to mark end of function key definitions 40C5 - 47FF Program (Variable) Memory 4800 - 6FFF Module RAM 7000 - 75FF Duplicate of 7600 - 7BFF 7000 - 75FF Duplicate of 7600 - 78FF 7600 - 76FF Display Chip 1 & 3 7600 - 764D LCD Display - Sections 1 & 3 764E Indicator Bit 0 - Busy Bit 1 - Shift Bit 2 - Japanese Bit 3 - Small Bit 4 - III Bit 5 - II Bit 6 - I Bit 7 - Def Indicator Bit 0 - De Bit 1 - G Bit 2 - Rad Bit 3 - Small Bit 4 - Reserve Bit 5 - Pro Bit 6 - Run pansion ROM - 16K Change printer pen color Printer motor off Send ASCII character to printer (no LF) Move pen Send line feed (LF) to printer Send n line feeds to printer Send n line feeds to printer Send n line feeds to printer Pen Up/Down Switch printer from graphic to text mode Switch printer from text to graphic mode Write tape synchronization header Finalization of tape I/O control Read tape synchronization header/search for filename Read/Write file to tape Send a character to tape Read a character from tape Turn tape drive of Turn tape drive off stern Program ROM - 16K A781 A8DD A9F1 AAO4 AAD9 ABCB ABEF BBD6 7650 - 765F ES 7660 - 765F ES 7670 - 765F ES 7690 - 769F IS 7690 - 769F IS 7690 - 769F IS 7690 - 769F IS 7690 - 769F IS 7600 - 766F IS 7600 - 760F IS 7600 - 760F IS 7600 - 760F IS BBF5 BCE8 BD3C BDCC BDF0 BF11 BF43 Turn tape drive off FFFF System Program ROM - 16K D0D2 Magnitude Comparison for Numeric Values D6F9 Magnitude Comparison for Character Strings D6F9 D2EA Search for program line number D7F1 Find address of variable D7F1 CHRS CH BF43 C000 - 76F0 - 76FF OS 77FF Display Chips 2 & 4 7700 - 774D LCD Display - Sections 2 & 4 774E - 774F Not used 7750 - 775F OS 7770 - 777F RS 7780 - 778F SS 7790 - 779F TS 7780 - 778F VS 7700 - 770F VS 7700 - 770F XS 7700 - 770F XS 7700 - 770F XS 7700 - 770F XS Auto Power Off Keyboard Scan - no wait Display contents of display buffer Output n characters to LCD using current cursor location Output n characters to LCD beginning at cursor = 0 Output one char to LCD and increment cursor position by one Output one character to LCD Convert two bytes of ASCII code (0-9,A-F) into one byte of hex data Output one graphic column to current cursor position X - Y -> X X + E8CA ED00 ED3B ED4D F161 F39E F492 F496 F49A FF00 - FFF6 Vectors for jumps and calls FFF8 - FFF9 Start Address for MI routine FFFA - FFFB Start Address for the Internal Timer FFFC - FFFD Start Address for the NMI routine FFFE - FFFF Start address for the RESET routine 7968 796F N 7977 O - 7977 O - 797F P - 7987 O - 798F R - 7997 S - 799F T - 79A7 U - 79AF V - 79BF W - 79BF X - 79CF 7 7970 7978 PAG SUM TRS-80 7980 - 7988 - 7990 - 7998 - 79A0 79A8 79B0 79B8 79C0 ON क्ल हो हैं। हैं। हैं। हैं। OFF A S D F G H J K L = 4 5 6 * ... ZXCVBNMÍĎÍ123 79C8 - 79CF Z 7BFF System Memory - 560 Bytes 79D0 SAIL $ INCL SPACE ENTER A DEL TO THE PARTY OF O 79E0 - 79E1 Printer X-axis position relative to origin 79E2 - 79E3 Printer Y-axis position relative to origin 79E4 - 79E5 Printer HCURSOR value - 79E8 Printer pen up/down Printer line type ``` Article by Bruce Elliott This is the second in a series of articles which will describe the MPU (microprocessor unit) used in the Radio Shack PC-2 pocket computer. It is our intention to include specific information about the 8-bit CMOS microprocessor, the machine code used by the microprocessor, as well as information about the PC-2 memory map and certain ROM calls which are available. Please realize that much of what we are talking about refers to the overall capabilities of the MPU, and does not imply that all of these things can be done with a PC-2. The information provided in these articles is the only information which is available. We will try to clarify any ambiguities which occur in the articles, but can not reply to questions outside the scope of these articles. Further, published copies of TRS-80 Microcomputer News are the only source of this information, and we will not be maintaining back issues. #### Instruction Set #### LOGICAL OPERATIONS ADC—The contents of the internal register (RL or RH), or the contents of external memory [(R), #(R), (ab), or #(ab)] is added into the accumulator including the carry C. The result is stored in the accumulator. Flags C, H, Z, and V may change after the execution of this instruction. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |-----------|--------------------------------|----------------|------|-------| | ADC XL | $A + XL + C \rightarrow A$ | 02 | 1 | 6 | | ADC YL | $A + YL + C \rightarrow A$ | 12 | 1 | 6 | | ADC UL | $A + UL + C \rightarrow A$ | 22 | 1 | 6 | | ADC XH | $A + XH + C \rightarrow A$ | 82 | 1 | 6 | | ADC YH | $A + YH + C \rightarrow A$ | 92 | 1 | 6 | | ADC UH | $A + UH + C \rightarrow A$ | A2 | 1 | 6 | | ADC (X) | $A + (X) + C \rightarrow A$ | 03 | 1 | 7 | | ADC (Y) | $A + (Y) + C \rightarrow A$ | 13 | 1 | 7 | | ADC (U) | $A + (U) + C \rightarrow A$ | 23 | 1 | 7 | | ADC (ab) | $A + (ab) + C \rightarrow A$ | A3 a b | 3 | 13 | | ADC #(X) | $A + \#(X) + C \rightarrow A$ | FD 03 | 2 | 11 | | ADC #(Y) | $A + \#(Y) + C \rightarrow A$ | FD 13 | 2 | 11 | | ADC #(U) | A + #(U) + C A | FD 23 | 2 | 11 | | ADC #(ab) | $A + \#(ab) + C \rightarrow A$ | .FD A3 a b | 4 | 17 | **ADI**—Performs immediate addition to the accumulator or to external memory [(R), #(R), (ab), or #(ab)]. Changes may take place in C, H, Z, or V. The carry flag C will be included in the immediate addition to the accumulator. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |------------|-------------------------------|----------------|------|-------| | ADI A,i | $A + i + C \rightarrow A$ | B3 i | 2 | 7 | | ADI (X),i | $(X) + i \rightarrow (X)$ | 4Fi | 2 | 13 | | ADI (Y),i | $(Y) + i \rightarrow (Y)$ | 5Fi | 2 | 13 | | ADI (U),i | $(U) + i \rightarrow (U)$ | 6Fi | 2 | 13 | | ADI (ab),i | $(ab) + i \rightarrow (ab)$ | EFabi | 4 | 19 | | ADI #(X),i | #(X) + i - #(X) | FD 4F i | 3 | 17 | | ADI #(Y),i | $\#(Y) + i \rightarrow \#(Y)$ | FD 5F i | 3 | 17 | | | | | | | | ADI #(U),i | $\#(U) + i \rightarrow \#(U)$ | FD 6F i | 3 | 17 | |-------------|---------------------------------|---------|---|----| | ADI #(ab),i | $\#(ab) + i \rightarrow \#(ab)$ | FDEFabi | 5 | 23 | ADR—The content of the accumulator is added into the register R in 16 bits. Change may take place in C, H, Z, or V. | Mnemonic | Symbolic Operation | нех<br>Op-Code | Byte | Cycle | |-----------|--------------------------------------------|----------------|------|-------| | ADR X | $XL + A \rightarrow XL$ | FD CA | 2 | 11 | | ADR Y | $YL + A \rightarrow YL$ | FD DA | 2 | 11 | | ADR U | UL + A - UL | FD EA | 2 | 11 | | Comment—F | $RH + 1 \rightarrow RH$ if $C7 = 1$ (no.ch | ange in CVHZ) | | | AND—The content of the accumulator is logically ANDed with the content of external memory [(R), #(R), (ab), or #(ab)] and the result is stored in the accumulator. Change may take place in the Z flag only. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |-----------|--------------------------------|----------------|------|-------| | AND (X) | $A \wedge (X) \rightarrow A$ | 09 | 1 | 7 | | AND (Y) | $A \land (Y) \rightarrow A$ | 19 | 1 | 7 | | AND (U) | A ^ (U) - A | 29 | 1 | 7 | | AND (ab) | $A \wedge (ab) \rightarrow A$ | A9 a b | 3 | 13 | | AND #(X) | A ^ #(X) - A | FD 09 | 2 | 11 | | AND #(Y) | $A \wedge \#(Y) \rightarrow A$ | FD 19 | 2 | 11 | | AND #(U) | A ^ #(U) → A | FD 29 | 2 | 11 | | AND #(ab) | A ^ #(ab) - A | FD A9 a b | 4 | 17 | | | represents the AND operat | ion | | | ANI—Logical AND of the accumulator and an immediate value, or of external memory [(R), #(R), (ab), or #(ab)] and an immediate value with the results stored in the accumulator or external memory as indicated. Change may take place in the Z flag only. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |-------------|-------------------------------------|----------------|------|-------| | ANI A,i | $A \wedge i \rightarrow A$ | B9 i | 2 | 7 | | ANI (X),i | (X) ^ i → (X) | 49 i | 2 | 13 | | ANI (Y),i | $(Y) \wedge i \rightarrow (Y)$ | 59 i | 2 | 13 | | ANI (U),i | (U) ^ i (U) | 69 i | 2 | 13 | | ANI (ab),i | (ab) ^ i → (ab) | E9 a b i | 4 | 19 | | ANI #(X),i | #(X) ^ i → #(X) | FD 49 i | 3 | 17 | | ANI #(Y),i | $\#(Y) \land i \rightarrow \#(Y)$ | FD 59 i | 3 | 17 | | ANI #(U),i | #(U) ^ i → #(U) | FD 69 i | 3 | 17 | | ANI #(ab),i | $\#(ab) \land i \rightarrow \#(ab)$ | FD E9 a b i | 5 | 23 | **DCA**—The content of external memory [(R) or #(R)] including the carry C is added to the accumulator in the binary-coded-decimal (BCD) system and the result is stored in the accumulator. Change may take place in C, H, Z, or V. | DCA (X) A + (X) + C - A 8C 1 15 | ycle | |--------------------------------------------------|------| | | 5 | | DCA (Y) A + (Y) + C $\rightarrow$ A 9C 1 15 | 5 | | DCA (U) A + (U) + C $\rightarrow$ A AC 1 15 | 5 | | DCA #(X) A + #(X) + C $\rightarrow$ A FD 8C 2 19 | ) | | DCA #(Y) | $A + \#(Y) + C \rightarrow A$ | FD 9C | 2 | 19 | |----------|-------------------------------|-------|---|----| | DCA #(U) | $A + \#(U) + C \rightarrow A$ | FD AC | 2 | 19 | **DCS**—The content of the external memory [(R) or #(R)], including the carry C is subtracted from the content of the accumulator in the BCD system, and the result is stored in the accumulator. Change may take place in C, H, Z, or V. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |----------|------------------------------------------|---------|------|-------| | DCS (X) | $A - (X) - \overline{C} \rightarrow A$ | OC. | 1 | 13 | | DCS (Y) | $A - (Y) - \overline{C} \rightarrow A$ | 1C | 1 | 13 | | DCS (U) | $A - (U) - \overline{C} \rightarrow A$ | 2C | 1 | 13 | | DCS #(X) | $A - \#(X) - \overline{C} \rightarrow A$ | FD 0C | 2 | 17 | | DCS #(Y) | $A - \#(Y) - \overline{C} \rightarrow A$ | FD 1C | 2 | 17 | | DCS #(U) | $A - \#(U) - \overline{C} \rightarrow A$ | FD 2C | 2 | 17 | DEC—Decrements the accumulator or the register (RL, RH, or R). Change may take place in C, V, H, and Z for the decrement of the accumulator, or the register, RL or RH. But no change takes place in flags when the 16-bit R is decremented. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|-----------------------|----------------|------|-------| | DEC A | $A-1 \rightarrow A$ | DF | 1 | 5 | | DEC XL | XL−1 → XL | 42 | 1 | 5 | | DEC YL | $YL-1 \rightarrow YL$ | 52 | 1 | 5 | | DEC UL | UL-1 → UL | 62 | 1 | 5 | | DEC XH | $XH-1 \rightarrow XH$ | FD 42 | 2 | 9 | | DEC YH | $YH-1 \rightarrow YH$ | FD 52 | 2 | 9 | | DEC UH | UH−1 → UH | FD 62 | 2 | 9 | | DEC X | $X-1 \rightarrow X$ | 46 | 1 | 5 | | DEC Y | $Y-1 \rightarrow Y$ | 56 | 1 | 5 | | DEC U | $U-1 \rightarrow U$ | 66 | 1 | 5 | | | | | | | **EAI**—The accumulator is EXCLUSIVE ORed with an immediate value and the result is stored in the accumulator. Change may take place in the Z flag only. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |------------|--------------------------|---------|------|-------| | EAI i | A ⊕ i A | BD i | 2 | 7 | | Comment— ⊕ | - represents the XOR ope | ration | | | **EOR**—Logical EXCLUSIVE OR (XOR) of the accumulator with external memory [(R), #(R), (ab), or #(ab)] is performed and the result is stored in the accumulator. Change may take place in the Z flag. | Mnemonic | Symbolic Operation | нех<br>Op-Code | Byte | Cycle | |-----------|--------------------------------|----------------|------|-------| | EOR (X) | $A \oplus (X) \rightarrow A$ | 0D | 1 | 7 | | EOR (Y) | $A \oplus (Y) \rightarrow A$ | 1D | 1 | 7 | | EOR (U) | A ⊕ (U) → A | 2D | 1 | 7 | | EOR (ab) | A ⊕ (ab) → A | AD a b | 3 | 13 | | EOR #(X) | $A \oplus \#(X) \rightarrow A$ | FD 0D | 2 | 11 | | EOR #(Y) | A ⊕ #(Y) → A | FD 1D | 2 | 11 | | EOR #(U) | A ⊕ #(U) → A | FD 2D | 2 | 11 | | EOR #(ab) | A ⊕ #(ab)A | FD AD a b | 4 | 17 | | | | | | | INC—Increments the accumulator or the register (RL, RH, or R). Change may take place in C, V, H, and Z for an increment of the accumulator, or the registers, RL or RH. But no change takes place in flags when the 16-bit register R is incremented. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|-------------------------|----------------|------|-------| | INC A | $A + 1 \rightarrow A$ | DD | 1 | 5 | | INC XL | $XL + 1 \rightarrow XL$ | 40 | 1 | 5 | | INC YL | $YL + 1 \rightarrow YL$ | 50 | 1 | 5 | | INC UL | UL + 1 → UL | 60 | 1 | 5 | | INC XH | $XH + 1 \rightarrow XH$ | FD 40 | 2 | 9 | | INC YH | YH + 1 → YH | FD 50 | 2 | 9 | | INC UH | UH + 1 - UH | FD 60 | 2 | 9 | | INC X | $X + 1 \rightarrow X$ | 44 | 1 | 5 | |-------|-----------------------|----|---|---| | INC Y | $Y + 1 \rightarrow Y$ | 54 | 1 | 5 | | INC U | $U + 1 \rightarrow U$ | 64 | 1 | 5 | **ORA**—The accumulator is logically ORed with external memory [(R), #(R), or (ab)] and the result is stored in the accumulator. Change may take place in the Z flag only. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |-----------|-------------------------------|----------------|------|-------| | ORA (X) | A v (X) → A | 0B | 1 | 7 | | ORA (Y) | $A \vee (Y) \rightarrow A$ | 1B | 1 | 7 | | ORA (U) | $A \vee (U) \rightarrow A$ | 2B | 1 | 7 | | ORA (ab) | $A \vee (ab) \rightarrow A$ | ABab | 3 | 13 | | ORA #(X) | A v #(X) A | FD 0B | 2 | 11 | | ORA #(Y) | $A \vee \#(Y) \rightarrow A$ | FD 1B | 2 | 11 | | ORA #(U) | A ∨ #(U) → A | FD 2B | 2 | 11 | | ORA #(ab) | A v #(ab) → A | FD AB a b | 4 | 17 | | Comment-v | - represents the OR operation | n | | | ORI—Logical OR of the accumulator or external memory [(R), #(R), (ab), or #(ab)] with an immediate value. The result is stored in the accumulator or the external memory as indicated. Change may take place in the Z flag only. | Mnemonic Symbolic Operation | | Byte | Cycle | |------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Avi - A | BB i | 2 | 7 | | $(X) \lor i \to (X)$ | 4B i | 2 | 13 | | $(Y) \vee i \rightarrow (Y)$ | 5B i | 2 | 13 | | $(U) \vee i \rightarrow (U)$ | 6B i | 2 | 13 | | (ab) v i → (ab) | EBabi | 4 | 19 | | $\#(X) \lor i \to \#(X)$ | FD 4B i | 3 | 17 | | $\#(Y) \lor i \to \#(Y)$ | FD 5B i | 3 | 17 | | #(U) v i → #(U) | FD 6B i | 3 | 17 | | #(ab) v i → #(ab) | FDEBabi | 5 | 23 | | | A $v i \rightarrow A$<br>(X) $v i \rightarrow (X)$<br>(Y) $v i \rightarrow (Y)$<br>(U) $v i \rightarrow (U)$<br>(ab) $v i \rightarrow (ab)$<br>#(X) $v i \rightarrow \#(X)$<br>#(Y) $v i \rightarrow \#(Y)$<br>#(U) $v i \rightarrow \#(U)$ | A v i — A BB i (X) v i — (X) 4B i (Y) v i — (Y) 5B i (U) v i — (U) 6B i (ab) v i — (ab) EB a b i #(X) v i — #(X) FD 4B i #(Y) v i — #(Y) FD 5B i #(U) v i — #(U) FD 6B i | Symbolic Operation Op-Code Byte A ∨ i → A BB i 2 (X) ∨ i → (X) 4B i 2 (Y) ∨ i → (Y) 5B i 2 (U) ∨ i → (U) 6B i 2 (ab) ∨ i → (ab) EB a b i 4 #(X) ∨ i → #(X) FD 4B i 3 #(Y) ∨ i → #(Y) FD 5B i 3 #(U) ∨ i → #(U) FD 6B i 3 | **SBC**—The content of the internal register [RL or RH] or external memory [(R), #(R),(ab), or #(ab)] including the carry C is subtracted from the accumulator and the result is stored in the accumulator. Change may take place in C, H, Z, or V. This operation can be expressed in the following manner: The complement of the contents in the internal register, RL or RH, or external memory, (R), #(R), (ab), or #(ab) is first obtained. Then the complement is added into the accumulator including the carry C, and the result is stored in the accumulator. Change may take place in C, H, Z, or V. | Mnemonic Symbolic Operation Op | o-Code Byte | Cycle | |--------------------------------------------------------|-------------|-------| | SBC XL $A-XL-\overline{C} \rightarrow A$ 00 | 1 | 6 | | SBC YL $A-YL-\overline{C} \rightarrow A$ 10 | 1 | 6 | | SBC UL $A-UL-\overline{C} \rightarrow A$ 20 | 1 | 6 | | SBC XH $A - XH - \overline{C} \rightarrow A$ 80 | 1 | 6 | | SBC YH $A-YH-\overline{C} \rightarrow A$ 90 | 1 | 6 | | SBC UH $A-UH-\overline{C} \rightarrow A$ A0 | ) 1 | 6 | | SBC (X) $A - (X) - \overline{C} \rightarrow A$ 01 | 1 | 7 | | SBC (Y) $A-(Y)-\overline{C} \rightarrow A$ 11 | 1 | 7 | | SBC (U) $A - (U) - \overline{C} \rightarrow A$ 21 | 1 | 7 | | SBC (ab) $A - (ab) - \overline{C} \rightarrow A$ A1 | ab 3 | 13 | | SBC #(X) $A - \#(X) - \overline{C} \rightarrow A$ FD | 01 2 | 11 | | SBC $\#(Y)$ A $-\#(Y) - \overline{C} \rightarrow A$ FD | ) 11 2 | 11 | | SBC #(U) $A - \#(U) - \overline{C} \rightarrow A$ FD | 21 2 | 11 | | SBC #(ab) $A - \#(ab) - \overline{C} \rightarrow A$ FD | ) A1 a b 4 | 17 | **SBI**—The immediate value including the carry C is subtracted from the accumulator and the result is stored in the accumulator. Change may take place in C, H, Z, or V. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|----------------------------------|----------------|------|-------| | SBI A,i | $A-i-\overline{C} \rightarrow A$ | B1 i | 2 | 7 | #### **COMPARISONS, BIT TESTS** **BII**—The accumulator or external memory [(R), #(R), (ab), or #(ab)] is logically ANDed with an immediate value. The result of the test is in the Z flag. Change may take place in the Z flag only. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |-------------|-------------------------------|----------------|------|-------| | BII A,i | A^i - Z | BFi | 2 | 7 | | BII (X),i | $(X) \wedge i \rightarrow Z$ | 4D i | 2 | 10 | | BII (Y),i | (Y) ^ i → Z | 5D i | 2 | 10 | | BII (U),i | (U) ^ i → Z | 6D i | 2 | 10 | | BII (ab),i | (ab) ^ i → Z | EDabi | 4 | 16 | | BII #(X),i | $\#(X) \land i \rightarrow Z$ | FD 4D i | 3 | 14 | | BII #(Y),i | $\#(Y) \land i \rightarrow Z$ | FD 5D i | 3 | 14 | | BII #(U),i | #(U) ^ i → Z | FD 6D i | 3 | 14 | | BII #(ab),i | #(ab) ^ i → Z | FD ED a b i | 5 | 20 | | | - represents the AND opera | ation | | | **BIT**—The accumulator is logically ANDed with external memory [(R), #(R), (ab), or #(ab)]. The result is in Z. Change may take place in the Z flag only. | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |-------------------------------|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | $A \wedge (X) \rightarrow Z$ | OF | 1 | 7 | | $A \wedge (Y) \rightarrow Z$ | 1F | 1 | 7 | | A ^ (U) → Z | 2F | 1 | 7 | | $A \wedge (ab) \rightarrow Z$ | AFab | 3 | 13 | | A ^ #(X) - Z | FD 0F | 2 | 11 | | A ^ #(Y) - Z | FD 1F | 2 | 11 | | A ^ #(Ú) - Z | FD 2F | 2 | 11 | | A ^ #(ab) - Z | FD AF a b | 4 | 17 | | | A ^ (X) - Z<br>A ^ (Y) - Z<br>A ^ (U) - Z<br>A ^ (ab) - Z<br>A ^ #(X) - Z<br>A ^ #(Y) - Z<br>A ^ #(U) - Z | Symbolic Operation Op-Code A ^ (X) - Z 0F A ^ (Y) - Z 1F A ^ (U) - Z 2F A ^ (ab) - Z AF a b A ^ #(X) - Z FD 0F A ^ #(Y) - Z FD 1F A ^ #(U) - Z FD 2F | Symbolic Operation Op-Code Byte A ^ (X) - Z 0F 1 A ^ (Y) - Z 1F 1 A ^ (U) - Z 2F 1 A ^ (ab) - Z AF a b 3 A ^ #(X) - Z FD 0F 2 A ^ #(Y) - Z FD 1F 2 A ^ #(U) - Z FD 2F 2 | CPA—Compares the contents of the accumulator with that of the register, RL or RH, or external memory, (R), #(R), (ab), or #(ab). Change may take place in C, V, H, or Z. | (22), 01 "(22), 01 2.190 | | | | | Hex | | | |--------------------------|-----------|-------|-------|---|-----------|------|------------------| | Mnemonic | Symbolic | Opera | ation | | Op-Code | Byte | Cycle | | CPA XL | A-XL | | | | 06 | 1 | 6 | | CPA YL | A-YL | | | | 16 | 1 | 6 | | CPA UL | A-UL | | | | 26 | 1 | | | CPA XH | A - XH | | | | 86 | 1 | 6 | | CPA YH | A-YH | | | | 96 | 1 | 6 | | CPA UH | A-UH | | | | A6 | 1 | 6<br>6<br>6<br>7 | | CPA (X) | A - (X) | | | | 07 | 1 | 7 | | CPA (Y) | A - (Y) | | | | 17 | 1 | 7 | | CPA (U) | A - (U) | | | | 27 | 1 | 7 | | CPA (ab) | A - (ab) | | | | A7 a b | 3 | 13 | | CPA #(X) | A - #(X) | | | | FD 07 | 2 | 11 | | CPA #(Y) | A - #(Y) | | | | FD 17 | 2 | 11 | | CPA #(U) | A - #(U) | | | | FD 27 | 2 | 11 | | CPA #(ab) | A - #(ab) | | | | FD A7 a b | 4 | 17 | | Comment- | If | C | Z | V | Н | | | | | A)op | 1 | 0 | * | * | | | | | A = op | 1 | 1 | * | * | | | | | A(op | 0 | 0 | * | * | | | $\ensuremath{\mathsf{V}}$ and $\ensuremath{\mathsf{H}}$ may change depending upon the arithmetic result of the compare. **CPI**—The content of the accumulator or the register RL or RH, is compared with the immediate value, i. Change may take place in C, V, H or Z. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|--------------------|----------------|------|-------| | CPI A,i | A-i | B7 i | 2 | 7 | | CPI XL,i | XL – i | 4E i | 2 | 7 | | | | | | | | CPI YL,i | YL-i | | | 5 | Εi | 2 | 7 | |----------|----------|---|---|---|------|---|---| | CPI UL,i | UL-i | | | 6 | Εi | 2 | 7 | | CPI XH,i | XH-i | | | 4 | Ci | 2 | 7 | | CPI YH,i | YH-i | | | 5 | iC i | 2 | 7 | | CPI UH,i | UH-i | | | 6 | Ci | 2 | 7 | | Comment- | - If | C | Z | V | Н | | | | | (op) ) i | 1 | 0 | * | * | | | | | (op) = i | 1 | 1 | * | * | | | | | (op) ( i | 0 | 0 | * | * | | | V and H may change depending upon the arithmetic result of the compare. #### LOADS, STORES **ATT**—The content of the accumulator is transferred to the T register. All flags are subject to change depending on the content of A. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |------------------|----------------------------|----------------|------|-------| | ATT<br>Comment—T | A → T<br>- Status Register | FD EC | 2 | 9 | LDA—The content of the register, RL or RH, or external memory [(R), #(R), (ab), or #(ab)] is loaded into the accumulator. When the content loaded is "00", it sets the flag Z. No change is made with respect to other flags. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |-----------|---------------------|----------------|------|------------------| | LDA XL | $XL \rightarrow A$ | 04 | 1 | 5 | | LDA YL | YL → A | 14 | 1 | 5 | | LDA UL | UL → A | 24 | 1 | 5<br>5<br>5<br>5 | | LDA XH | $XH \rightarrow A$ | 84 | 1 | 5 | | LDA YH | YH → A | 94 | 1 | 5 | | LDA UH | UH → A | A4 | 1 | 5 | | LDA (X) | $(X) \rightarrow A$ | 05 | 1 | 6 | | LDA (Y) | (Y) → A | 15 | 1 | 6 | | LDA (U) | (U) → A | 25 | 1 | 6 | | LDA (ab) | (ab) → A | A5 a b | 3 | 12 | | LDA #(X) | #(X) → A | FD 05 | 2 | 10 | | LDA #(Y) | #(Y) → A | FD 15 | 2 | 10 | | LDA #(U) | #(U) → A | FD 25 | 2 | 10 | | LDA #(ab) | #(ab) → A | FD A5 a b | 4 | 16 | | | | | | | **LDE**—The content of the register R is decremented upon loading the content of the external memory (R) into the accumulator. Change may take place only in the Z flag. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|------------------------------------------|----------------|------|-------| | LDE X | (X) - A, X - 1 - X | 47 | 1 | 6 | | LDE Y | $(Y) \rightarrow A, Y - 1 \rightarrow Y$ | 57 | 1 | 6 | | LDE U | $(U) \rightarrow A, U - 1 \rightarrow U$ | 67 | 1 | 6 | **LDI**—The immediate value is loaded into the accumulator, register (RL or RH), or the stack pointer S. Only the immediate value being placed in S may contain 2 bytes. When using LDI A,i the Z flag may change. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |-----------|--------------------|----------------|------|-------| | LDI A,i | i → A | B5 i | 2 | 6 | | LDI XL,i | i → XL | 4A i | 2 | 6 | | LDI YL,i | i → YL | 5A i | 2 | 6 | | LDI UL,i | i → UL | 6A i | 2 | 6 | | LDI XH,i | i → XH | 48 i | 2 | 6 | | LDI YH,i | i → YH | 58 i | 2 | 6 | | LDI UH,i | i → UH | 68 i | 2 | 6 | | LDI S,i,j | i → SH, j → SL | AA i j | 3 | 12 | | | | | | | **LDX**—The content of the register R, stack pointer S, or program counter P is loaded into the X register. No change takes place in flags. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|--------------------|----------------|------|-------| | LDX X | $\times - \times$ | FD 08 | 2 | 11 | | LDX Y | $Y \rightarrow X$ | FD 18 | 2 | 11 | | LDX U | U - X | FD 28 | 2 | 11 | | LDX S | $S \rightarrow X$ | FD 48 | 2 | 11 | | LDX P | $P \rightarrow X$ | FD 58 | 2 | 11 | | | | | | | **LIN**—Increments R upon loading the content of the external memory (R) into the accumulator. Change may take place only in the Z flag. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |----------|----------------------------------------|---------|------|-------| | LIN X | $(X) \rightarrow A, X+1 \rightarrow X$ | 45 | 1 | 6 | | LIN Y | $(Y) \rightarrow A, Y+1 \rightarrow Y$ | 55 | 1 | 6 | | LIN U | $(U) \rightarrow A, U+1 \rightarrow U$ | 65 | 1 | 6 | POP—The contents placed on the stack by PSH is returned to the accumulator, A or the register, R. POP increments S by one in the case of the accumulator, and increments S by two in the case of a register. The Z flag may change as a result of the POP. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |----------|-------------------------------------------|---------|------|-------| | POP A | $(S+1) \rightarrow A, S+1 \rightarrow S$ | FD 8A | 2 | 12 | | POP X | $(S+1) \rightarrow XH$ | | | | | | $(S+2) \rightarrow XL, S+2 \rightarrow S$ | FD 0A | 2 | 15 | | POP Y | $(S+1) \rightarrow YH$ | | | | | | $(S+2) \rightarrow YL, S+2 \rightarrow S$ | FD 1A | 2 | 15 | | POP U | $(S+1) \rightarrow UH$ | | | | | | $(S+2) \rightarrow UL, S+2 \rightarrow S$ | FD 2A | 2 | 15 | **PSH**—The content of the accumulator A or register R is stacked into the memory location specified by S. PSH decrements S by one in the case of the accumulator, and decrements S by two in the case of the register R. No change takes place in flags. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|-------------------------------------------|----------------|------|-------| | PSH A | $A \rightarrow (S), S-1 \rightarrow S$ | FD C8 | 2 | 11 | | PSH X | XL → (S), | | | | | | XH - (S-1), S-2 - S | FD 88 | 2 | 14 | | PSH Y | YL → (S), | | | | | | $YH \rightarrow (S-1), S-2 \rightarrow S$ | FD 98 | 2 | 14 | | PSH U | $UL \rightarrow (S)$ , | | | | | | $UH \rightarrow (S-1), S-2 \rightarrow S$ | FD A8 | 2 | 14 | **SDE**—The register R is decremented after the content of the accumulator is stored in external memory (R). No change takes place in flags. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |----------|----------------------------------------|---------|------|-------| | SDE X | $A \rightarrow (X), X-1 \rightarrow X$ | 43 | 1 | 6 | | SDE Y | $A \rightarrow (Y), Y-1 \rightarrow Y$ | 53 | 1 | 6 | | SDE U | $A \rightarrow (U), U-1 \rightarrow U$ | 63 | 1 | 6 | **SIN**—The register R is incremented after content of the accumulator is stored in external memory (R). No change takes place in flags. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|----------------------------------------|----------------|------|-------| | SIN X | $A \rightarrow (X), X+1 \rightarrow X$ | 41 | 1 | 6 | | SIN Y | $A \rightarrow (Y), Y+1 \rightarrow Y$ | 51 | 1 | 6 | | SIN U | $A \rightarrow (U), U+1 \rightarrow U$ | 61 | 1 | 6 | **STA**—The content of the accumulator is stored into register, RL or RH, or into external memory [(R), #(R), (ab), #(ab)]. No change takes place in flags. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |----------|--------------------|---------|------|-------| | STA XL | $A \rightarrow XL$ | 0A | 1 | 5 | | STA YL | A - YL | 1A | 1 | 5 | | STA UL | A → UL | 2A | 1 | 5 | | | | | | | | STA XH | $A \rightarrow XH$ | 08 | 1 | 5 | |-----------|-----------------------|-----------|---|----| | STA YH | A → YH | 18 | 1 | 5 | | STA UH | A - UH | 28 | 1 | 5 | | STA (X) | $A \rightarrow (X)$ | 0E | 1 | 6 | | STA (Y) | $A \rightarrow (Y)$ | 1E | 1 | 6 | | STA (U) | $A \rightarrow (U)$ | 2E | 1 | 6 | | STA (ab) | A → (ab) | AEab | 3 | 12 | | STA #(X) | $A \rightarrow \#(X)$ | FD 0E | 2 | 10 | | STA #(Y) | $A \rightarrow \#(Y)$ | FD 1E | 2 | 10 | | STA #(U) | A → #(U) | FD 2E | 2 | 10 | | STA #(ab) | A → #(ab) | FD AE a b | 4 | 16 | **STX**—The content of the X register is stored into register R, stack pointer S, or program counter P. No change takes place in flags. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|-----------------------------|----------------|------|-------| | STX X | $\times \rightarrow \times$ | FD 4A | 2 | 11 | | STX Y | $X \rightarrow Y$ | FD 5A | 2 | 11 | | STX U | X U | FD 6A | 2 | 11 | | STX S | X → S | FD 4E | 2 | 11 | | STX P | X - P | FD 5E | 2 | 11 | **TTA**—The content of the T register is transferred to the accumulator. The Z flag may change as a result of this operation. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |-----------|--------------------|---------|------|-------| | TTA | T - A | FD AA | 2 | 9 | | Comment-T | - Status Register | | | | Have #### **BLOCK TRANSFER, SEARCH** **AEX**—The high order 4 bit digit in the accumulator is exchanged with the lower order 4 bit digit. | Mnemonic | Symbolic Operation | | | | Hex<br>Op-Code | Byte | Cycle | |----------|--------------------|---|---|---|----------------|------|-------| | AEX | 7 | 4 | 3 | 0 | F1 | 1 | 6 | | | 1 | | _ | | | | | CIN—The content of the accumulator is compared with the content of the external memory (X), the flags C, V, H, and Z are set by the compare, then X register is incremented. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |----------|--------------------------------|---------|------|-------| | CIN | $A - (X), X + 1 \rightarrow X$ | F7 | 1 | 7 | DRL—Performs digit-to-digit forward rotation between the accumulator and external memory, [(X) or #(X)]. No change takes place with respect to flags. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |---------------------|--------------------|-------------|------|----------| | DRL (X)<br>DRL #(X) | | D7<br>FD D7 | 1 2 | 12<br>16 | | | A (X) or #(X) | | | | **DRR**—Performs digit-to-digit backward rotation between the accumulator and external memory [(X) or #(X)]. No change takes place with respect to flags. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |---------------------|--------------------|-------------|------|----------| | DRR (X)<br>DRR #(X) | | D3<br>FD D3 | 1 2 | 12<br>16 | | | A (X) or #(X) | | | | ROL—Forward rotation is made between the accumulator and the flag C. Flags C, V, H, and Z are subject to change | mbolic Operation | Op-Code | Byte | Cycle | |------------------|-----------|------|-------| | C ← 7 0 ← | DB | 1 | 6 | | | C ← 7 0 ← | | | | and | kward rotation is made I<br>the flag C. Flags C, V, | | | | NOP—No | | Hex | <u> </u> | <u> </u> | |------------------------|----------------------------------------------------------------------------------|-------------------------|------------------------|--------------|-------------------|----------------------------------------------------|-------------------------|-----------|-----------| | | nge. | Hex | <u>48</u> /800 (38/00) | 120 CONTROLS | Mnemonic<br>NOP | Symbolic Operation | Op-Code<br>38 | Byte | Cycl<br>5 | | Inemonic | Symbolic Operation | Op-Code | Byte | Cycle | ASSESSED AND | | | | | | ROR | $\begin{bmatrix} -C & -7 & 0 \end{bmatrix}$ | D1 | 1 | 9 | OFF—Res | ets the BF flip-flop. It o | causes no ci | nange | in th | | | content of the accumu<br>s C, V, H, and Z are su | | | ne left. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | | Cycl | | HL | C ← 7 0 ← 0 | D9 | 1 | 6 | OFF | 0 → BF | FD 4C | 2 | 8 | | | A | 1001000 | d to th | | RDP—Res | ets display flip-flop. | | | | | | content of the accumul<br>is C, V, H, and Z are su | | | e right. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cvc | | HR | 0 - 7 0 - C | D5 | 1 | 9 | RDP | 0 - Display | FD C0 | 2 | 8 | | 1111 | A | 55 | 27 | 3 | RECRes | ets the carry flag C off | It causes n | n cha | nge | | into th | content of the external r<br>he external memory (Y), | the X and Y | registe | ers are | | er flags. | Hex | io cha | rige | | then | incremented. No chang | | ce in f | lags. | Mnemonic | Symbolic Operation<br>0 → C | Op-Code | Byte | 0.00 | | Inemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | REC | 0 <del>-</del> C | F9 | 3 | 4 | | IN | (X) - (Y),<br>$X+1 \rightarrow X, Y+1 \rightarrow Y$ | F5 | 1 | 7 | | ets the Interrupt Enable (<br>nge in other flags. | | f. It cau | uses | | NPUT/OU | TPUT | | | | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cyc | | MO—The | contents of the accumi | ulator is tran | sferrec | d timer. | RIE | 0 IE | FD BE | 2 | 8 | | cour | e the timer is compos<br>nter, the content of the a<br>ugh 8th bits of the count | ccumulator is | s set in | the 1st | | sets the general purpose<br>change in other flags. | e flip-flop PU | off. It | caus | | bit. I | It causes no change in | flags.<br>Hex | | | Mnemonic<br>RPU | Symbolic Operation<br>0 → PU | Op-Code<br>E3 | Byte<br>1 | Cyc | | Inemonic | Symbolic Operation | Op-Code | Byte | Cycle | | 20 20 20 20 20 20 | 23-25 C 20 C | | | | .MO | A → Timer (0-7)<br>0 → Timer (8) | FD CE | 2 | 9 | | sets the general flip-flo<br>inge in other flags. | N. | t caus | ses | | | ne as AMO, except that ses no flag changes. | "1" is set in | the 9th | n bit. It | Mnemonic<br>RPV | Symbolic Operation<br>0 → PV | Hex<br>Op-Code<br>B8 | Byte<br>1 | Cyc<br>4 | | AM1 | A → Timer (0-7)<br>1 → Timer (8) | FD DE | 2 | 9 | SDP—Sets | display flip-flop. | | | | | | , minor (e) | | | | Mnemonic | O | Hex | | • | | | ds the content of the ac<br>bus. It causes no flag | change. | the e | xternal | SDP | Symbolic Operation 1 Display | <b>Op-Code</b><br>FD C1 | Byte<br>2 | 8 | | Mnemonic | Symbolic Operation A — Data Bus | Hex<br>Op-Code<br>FD CC | Byte<br>2 | Cycle<br>9 | SEC—Sets<br>flags | s the carry flag C on. It c<br>s. | | ange i | n oth | | | | | | | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Сус | | CDV—Clea | ars the internal divider. It | | lag ch | anges. | SEC | 1 - C | FB | 1 | 4 | | <b>Inemonic</b><br>CDV | Symbolic Operation 0 — Divider | Hex<br>Op-Code<br>FD 8E | Byte<br>2 | Cycle<br>8 | | the Interrupt Enable (IE | () flip-flop on. | It cau | ises | | exec | MPU is put into a halt sta | livider is still | in ope | eration. | Mnemonic<br>SIE | Symbolic Operation | Hex<br>Op-Code<br>FD 81 | Byte<br>2 | Cyc<br>8 | | | J operation can be re-<br>rupt. No changes in fla | | neans | or the | | s the general purpose fli<br>inge in other flags. | | . It cau | ises | | <b>Inemonic</b> | Symbolic Operation | Op-Code | | Cycle | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Сус | | ILT | | FD B1 | 2 | 9 | SPU | 1 PU | E1 | 1 | 4 | | mulat | contents of the input IN<br>tor. Change may take pl | ace in the Z f | | | | s the general purpose fli<br>nge in other flags. | | . It cau | ises | | will b | e no change in other fl | 0.70 | | | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cv | | /Inemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | SPV | 1 - PV | A8 | 1 | 4 | | TA | IN → A | FD BA | 2 | 9 | | | 1000 TO TO | 247 | 1,00,000 | 2 FD BA IN → A ITA By Bruce Elliott This is the third in a series of articles which will describe the MPU (microprocessor unit) used in the Radio Shack PC-2 pocket computer. It is our intention to include specific information about the 8-bit CMOS microprocessor, the machine code used by the microprocessor, as well as information about the PC-2 memory map, and certain ROM calls which are available. Please realize that much of what we are talking about refers to the overall capabilities of MPU, and does not imply that all of these things can be done with a PC-2. The information provided in these articles is the only information which is available. We will try to clarify any ambiguities which occur in the articles, but can not reply to questions outside the scope of these articles. Further, published copies of TRS-80 Microcomputer News are the only source of this information, and we will not be maintaining back issues. Parts One and Two of this series were published in the March and April issues, respectively. #### JUMPS/BRANCHES **BCH**—Causes a relative jump to a new program area that is determined by adding/subtracting the immediate value i to/from the program counter P. | | | нех | | | | | |----------|--------------------|---------|------|-------|--|--| | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | | | | BCH+i | P+i→P | 8E i | 2 | 8 | | | | BCH-i | $P-i\rightarrow P$ | 9E i | 2 | 9 | | | **BCR**—Conditional relative jump instruction. The relative jump is made when "C=0". If "C=1", control proceeds to the next instruction. It causes no flag changes. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|------------------------------------|----------------|------|-------| | BCR+i | if $C = 0$ , $P + i \rightarrow P$ | 81 i | 2 | 8-11 | | BCR-i | if $C = 0$ , $P - i \rightarrow P$ | 91 i | 2 | 8-11 | | Comment- | f C = 1, no jump | | | | **BCS**—Conditional relative jump instruction. When the condition "C=1" is met, a relative jump is made to the program area that is found after adding/subtracting the immediate value i to/from the program counter P. If "C=0", control proceeds to the next instruction without making the relative jump. It causes no flag change. | | | Hex | | | |-----------|------------------------------------|---------|------|-------| | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | | BCS+i | if $C = 1$ , $P + i \rightarrow P$ | 83 i | 2 | 8-11 | | BCS-i | if $C = 1$ , $P - i \rightarrow P$ | 93 i | 2 | 8-11 | | Comments- | if $C = 0$ , no jump | | | | **BHR**—A relative jump is made when "H=0". If "H=1", control proceeds to the next instruction. It causes no flag changes. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |------------|------------------------------------|---------|------|-------| | BHR+i | if $H=0$ , $P+i\rightarrow P$ | 85 i | 2 | 8-11 | | BHR-i | if $H = 0$ , $P - i \rightarrow P$ | 95 i | 2 | 8-11 | | Comment-if | fH=1, no jump | | | | **BHS**—A relative jump is made when "H = 1". If "H = 0", control proceeds to the next instruction. It causes no flag changes. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |------------|------------------------------------|---------|------|-------| | BHS+i | if $H = 1$ , $P + i \rightarrow P$ | 87 i | 2 | 8-11 | | BHS-i | if $H = 1$ , $P - i \rightarrow P$ | 97 i | 2 | 8-11 | | Comment-it | H=0, no jump | | | | **BVR**—A relative jump is made when "V = 0". If "V = 1", control proceeds to the next instruction. It causes no flag changes. | | | Hex | | | |------------|------------------------------------|---------|------|-------| | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | | BVR+i | if $V = 0$ , $P + i \rightarrow P$ | 8D i | 2 | 8-11 | | BVR-i | if $V = 0$ , $P - i \rightarrow P$ | 9D i | 2 | 8-11 | | Comment-if | V = 1 no jump | | | | **BVS**—A relative jump is made when "V = 1". If "V = 0", control proceeds to the next instruction. It causes no flag changes. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |------------|------------------------------------|---------|------|-------| | BVS+i | if $V = 1$ , $P + i \rightarrow P$ | 8F i | 2 | 8-11 | | BVS-i | if $V = 1$ , $P - i \rightarrow P$ | 9Fi | 2 | 8-11 | | Comment-if | fV = 0, no iump | | | | **BZR**—A relative jump is made when "Z = 0". If "Z = 1", control proceeds to the next instruction. It causes no flag changes. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |------------|------------------------------------|---------|------|-------| | BZR+i | if $Z = 0$ , $P + i \rightarrow P$ | 89 i | 2 | 8-11 | | BZR-i | if $Z = 0$ , $P - i \rightarrow P$ | 99 i | 2 | 8-11 | | Comment-if | Z=1, no iump | | | | **BZS**—A relative jump is made when "Z = 1". If "Z = 0", control proceeds to the next instruction. It causes no flag changes. | | | Hex | | 022 | |-----------|------------------------------------|---------|------|-------| | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | | BZS+i | if $Z = 1$ , $P + i \rightarrow P$ | 8B i | 2 | 8-11 | | BZS-i | if $Z = 1$ , $P - i \rightarrow P$ | 9B i | 2 | 8-11 | | Comment-i | fZ=0, no jump | | | | JMP—Causes a jump to a new program area implied by the immediate value in the second and third bytes. It causes no flag change. | | | Hex | | | | | |----------|--------------------|---------|------|-------|--|--| | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | | | | JMP i,j | i→PH, j→PL | BAij | 3 | 12 | | | LOP—This instruction causes a relative jump to a new program area if, when UL is reduced by 1, no borrow occurs (i.e., UL remains positive or zero). The new program area is determined by subtracting the immediate value i from P. If a borrow occurs when UL is reduced by 1, no jump takes place and execution proceeds to the next instruction. It causes no flag changes. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |------------|-----------------------------|------------------------------|------|-------| | LOP UL,i | UL-1-UL | 88 i | 2 | 8-11 | | Comment-if | borrow = 1, no jump; if bor | $row = 0, P - i \rightarrow$ | P | | #### CALLS **SJP**—Makes a subroutine jump to the address specified by the immediate values i and j. At the same time, the address of the next instruction is stored in the stack. It causes no flag changes. | | | Hex | | | |----------|---------------------------------------------|---------|------|-------| | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | | SJP | $PL \rightarrow (S), PH \rightarrow (S-1),$ | BÉij | 3 | 19 | | | S-2-S i-PH i-PI | | | | VCR—Conditional vector subroutine jump. When "C=0", the vector subroutine jump is performed. If "C=1", the control proceeds to the next instruction. The Z flag is reset after the jump. VCR uses FF00 through FFF6 as its vector address table, and the values 00 through F6 are valid for the immediate value. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |------------|--------------------------------------------|----------------|------|-------| | VCR i | if $C = 0$ , | Ci i | 2 | 8-21 | | | $PH \rightarrow (S-1), PL \rightarrow (S)$ | | | | | | (FFab)→PH, (FFab+1)→PL | | | | | | S-2→S | | | | | Comment-if | C=1, no jump, $ab=Hex$ | digits in i | | | VCS—Conditional vector subroutine jump. When "C = 1", it performs the vector subroutine jump. If "C = 0", the control proceeds to the next instruction. The Z flag is reset after the jump. VCS uses FF00 through FFF6 as its vector address table and the values 00 through F6 are valid for the immediate value. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | | |------------|-----------------------------|----------------|------|-------|--| | VCS i | if $C = 1$ . | C3 i | 2 | 8-21 | | | | PH→(S - 1), PL→(S) | | | | | | | (FFab)→PH, (FFab+1)→ | PL | | | | | | S-2→S | | | | | | Comment-if | C=0, no jump, $ab = Hex of$ | digits in i | | | | VEJ — Vector subroutine jump. VEJ is a one byte instruction which makes a subroutine jump based on a vectored address. The vector table is located in memory from FF00 to FFF6. The Z flag is reset after the vector jump is executed. | 5 <b>- 4</b> (4) (5) (5) (6) (7) (7) | | Hex | | | |--------------------------------------|-----------------------------------------|---------|------|-------| | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | | VEJ (ab) | $PL \rightarrow (S), S-1 \rightarrow S$ | | | | | VEJ (C0) | $PH\rightarrow(S), S-1\rightarrow S$ | CO | 1 | 17 | | VEJ (C2) | (FFab)→PH | C2 | 1 | 17 | | VEJ (C4) | (FFab + 1)→PL | C4 | 1 | 17 | | VEJ (C6) | 100 | C6 | 1 | 17 | | VEJ (C8) | | C8 | 1 | 17 | | VEJ (CA) | | CA | 1 | 17 | | VEJ (CC) | | CC | 1 | 17 | | VEJ (CE) | | CE | 1 | 17 | | | | | | | | VEJ (D0) | D0 | 1 | 17 | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----| | VEJ (D2) | D2 | 1 | 17 | | VEJ (D4) | D4 | 1 | 17 | | VEJ (D6) | D6 | 1 | 17 | | VEJ (D8) | D8 | 1 | 17 | | VEJ (DA) | DA | 1 | 17 | | VEJ (DC) | DC | 1 | 17 | | VEJ (DE) | DE | 1 | 17 | | VEJ (E0) | EO | 1 | 17 | | VEJ (E2) | E2 | 1 | 17 | | VEJ (E4) | E4 | 1 | 17 | | VEJ (E6) | E6 | 1 | 17 | | VEJ (E8) | E8 | 1 | 17 | | VEJ (EA) | EA | 1 | 17 | | VEJ (EC) | EC | 1 | 17 | | VEJ (EE) | EE | 1 | 17 | | VEJ (F0) | FO | 1 | 17 | | VEJ (F2) | F2 | 1 | 17 | | VEJ (F4) | F4 | 1 | 17 | | VEJ (F6) | F6 | 1 | 17 | | A | and the second s | | | Comment—Where, "ab" is the instruction code of VEJ. VHR—Conditional vector subroutine jump. When "H = 0", the vector subroutine jump is performed. If "H = 1", the control proceeds to the next instruction. The Z flag is reset after the jump. VHR uses FF00 through FFF6 as its vector address table and the values 00 through F6 are valid for the immediate value. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |----------|--------------------------------------------|----------------|------|-------| | VHR i | if $H = 0$ , | C5 i | 2 | 8-21 | | | $PH \rightarrow (S-1), PL \rightarrow (S)$ | | | | | | (FFab)→PH, (FFab+1)→PL | | | | | | S-2→S | | | | **Comment**—if H = 1, no jump, ab = Hex digits in i VHS — Conditional vector subroutine jump. When "H = 1", it performs the vector subroutine jump. If "H = 0", the control proceeds to the next instruction. The Z flag is reset after the jump. VHS uses FF00 through FFF6 as its vector address table and the values 00 through F6 are valid for the immediate value. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |------------|--------------------------------------------|----------------|------|-------| | VHS i | if $H = 1$ . | C7 i | 2 | 8-21 | | | $PH \rightarrow (S-1), PL \rightarrow (S)$ | | | | | | (FFab)→PH, (FFab+1)→ | PL | | | | | S-2-S | | | | | Comment-if | H=0, no jump; $ab=Hex$ | digits in i | | | VMJ—Vector subroutine jump. VMJ is the subroutine jump that branches to a vectored address, of which the high order byte is composed of "FF", and low order byte is composed of the immediate value i. Note that the Z flag is reset after the vector jump, when VMJ is executed. VMJ uses FF00 through FFF6 as its vector address table, and the values 00 through F6 are valid | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |-----------|-----------------------------------------|----------------|------|-------| | VMJ i | PL→(S), S - 1→S | CDi | 2 | 20 | | | $PH \rightarrow (S), S-1 \rightarrow S$ | | | | | | (FFab)→PH | | | | | | (FFab + 1) - PL | | | | | Comments- | ab = Hex digits in i | | | | for the immediate value. **VVS**—Conditional vector subroutine jump. When "V = 1", it performs the vector subroutine jump. If "V = 0", the control proceeds to the next instruction. The Z flag is reset after the jump. VVS uses FF00 through FFF6 as its vector address table and the values 00 through F6 are valid for the immediate value. VZR—Conditional vector subroutine jump. When "Z = 0", the vector subroutine jump is performed. If "Z = 1", the control proceeds to the next instruction. The Z flag is reset after the jump. VZR uses FF00 through FFF6 as its vector address table and the values 00 through F6 are valid for the immediate value. VZS—Conditional vector subroutine jump. When "Z = 1", it performs the vector subroutine jump. If "Z = 0", the control proceeds to the next instruction. The Z flag is reset after the jump. VZS uses FF00 through FFF6 as its vector address table, and the values 00 through F6 are valid for the immediate value. | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | Cycle | |------------|----------------------------|----------------|------|-------| | VZS i | if $Z = 1$ , | CB i | 2 | 8-21 | | | PH→(S-1), PL→(S) | | | | | | (FFab)→PH, (FFab+1)→ | PL | | | | | S-2-S | | | | | Comment-if | Z=0, no jump; $ab = Hex c$ | digits in i | | | #### RETURNS **RTI**—Return instruction from the interrupt subroutine to the main routine. All flags are subject to change. | Mnemonic | Symbolic Operation | нех<br>Op-Code | Byte | Cycle | |----------|--------------------|----------------|------|-------| | RTI | (S + 1)→PH, | 8A | 1 | 14 | | | (S+2)→PL, | | | | | | (S + 3) → T, | | | | | | C . 2 C | | | | **RTN**—Return instruction from a subroutine to the calling routine. RTN causes no changes in the flags. | Mnemonic | Symbolic Operation | Op-Code | Byte | Cycle | |----------|--------------------|---------|------|-------| | RTN | (S+1)→PH, | 9Å | 1 | 11 | | | (S+2)→PL, | | | | | | S+2-S | | | | #### TIMER The timer is composed of a 9-bit polynomial counter and the time duration can be set using the AM0 and AM1 instructions. This counter is in operation at all times, so it needs to be set to 000 (Hex) before being used. A timer interrupt request can be generated when the content of the counter is 1FF (Hex), if Interrupt Enable IE is on. When a timer interrupt occurs, interrupt processing begins at the address specified in addresses FFFA and FFFB. When a 4MHz crystal oscillator is used, the clock produces a oF of 31.25KHz with a cycle of 32 microseconds. In other words, the timer counter is incremented once every 32 microseconds. # National Computer Camp National Computer Camp (NCC), which is believed to be the first computer camp in this country, is powering up for another series of computer camps for kids from ages nine to eighteen. Campers at National Computer Camps learn to program the computer through a hands-on approach along with ample time on, and access to, the computer—two to three campers per computer. In the process, the campers come to understand the potential as well as the limitations involved in using computers. 1983 will be the sixth season of NCC, and for the first time, the camp will be held in three separate locations: Simsbury, CT; Atlanta, GA; and St. Louis, MO. The sessions will be: July 3—July 8 July 10—July 15 July 17—July 22 July 24—July 29 July 31—August 5 National Computer Camps P.O. Box 585 Orange, CT 06477 1-203-795-9667 #### FLASH—Fourth Location Now Available Dr. Zabinski has just informed us of a fourth National Computer Camp location for this summer. The fourth camp will be at Linfield College in McMinnville, Oregon. For further information, contact NCC at the address and phone number shown above. By Bruce Elliott This is the fourth in a series of articles which describe the MPU (microprocessor unit) used in the Radio Shack PC-2 pocket computer. It is our intention to include specific information about the 8-bit CMOS microprocessor, the machine code used by the microprocessor, as well as information about the PC-2 memory map, and certain ROM calls which are available. Please realize that much of what we are talking about refers to the overall capabilities of the MPU, and does not imply that all of these things can be done with a PC-2. The information provided in these articles is the only information which is available. We will try to clarify any ambiguities which occur in the articles, but can not reply to questions outside the scope of these articles. Further, published copies of *TRS-80 Microcomputer News* are the only source of this information, and we will not be maintaining back issues. Parts One, Two and Three of this series were published in the March, April, and May 1983 issues, respectively. The first three articles described the MPU used in the PC-2, including information on the MPU's structure and its machine language. We also gave you details on the PC-2 memory map and the locations of ROM routines which are available. In this article we will present two lists which we hope will make finding a particular machine language instruction easier. We will also provide some information on how you might begin to use the information we have published. #### ALPHABETIC OP-CODE LIST The following list presents the PC-2 machine language instructions alphabetically along with each code's symbolic operation and its hex op-code, and byte count. Parts two and three of this series presented the same information arranged according to function and provided details on how the instructions work. | | | | | ANI #(X),i | $\#(X) \land i \rightarrow \#(X)$ | FD 49 i | 3 | |-------------|--------------------------------|-----------|------|------------|------------------------------------|----------|---| | | | Hex | | ANI #(Y),i | $\#(Y) \land i \rightarrow \#(Y)$ | FD 59 i | 3 | | Mnemonic | Symbolic Operation | Op-Code | Byte | ANI (ab),i | (ab) ∧ i → (ab) | E9 a b i | 4 | | ADC #(ab) | $A + \#(ab) + C \rightarrow A$ | FD A3 a b | 4 | ANI (U),i | (U) $\wedge$ i $\rightarrow$ (U) | 69 i | 2 | | ADC #(U) | $A + \#(U) + C \rightarrow A$ | FD 23 | 2 | ANI (X),i | $(X) \land i \rightarrow (X)$ | 49 i | 2 | | ADC #(X) | $A + \#(X) + C \rightarrow A$ | FD 03 | 2 | ANI (Y),i | $(Y) \land i \rightarrow (Y)$ | 59 i | 2 | | ADC #(Y) | $A + \#(Y) + C \rightarrow A$ | FD 13 | 2 | ANI A,i | $A \wedge i \rightarrow A$ | B9 i | 2 | | ADC (ab) | $A + (ab) + C \rightarrow A$ | A3 a b | 3 | | | | | | ADC (U) | $A + (U) + C \rightarrow A$ | 23 | 1 | ATP | A → Data Bus | FD CC | 2 | | ADC (X) | $A + (X) + C \rightarrow A$ | 03 | 1 | | | | | | ADC (Y) | $A + (Y) + C \rightarrow A$ | 13 | 1 | ATT | $A \rightarrow T$ | FD EC | 2 | | ADC UH | $A + UH + C \rightarrow A$ | A2 | 1 | | | | | | ADC UL | $A + UL + C \rightarrow A$ | 22 | 1 | BCH+i | $P + i \rightarrow P$ | 8E i | 2 | | ADC XH | $A + XH + C \rightarrow A$ | 82 | 1 | BCH i | $P - i \rightarrow P$ | 9E i | 2 | | ADC XL | $A + XL + C \rightarrow A$ | 02 | 1 | | | | | | ADC YH | $A + YH + C \rightarrow A$ | 92 | 1 | BCR + i | if $C = 0$ , $P + i \rightarrow P$ | 81 i | 2 | | ADC YL | $A + YL + C \rightarrow A$ | 12 | 1 | BCR - i | if $C = 0$ , $P - i \rightarrow P$ | 91 i | 2 | | ADI #(ab),i | #(ab) + i → #(ab) | FDEFabi | 5 | BCS+i | if $C = 1$ , $P + i \rightarrow P$ | 83 i | 2 | | ADI #(U),i | $\#(U) + i \rightarrow \#(U)$ | FD 6F i | 3 | BCS - i | if $C = 1$ , $P - i \rightarrow P$ | 93 i | 2 | | | | | | | | | | | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | |-------------|-----------------------------------|----------------|------| | ADI #(X),i | $\#(X) + i \rightarrow \#(X)$ | FD 4F i | 3 | | ADI #(Y),i | $\#(Y) + i \rightarrow \#(Y)$ | FD 5F i | 3 | | ADI (ab),i | (ab) + i → (ab) | EFabi | 4 | | ADI (U),i | $(U) + i \rightarrow (U)$ | 6Fi | 2 | | ADI (X),i | $(X) + i \rightarrow (X)$ | 4Fi | 2 | | ADI (Y),i | $(Y) + i \rightarrow (Y)$ | 5F i | 2 | | ADI A,i | $A + i + C \rightarrow A$ | B3 i | 2 | | ADR U | UL + A → UL | FD EA | 2 | | ADR X | $XL + A \rightarrow XL$ | FD CA | 2 | | ADR Y | $YL + A \rightarrow YL$ | FD DA | 2 | | AEX | A 3 0 | F1 | 1 | | | | | | | AM0 | A → Timer (0-7) | FD CE | 2 | | | 0 → Timer (8) | בט טב | | | AM1 | A → Timer (0-7)<br>1 → Timer (8) | FD DE | 2 | | AND #(ab) | A ∧ #(ab) → A | FD A9 a b | 4 | | AND #(U) | $A \wedge \#(U) \rightarrow A$ | FD 29 | 2 | | AND #(X) | $A \wedge \#(X) \rightarrow A$ | FD 09 | 2 | | AND #(Y) | $A \wedge \#(Y) \rightarrow A$ | FD 19 | 2 | | AND (ab) | $A \wedge (ab) \rightarrow A$ | A9 a b | 3 | | AND (U) | $A \wedge (U) \rightarrow A$ | 29 | 1 | | AND (X) | $A \wedge (X) \rightarrow A$ | 09 | 1 | | AND (Y) | $A \wedge (Y) \rightarrow A$ | 19 | 1 | | ANI #(ab),i | #(ab) ∧ i → #(ab) | FD E9 a b i | 5 | | ANI #(U),i | #(U) ∧ i → #(U) | FD 69 i | 3 | | ANI #(X),i | $\#(X) \land i \rightarrow \#(X)$ | FD 49 i | 3 | | ANI #(Y),i | $\#(Y) \land i \rightarrow \#(Y)$ | FD 59 i | 3 | | ANI (ab),i | (ab) ∧ i → (ab) | E9 a b i | 4 | | ANI (U),i | $(U) \land i \rightarrow (U)$ | 69 i | 2 | | ANI (X),i | $(X) \land i \rightarrow (X)$ | 49 i | 2 | | ANI (Y),i | $(Y) \land i \rightarrow (Y)$ | 59 i | 2 | | ANI A,i | $A \wedge i \rightarrow A$ | B9 i | 2 | | ATD | A . Data Bus | ED 00 | 0 | | | | Hex | | | | Hex | | |-----------------------------------------|------------------------------------------------------------------|---------------------|-------------------|--------------------|--------------------------------------------------------------|--------------|------| | Mnemonic | Symbolic Operation | Op-Code | Byte | Mnemonic | Symbolic Operation | Op-Code | Byte | | BHR+i | if $H = 0$ , $P + i \rightarrow P$ | 85 i | 2 | DCA (U) | $A + (U) + C \rightarrow A$ | AC | 1 | | BHR - i | if $H = 0$ , $P - i \rightarrow P$ | 95 i | 2 | DCA (X) | $A + (X) + C \rightarrow A$ | 8C | 1 | | BHS+i | if $H=1$ , $P+i \rightarrow P$ | 87 i | 2 | DCA (Y) | $A + (Y) + C \rightarrow A$ | 9C | 1 | | BHS - i | if $H = 1$ , $P - i \rightarrow P$ | 97 i | 2 | DCS #(U) | $A - \#(U) - \overline{C} \rightarrow A$ | FD 2C | 2 | | 100000000000000000000000000000000000000 | | E35. 10 | 9751 | DCS #(X) | $A - \#(X) - \overline{C} \rightarrow A$ | FD 0C | 2 | | BII #(ab),i | #(ab) $\wedge$ i $\rightarrow$ Z | FDEDabi | 5 | DCS #(Y) | $A - \#(Y) - \overline{C} \rightarrow A$ | FD 1C | 2 | | BII #(U),i | $\#(U) \land i \rightarrow Z$ | FD 6D i | 3 | DCS (U) | $A - (U) - \overline{C} \rightarrow A$ | 2C | 1 | | BII #(X),i | $\#(X) \land i \rightarrow Z$ | FD 4D i | 3<br>3 | DCS (X) | $A - (X) - \overline{C} \rightarrow A$ | OC | 1 | | BII #(Y),i | $\#(Y) \land i \rightarrow Z$<br>(ab) $\land i \rightarrow Z$ | FD 5D i<br>ED a b i | 4 | DCS (Y) | $A - (Y) - \overline{C} \rightarrow A$ | 1C | 1 | | BII (ab),i<br>BII (U),i | $(U) \land i \rightarrow Z$ | 6D i | 2 | DEC A | $A - 1 \rightarrow A$ | DF | 1 | | BII (X),i | $(X) \land i \rightarrow Z$ | 4D i | 2 | DEC U | Ü – 1 → Ü | 66 | i | | BII (Y),i | $(Y) \land i \rightarrow Z$ | 5D i | 2 | DEC UH | UH - 1 → UH | FD 62 | 2 | | BII A,i | $A \wedge i \rightarrow Z$ | BF i | 2 | DEC UL | UL - 1 → UL | 62 | 1 | | | | | | DEC X | $X - 1 \rightarrow X$ | 46 | 1 | | BIT #(ab) | A ∧ #(ab) → Z | FD AF a b | 4 | DEC XH | XH - 1 → XH | FD 42 | 2 | | BIT #(U) | A ∧ #(U) → Z | FD 2F | 2 | DEC XL<br>DEC Y | $XL - 1 \rightarrow XL$<br>$Y - 1 \rightarrow Y$ | 42<br>56 | 1 | | BIT #(X)<br>BIT #(Y) | $A \wedge \#(X) \rightarrow Z$<br>$A \wedge \#(Y) \rightarrow Z$ | FD 0F<br>FD 1F | 2 | DEC YH | $Y = 1 \rightarrow Y$<br>$YH = 1 \rightarrow YH$ | 56<br>FD 52 | 2 | | BIT (ab) | $A \wedge \pi(1) \rightarrow Z$<br>$A \wedge (ab) \rightarrow Z$ | AFab | 3 | DEC YL | $YL - 1 \rightarrow YL$ | 52 | 1 | | BIT (U) | $A \wedge (U) \rightarrow Z$ | 2F | 1 | DEO 12 | TE CONTROL TE | 02 | • | | BIT (X) | $A \wedge (X) \rightarrow Z$ | OF | 1 | | | | | | BIT (Y) | $A \wedge (Y) \rightarrow Z$ | 1F | 1 | DRL #(X) | | FD D7 | 2 | | | | | | DRL (X) | | D7 | 1 | | BVR+i | if $V = 0$ , $P + i \rightarrow P$ | 8D i | 2 | | TT TT | | | | BVR- i | if $V = 0$ , $P - i \rightarrow P$ | 9D i | 2 | | A (X) or #(X) | | | | BVS+i | if $V = 1$ , $P + i \rightarrow P$ | 8F i | 2 | | | | | | BVS - i | if $V = 1$ , $P \rightarrow i \rightarrow P$ | 9F i | 2 | | | | | | 5.0 | West Frod of Sect 15 Sect. | 01 1 | , m. | DRR #(X) | | FD D3 | 2 | | BZR+i | if $Z=0$ , $P+i \rightarrow P$ | 89 i | 2 | DRR (X) | | D3 | 1 | | BZR - i | if $Z = 0$ , $P - i \rightarrow P$ | 99 i | 2 | | | | | | | | | | | A $(X)$ or $\#(X)$ | | | | BZS+i | if $Z = 1$ , $P + i \rightarrow P$ | 8B i | 2 | EALi | $A \oplus i \rightarrow A$ | BD i | 2 | | BZS – i | if $Z = 1$ , $P - i \rightarrow P$ | 9B i | 2 | LAIT | A 01 - A | 001 | 2 | | CDV | 0 → Divider | FD 8E | 2 | EOR #(ab) | A ⊕ #(ab) → A | FD AD a b | 4 | | | | 1000 | _ | EOR #(U) | $A \oplus \#(U) \rightarrow A$ | FD 2D | 2 | | CIN | $A - (X), X + 1 \rightarrow X$ | F7 | 1 | EOR #(X) | $A \oplus \#(X) \rightarrow A$ | FD 0D | 2 | | 227 3277 | 2 80 80 | 220.2 | | EOR #(Y) | $A \oplus \#(Y) \rightarrow A$ | FD 1D | 2 | | CPA #(ab) | A - #(ab) | FD A7 a b | 4 | EOR (ab) | $A \oplus (ab) \rightarrow A$ | AD a b<br>2D | 3 | | CPA #(U) | A - #(U) | FD 27 | 2 | EOR (U)<br>EOR (X) | $A \oplus (U) \rightarrow A$<br>$A \oplus (X) \rightarrow A$ | 0D | 1 | | CPA #(X)<br>CPA #(Y) | A - #(X)<br>A - #(Y) | FD 07<br>FD 17 | 2 | EOR (Y) | $A \oplus (Y) \rightarrow A$ | 1D | i | | CPA (ab) | A – (ab) | A7 a b | 3 | 2011(1) | | | , | | CPA (U) | A - (U) | 27 | 1 | HLT | | FD B1 | 2 | | CPA (X) | A - (X) | 07 | 1 | | | | | | CPA (Y) | A - (Y) | 17 | 1 | INC A | $A + 1 \rightarrow A$ | DD | 1 | | CPA UH | A – UH | A6 | 1 | INC U | U + 1 → U | 64 | 1 | | CPA UL | A ~ UL | 26 | 1 | INC UH | UH + 1 → UH<br>UL + 1 → UL | FD 60<br>60 | 2 | | CPA XH<br>CPA XL | A – XH<br>A – XL | 86<br>06 | 4 | INC UL | $X + 1 \rightarrow X$ | 44 | 1 | | CPA YH | A – YH | 96 | 1 | INC XH | XH + 1 → XH | FD 40 | 2 | | CPA YL | A – ÝL | 16 | 1 | INC XL | $XL + 1 \rightarrow XL$ | 40 | 1 | | | 83 AT | | | INC Y | $Y + 1 \rightarrow Y$ | 54 | 1 | | CPI A,i | A - i | B7 i | 2 | INC YH | YH + 1 → YH | FD 50 | 2 | | CPI UH,i | UH – i | 6C i | 2 | INC YL | $YL + 1 \rightarrow YL$ | 50 | 1 | | CPI UL,i | UL - i | 6E i | 2 | 177 | IN I | ED DA | | | CPI XH,i | XH – i | 4C i | 2 | ITA | IN → A | FD BA | 2 | | CPI XL,i<br>CPI YH,i | XL – î<br>YH – î | 4E i<br>5C i | 2<br>2 | JMP i,j | $i \rightarrow PH, j \rightarrow PL$ | BAij | 3 | | CPI YL,i | YL – i | 5E i | 2 | JIVII. I,J | 1 S CHAISTE | DATI | J | | | (19년 전: | | <del>(10</del> 0) | LDA #(ab) | #(ab) → A | FD A5 a b | 4 | | DCA #(U) | $A + \#(U) + C \rightarrow A$ | FD AC | 2 | LDA #(U) | #(U) → A | FD 25 | 2 | | DCA #(X) | $A + \#(X) + C \rightarrow A$ | FD 8C | 2 | LDA #(X) | $\#(X) \rightarrow A$ | FD 05 | 2 | | DCA #(Y) | $A + \#(Y) + C \rightarrow A$ | FD 9C | 2 | LDA #(Y) | $\#(Y) \rightarrow A$ | FD 15 | 2 | | | | | | | | | | | | | Hex | - | | | Hex | | |--------------------------|------------------------------------------------------|--------------------|--------|-------------------------------------------------|--------------------------------------------------------------------|-----------|-------| | Mnemonic | Symbolic Operation | Op-Code | Byte | Mnemonic | Symbolic Operation | Op-Code | Byte | | LDA (ab) | (ab) → A | A5 a b | 3 | PSH A | $A \rightarrow (S), S-1 \rightarrow S$ | FD C8 | 2 | | LDA (U) | (U) → A | 25 | 1 | PSH U | UL → (S), | ED 40 | 0 | | LDA (X) | $(X) \rightarrow A$ | 05 | 1 | PSH X | $UH \rightarrow (S-1), S-2 \rightarrow S$ | FD A8 | 2 | | LDA (Y)<br>LDA UH | (Y) → A<br>UH → A | 15<br>A4 | 1 | ron x | $XL \rightarrow (S),$<br>$XH \rightarrow (S-1), S-2 \rightarrow S$ | FD 88 | 2 | | LDA UL | UL → A | 24 | 1 | PSH Y | $YL \rightarrow (S),$ | 10 00 | 2 | | LDA XH | XH → A | 84 | i | 1 011 1 | $YH \rightarrow (S-1), S-2 \rightarrow S$ | FD 98 | 2 | | LDA XL | XL → A | 04 | 1 | | (0 1), 0 2 0 | 1000 | - | | LDA YH | YH → A | 94 | 1 | RDP | 0 → Display | FD C0 | 2 | | LDA YL | YL → A | 14 | 1 | | to 1751 | | | | | | | | REC | 0 → C | F9 . | 1 | | LDE U | $(U) \rightarrow A, U-1 \rightarrow U$ | 67 | 1 | | | | | | LDE X | $(X) \rightarrow A, X-1 \rightarrow X$ | 47 | 1 | RIE | 0 → IE | FD BE | 2 | | LDE Y | $(Y) \rightarrow A, Y-1 \rightarrow Y$ | 57 | 1 | | | | | | 1014 | | DE : | 0 | | | | | | LDI A,i | i → A | B5 i | 2 | ROL | - C - 7 0 - | DB | 1 | | LDI S,i,j | i → SH, j → SL<br>i → UH | AA i j<br>68 i | 2 | | | | | | LDI UH,i<br>LDI UL,i | i → UL | 6A i | 2 | | | | | | LDI XH,i | i → XH | 48 i | 2 | | | | | | LDI XL.i | i → XL | 4A i | 2 | ROR | C 7 0 | D1 | 1 | | LDI YH,i | i → YH | 58 i | 2 | | | | | | LDI YL,i | i → YL | 5A i | 2 | | ^ | | | | | | | | RPU | 0 → PU | E3 | 1 | | LDX P | $P \rightarrow X$ | FD 58 | 2 | RPU | 0 <del>-</del> P0 | E3 | 1 | | LDX S | $S \rightarrow X$ | FD 48 | 2 | RPV | 0 → PV | B8 | 1 | | LDX U | $U \rightarrow X$ | FD 28 | 2 | | 21 | 200 | | | LDX X | $X \rightarrow X$ | FD 08 | 2 | RTI | $(S + 1) \rightarrow PH$ , | 8A | 1 | | LDX Y | $Y \rightarrow X$ | FD 18 | 2 | | $(S + 2) \rightarrow PL$ | | | | | Paris 1989 Indicates (1980) | 2/2 - | 2 | | $(S + 3) \rightarrow T$ | | | | LIN U | $(U) \rightarrow A, U+1 \rightarrow U$ | 65 | 1 | | $S + 3 \rightarrow S$ | | | | LIN X | $(X) \rightarrow A, X+1 \rightarrow X$ | 45 | 1 | DTN | (0 1 4) BH | 0.4 | ŭ. | | LIN Y | $(Y) \rightarrow A, Y+1 \rightarrow Y$ | 55 | 1 | RTN | $(S + 1) \rightarrow PH$ | 9A | 1 | | LOBIU | UL - 1 → UL | 00: | 2 | | $(S + 2) \rightarrow PL,$<br>$S + 2 \rightarrow S$ | | | | LOP UL,i | $UL - I \rightarrow UL$ If borrow = 0, P - | 88 i | < | | 5 + 2 - 5 | | | | | 11 DONOW = 0, P - | 13.6 | | SBC #(ab) | $A - \#(ab) - \overline{C} \rightarrow A$ | FD A1 a b | 4 | | NOP | | 38 | 1 | SBC #(U) | $A - \#(U) - \overline{C} \rightarrow A$ | FD 21 | 2 | | NOI | | 00 | | SBC #(X) | $A - \#(X) - \overline{C} \rightarrow A$ | FD 01 | 2 | | OFF | 0 → BF | FD 4C | 2 | SBC #(Y) | $A - \#(Y) - \overline{C} \rightarrow A$ | FD 11 | 2 | | | | | | SBC (ab) | $A - (ab) - \overline{C} \rightarrow A$ | A1 a b | 3 | | ORA #(ab) | $A \vee \#(ab) \rightarrow A$ | FD AB a b | 4 | SBC (U) | $A - (U) - \overline{C} \rightarrow A$ | 21 | 1 | | ORA #(U) | A v #(U) → A | FD 2B | 2 | SBC (X) | $A - (X) - \overline{C} \rightarrow A$ | 01 | 1 | | ORA #(X) | $A \vee \#(X) \rightarrow A$ | FD 0B | 2 | SBC (Y) | $A - (Y) - \overline{C} \rightarrow A$ | 11 | 1 | | ORA #(Y) | $A \vee \#(Y) \rightarrow A$ | FD 1B | 2 | SBC UH | $A - UH - \overline{C} \rightarrow A$ | A0 | 1 | | ORA (ab) | $A \vee (ab) \rightarrow A$ | ABab | 3 | SBC UL | $A - UL - \overline{C} \rightarrow A$ | 20 | 1 | | ORA (U) | $A \vee (U) \rightarrow A$ | 2B | 1 | SBC XH | $A - XH - \overline{C} \rightarrow A$ | 80 | 1 | | ORA (X) | $A \vee (X) \rightarrow A$ | 0B | 1 | SBC XL | $A - XL - \overrightarrow{C} \rightarrow A$ | 00 | 1 | | ORA (Y) | $A \vee (Y) \rightarrow A$ | 1B | 1 | SBC YH | $A - YH - \overline{C} \rightarrow A$ | 90 | 1 | | ODI #/-137 | #/ab) v : 4/ab) | ED ED a b | 5 | SBC YL | $A - YL - \overline{C} \rightarrow A$ | 10 | 1 | | ORI #(ab),i | #(ab) v i → #(ab) | FD EB a b i | 5<br>3 | SBI A, i | $A - i - \overline{C} \rightarrow A$ | B1 i | 2 | | ORI #(U),i | $\#(U) \lor i \to \#(U)$<br>$\#(X) \lor i \to \#(X)$ | FD 6B i<br>FD 4B i | 3 | 975775 (A.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1 | 309 259 576 055 | | | | ORI #(X),i<br>ORI #(Y),i | $\#(Y) \lor i \to \#(Y)$ | FD 5B i | 3 | SDE U | $A \rightarrow (U), U-1 \rightarrow U$ | 63 | 1 | | ORI (ab),i | (ab) $\forall i \rightarrow \pi(i)$ | EBabi | 4 | SDE X | $A \rightarrow (X), X-1 \rightarrow X$ | 43 | 1 | | ORI (U),i | $(U) \lor i \to (U)$ | 6B i | 2 | SDE Y | $A \rightarrow (Y), Y-1 \rightarrow Y$ | 53 | 1 | | ORI (X),i | $(X) \lor i \to (X)$ | 4B i | 2 | CDD | 1 Dianle | ED C1 | 2 | | ORI (Y),i | $(Y) \lor i \to (Y)$ | 5B i | 2 | SDP | 1 → Display | FD C1 | 2 | | ORI A,i | $A \vee i \rightarrow A$ | BB i | 2 | SEC | 1 → C | FB | 1 | | 2 15 | | | | 320 | | | 355 | | POP A | $(S+1) \rightarrow A, S+1 \rightarrow S$ | FD 8A | 2 | Sample State | | Ladoren | | | POP U | $(S+1) \rightarrow UH$ | | | SHL | C 7 0 0 0 | D9 | 1 | | | $(S+2) \rightarrow UL, S+2 \rightarrow S$ | FD 2A | 2 | | A | | | | POP X | $(S+1) \rightarrow XH$ | | 430.00 | | | | | | | $(S+2) \rightarrow XL, S+2 \rightarrow S$ | FD 0A | 2 | SHR | 0-7 0-0 | D5 | 1 | | POP Y | (S+1) → YH, | FD 44 | 0 | OI III | V - [ V - [ V ] | | (10)3 | | | $(S+2) \rightarrow YL, S+2 \rightarrow S$ | FD 1A | 2 | | A | | | | | | | | | | | | | Mnemonic<br>SIE | Symbolic Operation<br>1 → IE | Hex<br>Op-Code<br>FD 81 | Byte<br>2 | Mnemonic<br>VEJ (DE) | Symbolic Operation | Hex<br>Op-Code<br>DE | Byte<br>1 | |----------------------|------------------------------------------------------------------|-------------------------|-----------|-----------------------|---------------------------------------------------------------------------------------------------------------|------------------------------|--------------------------| | SIN U | $A \rightarrow (U), U+1 \rightarrow U$ | 61 | 1 | VEJ (E0) | | E0 | 1 | | SIN X | $A \rightarrow (X), X+1 \rightarrow X$ | 41 | 1 | VEJ (E2)<br>VEJ (E4) | | E2 | 1 | | SIN Y | $A \rightarrow (Y), Y+1 \rightarrow Y$ | 51 | i | VEJ (E6) | | E4<br>E6 | 1 | | | | | | VEJ (E8) | | E8 | 1 | | SJP | $PL \rightarrow (S), PH \rightarrow (S-1),$ | BEij | 3 | VEJ (EA) | | EA | 1 | | | $S - 2 \rightarrow S, i \rightarrow PH,$ | | | VEJ (EC) | | EC | 1 | | | j → PL | | | VEJ (EE) | | EE | 1 | | | | | | VEJ (F0) | | F0 | 1 | | SPU | 1 → PU | E1 | 1 | VEJ (F2) | | F2 | 1 | | SPV | 1 → PV | A8 | 1 | VEJ (F4)<br>VEJ (F6) | | F4<br>F6 | 1 | | STA #(ab) | A → #(ab) | FD AE a b | 4 | VHR i | if $H = 0$ , | C5 i | 2 | | STA #(U) | A → #(U) | FD 2E | 2 | VIII | $PH \rightarrow (S-1), PL \rightarrow (S)$ | Col | 2 | | STA #(X) | $A \rightarrow \#(X)$ | FD 0E | 2 | | (FFab) → PH | | | | STA #(Y) | $A \rightarrow \#(Y)$ | FD 1E | 2 | | (FFab+1) → PL | | | | STA (ab) | A → (ab) | AE a b | 3 | | S - 2 → S | | | | STA (U) | $A \rightarrow (U)$ | 2E | 1 | | | | | | STA (X) | $A \rightarrow (X)$ | 0E | 1 | VHS i | if $H = 1$ , | C7 i | 2 | | STA (Y) | A → (Y) | 1E | 1 | | $PH \rightarrow (S-1), PL \rightarrow (S)$ | | | | STA UH<br>STA UL | A → UH<br>A → UL | 28<br>2A | 4 | | (FFab) → PH | | | | STA OL | A → XH | 08 | 1 | | (FFab + 1) → PL | | | | STA XL | $A \rightarrow XL$ | 0A | 1 | | $S-2 \rightarrow S$ | | | | STA YH | A → YH | 18 | 1 | VMJ i | $PL \rightarrow (S), S-1 \rightarrow S$ | CDi | 2 | | STA YL | $A \rightarrow YL$ | 1A | 1 | VIVIJ I | $PH \rightarrow (S), S-1 \rightarrow S$<br>$PH \rightarrow (S), S-1 \rightarrow S$<br>$(FFab) \rightarrow PH$ | CDT | 2 | | STX P | $X \rightarrow P$ | FD 5E | 2 | | (FFab+1) → PL | | | | STX S | $X \rightarrow S$ | FD 4E | 2 | | <i>y</i> | | | | STX U | X → U | FD 6A | 2 | VVS i | if $V = 1$ , | CFi | 2 | | STX X | $X \to X$ | FD 4A | 2 | | $PH \rightarrow (S-1), PL \rightarrow (S)$ | | | | STX Y | $X \rightarrow Y$ | FD 5A | 2 | | (FFab) → PH | | | | TIN | $(X) \rightarrow (Y),$<br>$X+1 \rightarrow X, Y+1 \rightarrow Y$ | F5 | 1 | | $(FFab+1) \rightarrow PL$ $S - 2 \rightarrow S$ | | | | | | | | VZR i | if $Z = 0$ , | C9 i | 2 | | TTA | $T \rightarrow A$ | FD AA | 2 | | $PH \rightarrow (S-1), PL \rightarrow (S)$ | | | | WOD: | 30 0 | 04: | 0 | | (FFab) →PH | | | | VCR i | if $C = 0$ ,<br>PH $\rightarrow$ (S - 1), PL $\rightarrow$ (S) | C1 i | 2 | | (FFab+1) →PL | | | | | (FFab) → PH | | | | S - 2 →S | | | | | (FFab+1) → PL | | | VZS i | 47 4 | CB i | 2 | | | S - 2 →S | | | V25 I | if $Z = 1$ ,<br>PH $\rightarrow$ (S – 1), PL $\rightarrow$ (S) | CBT | 2 | | | | | | | (FFab) →PH | | | | VCS i | if $C = 1$ , | C3 i | 2 | | (FFab+1) →PL | | | | | $PH \rightarrow (S-1), PL \rightarrow (S)$ | | | | S - 2 →S | | | | | (FFab) → PH | | | | | | Ä | | | $(FFab+1) \rightarrow PL$<br>S - 2 → S | | | | | AUTO-COTT / PERMANANT MENANT | | | | 5-2-5 | | | Radio Jhack<br>TRS-80 | TR9-80 100 100 100 | SEEN TO | | | VEJ (C0) | $PL \rightarrow (S), S-1 \rightarrow S$ | CO | 1 | CONSTITUTE | E INC OD SECTIONS | | | | VEJ (C2) | $PH \rightarrow (S), S-1 \rightarrow S$ | C2 | 1 | OFF ON | | ė ė | SHIFT | | VEJ (C4) | (FFab) → PH | C4 | 1 | White the second | | | 2 CA | | VEJ (C6) | (FFab+1) → PL | C6 | 1 | | | 0 | The second second second | | VEJ (C8) | | C8 | 1 | | | | | | VEJ (CA) | | CA | 1 | | OVBNM D | | | | VEJ (CC) | | CC | 1 | SM. (\$) | NCL SPACE ENTER C | | | | VEJ (CE) | | CE<br>D0 | 1 | | | | | | VEJ (D0)<br>VEJ (D2) | | D2 | 1 | MUMERIC | OD OODE 1 107 | | | | VEJ (D2)<br>VEJ (D4) | | D4 | 1 | | OP-CODE LIST | | | | VEJ (D6) | | D6 | 1 | | llowing list presents the | | | | VEJ (D8) | | D8 | 1 | instructions | numerically and include | des the hex and | d decimal | | VEJ (DA) | | DA | 1 | | he op-codes. Numeric | | | | VEJ (DC) | | DC | 1 | from the lis | t have no valid op-code | e that we are av | ware of. | | | | | | | | | | | Hex<br>Value | Decimal<br>Value | Opcode | Hex<br>Value | Decimal<br>Value | Opcode | Hex<br>Value | Decimal<br>Value | Opcode | |------------------------------|------------------------------|---------------------------------------------------------|------------------------------|----------------------------------|------------------------------------------------|----------------------------------|--------------------------------------|--------------------------------------------------| | 00<br>01<br>02 | 00<br>01<br>02 | SBC XL<br>SBC (X)<br>ADC XL | 5D i<br>5E i<br>5F i | 93 i<br>94 i<br>95 i | BII (Y),i<br>CPI YL,i<br>ADI (Y),i | C0<br>C1 i<br>C2 | 192<br>193 i<br>194 | VEJ (C0)<br>VCR i<br>VEJ (C2) | | 03<br>04<br>05 | 03<br>04<br>05 | ADC (X)<br>LDA XL<br>LDA (X) | 60<br>61 | 96<br>97 | INC UL<br>SIN U | C3 i<br>C4<br>C5 i | 195 i<br>196<br>197 i | VCS i<br>VEJ (C4)<br>VHR i | | 06<br>07<br>08<br>09 | 06<br>07<br>08<br>09 | CPA XL<br>CPA (X)<br>STA XH<br>AND (X) | 62<br>63<br>64<br>65 | 98<br>99<br>100<br>101 | DEC UL<br>SDE U<br>INC U<br>LIN U | C6<br>C7 i<br>C8<br>C9 i | 198<br>199 i<br>200<br>201 i | VEJ (C6)<br>VHS i<br>VEJ (C8)<br>VZR i | | OA<br>OB<br>OC | 10<br>11<br>12 | STA XL<br>ORA (X)<br>DCS (X) | 66<br>67<br>68 i | 102<br>103<br>104 i | DEC U<br>LDE U<br>LDI UH,i | CA<br>CB i | 202<br>203 i<br>204 | VEJ (CA)<br>VZS i<br>VEJ (CC) | | OD<br>OE<br>OF | 13<br>14<br>15 | EOR (X)<br>STA (X)<br>BIT (X) | 69 i<br>6A i<br>6B i | 105 i<br>106 i<br>107 i | ANI (U),i<br>LDI UL,i<br>ORI (U),i | CD i<br>CE<br>CF i | 205 i<br>206<br>207 i | VMJ i<br>VEJ (CE)<br>VVS i | | 10<br>11<br>12 | 16<br>17<br>18 | SBC YL<br>SBC (Y)<br>ADC YL | 6C i<br>6D i<br>6E i<br>6F i | 108 i<br>109 i<br>110 i<br>111 i | CPI UH,i<br>BII (U),i<br>CPI UL,i<br>ADI (U),i | D0<br>D1<br>D2 | 208<br>209<br>210 | VEJ (D0)<br>ROR<br>VEJ (D2) | | 13<br>14<br>15 | 19<br>20<br>21 | ADC (Y)<br>LDA YL<br>LDA (Y) | 80<br>81 i | 128<br>129 i | SBC XH<br>BCR+ i | D3<br>D4<br>D5 | 211<br>212<br>213 | DRR (X)<br>VEJ (D4)<br>SHR | | 16<br>17<br>18<br>19 | 22<br>23<br>24<br>25 | CPA YL<br>CPA (Y)<br>STA YH<br>AND (Y) | 82<br>83 i<br>84 | 130<br>131 i<br>132 | ADC XH<br>BCS + i<br>LDA XH | D6<br>D7<br>D8 | 214<br>215<br>216 | VEJ (D6)<br>DRL (X)<br>VEJ (D8) | | 1A<br>1B<br>1C | 26<br>27<br>28 | STA YL<br>ORA (Y)<br>DCS (Y) | 85 i<br>86<br>87 i<br>88 i | 133 i<br>134<br>135 i<br>136 i | BHR+ i<br>CPA XH<br>BHS+ i<br>LOP UL,i | D9<br>DA<br>DB<br>DC | 217<br>218<br>219<br>220 | SHL<br>VEJ (DA)<br>ROL<br>VEJ (DC) | | 1D<br>1E<br>1F | 29<br>30<br>31 | EOR (Y)<br>STA (Y)<br>BIT (Y) | 89 i<br>8A<br>8B i | 137 i<br>138<br>139 i | BZR+ i<br>RTI<br>BZS+ i | DD<br>DE<br>DF | 221<br>222<br>223 | INC A<br>VEJ (DE)<br>DEC A | | 20<br>21<br>22 | 32<br>33<br>34 | SBC UL<br>SBC (U)<br>ADC UL | 8C<br>8D i<br>8E i<br>8F i | 140<br>141 i<br>142 i<br>143 i | DCA (X)<br>BVR + i<br>BCH + i<br>BVS + i | E0<br>E1<br>E2 | 224<br>225<br>226 | VEJ (E0)<br>SPU | | 23<br>24<br>25 | 35<br>36<br>37 | ADC (U)<br>LDA UL<br>LDA (U) | 90<br>91 i | 144<br>145 î | SBC YH<br>BCR-i | E3<br>E4<br>E6 | 227<br>228<br>230 | VEJ (E2)<br>RPU<br>VEJ (E4)<br>VEJ (E6) | | 26<br>27<br>28<br>29 | 38<br>39<br>40<br>41 | CPA UL<br>CPA (U)<br>STA UH<br>AND (U) | 92<br>93 i<br>94 | 146<br>147 i<br>148 | ADC YH<br>BCS-i<br>LDA YH | E8<br>E9 a b i | 232<br>233 a b i<br>234 | VEJ (E8)<br>ANI (ab),i<br>VEJ (EA) | | 2A<br>2B<br>2C | 42<br>43<br>44 | STA ÚL<br>ORA (U)<br>DCS (U) | 95 i<br>96<br>97 i<br>99 i | 149 i<br>150<br>151 i<br>153 i | BHR – i<br>CPA YH<br>BHS – i<br>BZR – i | EBabi<br>EC<br>EDabi<br>EE | 235 a b i<br>236<br>237 a b i<br>238 | ORI (ab),i<br>VEJ (EC)<br>BII (ab),i<br>VEJ (EE) | | 2D<br>2E<br>2F | 45<br>46<br>47 | EOR (U)<br>STA (U)<br>BIT (U) | 9A<br>9B i<br>9C | 154<br>155 i<br>156 | RTN<br>BZS-i<br>DCA (Y) | EF a b i | 239 a b i | ADI (ab),i VEJ (F0) | | 38<br>40 | 56<br>64 | NOP | 9D i<br>9E i<br>9F i | 157 i<br>158 i<br>159 i | BVR-i<br>BCH-i<br>BVS-i | F1<br>F2<br>F4 | 241<br>242<br>244 | AEX<br>VEJ (F2)<br>VEJ (F4) | | 41<br>42<br>43 | 65<br>66<br>67 | SIN X<br>DEC XL<br>SDE X | A0<br>A1 a b<br>A2 | 160<br>161 a b<br>162 | SBC UH<br>SBC (ab)<br>ADC UH | F5<br>F6<br>F7<br>F9 | 245<br>246<br>247<br>249 | TIN<br>VEJ (F6)<br>CIN<br>REC | | 44<br>45<br>46<br>47 | 68<br>69<br>70<br>71 | INC X<br>LIN X<br>DEC X<br>LDE X | A3 a b<br>A4<br>A5 a b | 163 a b<br>164<br>165 a b | ADC (ab)<br>LDA UH<br>LDA (ab) | FB FD 01 | 251<br>253 01 | SEC<br>SBC #(X) | | 48 i<br>49 i<br>4A i | 72 i<br>73 i<br>74 i | LDE X<br>LDI XH,I<br>ANI (X),i<br>LDI XL,i<br>ORI (X),i | A6<br>A7 a b<br>A8<br>A9 a b | 166<br>167 a b<br>168<br>169 a b | CPA UH<br>CPA (ab)<br>SPV<br>AND (ab) | FD 03<br>FD 05<br>FD 07 | 253 03<br>253 05<br>253 07 | ADC #(X)<br>LDA #(X)<br>CPA #(X) | | 4B i<br>4C i<br>4D i<br>4E i | 75 i<br>76 i<br>77 i<br>78 i | OHI (X),i<br>CPI XH,i<br>BII (X),i<br>CPI XL,i | AAij<br>ABab<br>AC | 170 i j<br>171 a b<br>172 | LDI S,i,j<br>ORA (ab)<br>DCA (U) | FD 08<br>FD 09<br>FD 0A<br>FD 0B | 253 08<br>253 09<br>253 10<br>253 11 | LDX X<br>AND #(X)<br>POP X<br>ORA #(X) | | 4F i<br>50 | 79 i<br>80 | ADI (X),i | AD a b<br>AE a b<br>AF a b | 173 a b<br>174 a b<br>175 a b | EOR (ab)<br>STA (ab)<br>BIT (ab) | FD 0C<br>FD 0D<br>FD 0E | 253 12<br>253 13<br>253 14 | DCS #(X)<br>EOR #(X)<br>STA #(X) | | 51<br>52<br>53 | 81<br>82<br>83 | SIN Y<br>DEC YL<br>SDE Y | B1 i<br>B3 i<br>B5 i | 177 i<br>179 i<br>181 i | SBI i<br>ADI A,i<br>LDI A,i | FD 0F<br>FD 11 | 253 15<br>253 17<br>253 10 | BIT #(X)<br>SBC #(Y) | | 54<br>55<br>56<br>57 | 84<br>85<br>86<br>87 | INĆ Y<br>LIN Y<br>DEC Y<br>LDE Y | B3 i<br>B7 i<br>B8<br>B9 i | 183 i<br>184<br>185 i | CPI A,i<br>RPV<br>ANI A,i | FD 13<br>FD 15<br>FD 17<br>FD 18 | 253 19<br>253 21<br>253 23<br>253 24 | ADC #(Y)<br>LDA #(Y)<br>CPA #(Y)<br>LDX Y | | 58 i<br>59 i<br>5A i | 88 i<br>89 i<br>90 i | LDI YH,i<br>ANI (Y),i<br>LDI YL.i | BA i j<br>BB i<br>BD i | 186 i j<br>187 i<br>189 i | JMP i,j<br>ORI A,i<br>EAI i | FD 19<br>FD 1A<br>FD 1B | 253 25<br>253 26<br>253 27 | AND #(Y)<br>POP Y<br>ORA #(Y) | | 5B i<br>5C i | 91 i<br>92 i | ORI (Y),i<br>CPI YH,i | BEij<br>BFi | 190 i j<br>191 i | SJP<br>BII A,i | FD 1C<br>FD 1D | 253 28<br>253 29 | DCS #(Y)<br>EOR #(Y) | | Hex<br>Value | Decimal<br>Value | Opcode | |-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------| | FD 1E<br>FD 1F | 253 30<br>253 31 | STA #(Y)<br>BIT #(Y) | | FD 21<br>FD 23<br>FD 25<br>FD 27<br>FD 28<br>FD 29<br>FD 2A<br>FD 2B<br>FD 2C<br>FD 2C<br>FD 2C<br>FD 2C<br>FD 2C<br>FD 2C<br>FD 2C<br>FD 2C<br>FD 2F | 253 33<br>253 35<br>253 37<br>253 39<br>253 40<br>253 41<br>253 42<br>253 43<br>253 44<br>253 45<br>253 46<br>253 47 | SBC #(U) ADC #(U) LDA #(U) CPA #(U) LDX U AND #(U) POP U ORA #(U) DCS #(U) EOR #(U) STA #(U) BIT #(U) | | FD 40<br>FD 42<br>FD 48<br>FD 49 i<br>FD 4A<br>FD 4B i<br>FD 4C<br>FD 4D i<br>FD 4E<br>FD 4F i | 253 64<br>253 66<br>253 72<br>253 73 i<br>253 74<br>253 75 i<br>253 76<br>253 77 i<br>253 78<br>253 79 i | INC XH DEC XH LDX S ANI #(X),i STX X ORI #(X),i OFF BII #(X),i STX S ADI #(X),i | | FD 50<br>FD 52<br>FD 58 | 253 80<br>253 82<br>253 88 | INC YH<br>DEC YH<br>LDX P | | Hex<br>Value | Decimal<br>Value | Opcode | |---------------------------------------------------------------------|---------------------------------------------------------------------------------|-----------------------------------------------------------------| | FD 59 i | 253 89 i | ANI #(Y),i | | FD 5A | 253 90 | STX Y | | FD 5B i | 253 91 i | ORI #(Y),i | | FD 5D i | 253 93 i | BII #(Y),i | | FD 5E | 253 94 | STX P | | FD 5F i | 253 95 i | ADI #(Y),i | | FD 60<br>FD 62<br>FD 69 i<br>FD 6A<br>FD 6B i<br>FD 6D i<br>FD 6F i | 253 96<br>253 98<br>253 105 i<br>253 106<br>253 107 i<br>253 109 i<br>253 111 i | INC UH DEC UH ANI #(U),i STX U ORI #(U),i BII #(U),i ADI #(U),i | | FD 81 | 253 129 | SIE | | FD 88 | 253 136 | PSH X | | FD 8A | 253 138 | POP A | | FD 8C | 253 140 | DCA #(X) | | FD 8E | 253 142 | CDV | | FD 98 | 253 152 | PSH Y | | FD 9C | 253 156 | DCA #(Y) | | FD A1 a b<br>FD A3 a b<br>FD A5 a b<br>FD A7 a b | 253 163 a b | SBC #(ab)<br>ADC #(ab)<br>LDA #(ab)<br>CPA #(ab)<br>PSH U | | Hex<br>Value | Decimal<br>Value | Opcode | |--------------|------------------|-------------| | FD A9 a b | 253 169 a b | AND #(ab) | | FD AA | 253 170 | TTA | | FD AB a b | 253 171 a b | ORA #(ab) | | FD AC | 253 172 | DCA #(U) | | FD AD a b | 253 173 a b | EOR #(ab) | | FD AE a b | 253 174 a b | STA #(ab) | | FD AF a b | 253 175 a b | BIT #(ab) | | FD B1 | 253 177 | HLT | | FD BA | 253 186 | ITA | | FD BE | 253 190 | RIE | | FD C0 | 253 192 | RDP | | FD C1 | 253 193 | SDP | | FD C8 | 253 200 | PSH A | | FD CA | 253 202 | ADR X | | FD CC | 253 204 | ATP | | FD CE | 253 206 | AM0 | | FD D3 | 253 211 | DRR #(X) | | FD D7 | 253 215 | DRL #(X) | | FD DA | 253 218 | ADR Y | | FD DE | 253 222 | AM1 | | FD E9 a b i | 253 233 a b i | ANI #(ab),i | | FD EA | 253 234 | ADR U | | FD EB a b i | 253 235 a b i | ORI #(ab),i | | FD EC | 253 236 | ATT | | FD ED a b i | 253 237 a b i | BII #(ab),i | | FD EF a b i | 253 239 a b i | ADI #(ab),i | #### **HOW DO I USE ALL THIS?** The primary advantage of machine language over BASIC is speed. Your PC-2 has a very complete BASIC so there really isn't a lot of reason to program in machine language unless you are looking for a speed advantage. Let's look at a couple of programs which will demonstrate how fast machine language is compared to BASIC. What we will do is write a BASIC program which will reverse each graphic point on the PC-2's LCD display. Any point which is black (on) will be turned white (off) and any point which is off will be turned on. We will then show you a similar program in machine language. This should let you compare the speeds of the two languages. First the BASIC program: ``` 200 WAIT Ø 21Ø CLS 22Ø GCURSOR 3 : REM SHIFT PRINTING RIGHT SLIGHTLY 23Ø PRINT "Microcomputer News" 24Ø FOR I=Ø TO 155 : REM GRAPHIC COLUMNS 25Ø GCURSOR I : REM SET GRAPHIC CURSOR 260 A=POINT I : REM STORE COLUMN VALUE 27Ø B=Ø : REM NEW COLUMN - ALL POINTS OFF 28Ø FOR J=6 TO Ø STEP -1 : REM EXAMINE DOTS 29Ø C=INT(A/2^J) : POINT ON OR OFF (1 OR Ø) 300 IF C=0 LET B=B+2^J : REM TURN ON IF OFF 310 A=A-C*2^J : REM GET READY FOR NEXT POINT 320 NEXT J : REM DO NEXT DOT 330 CPRINT B. : REM PRINT REVERSED COLUMN ``` ``` 34Ø NEXT I : REM DO NEXT COLUMN 35Ø GOTO 35Ø ``` To use the program, enter it into your PC-2. Change line 230 to print what ever you wish on the LCD. When you run the program, the LCD will be reversed one column at a time from left to right. Lets look at a machine language program to do the same thing: ``` 1Ø WAIT Ø 2Ø CLS 3Ø GCURSOR 3 4Ø PRINT "TRS-8Ø PC-2" 5Ø POKE 184Ø9, 72, 118, 74, Ø, 5, 189, 255, 65, 78, 78, 153, 8 6Ø POKE 18421, 76, 119, 139, 6, 72, 119, 74, Ø, 158, 18, 154 8Ø CALL 184Ø9 9Ø NEXT I ``` Looks kind of like a BASIC program doesn't it? With the PC-2, you will normally use BASIC as a "vehicle" for getting the machine language routine into the computer and then executing it. Lines 10-40 of this second program look a lot like the first four lines of our first program, and they do the same things—housekeeping and getting something on the LCD so the program can reverse it. Lines 50 and 60 contain the actual machine code for our program. POKE is a PC-2 command which tells the computer to "poke" values into memory. The first value following POKE (18409 and 18421) tells the computer where in memory to start poking and the remaining values are the values to be POKEd into successive memory locations. The CALL statement in line 80 tells the PC-2 to "jump" to the memory location specified (18409) and begin executing the program it finds there. If you have the computer jump to a memory location and the location does not begin a valid program, your PC-2 may freeze or perform in an unpredictable manner. The GOTO 100 statement in line 100 "freezes" the LCD and lets you see the result of the reversal. If you have entered and RUN the second program, you should have noticed that your message was printed on the display and then, almost instantly, the LCD was reversed. Quite a bit faster than BASIC's many seconds to reverse the screen. This second program was copied from pages 62 and 63 of your PC-2 Owner's Manual. Add lines 70 and 90 from those pages to see multiple reversals. I numbered the first program in so that both programs can be in memory at the same time for comparisons of their speed. #### DISASSEMBLY You may be curious about how the machine code in lines 50 and 60 are able to reverse the display. To find out, we need to "disassemble" the machine code. The term "disassemble" means to take the hexadecimal (hex) or decimal values which represent a machine code program and to translate those values into more recognizable assembly language operation codes (op-codes.) Once you have the op-codes you will be better able to understand the logic that makes the program work. Here is how I went about disassembling the machine code from lines 50 and 60: - Find the first value which represents an instruction to the computer. This is the value 72 in line 50. We know that this is a decimal value because a hex value (on the PC-2) is preceded by an '&'. - Locate the value 72 in the numeric op-code list. Remember that the decimal values are in the second column. The listing looks like this: | Hex Value | <b>Decimal Value</b> | Op-Code | |-----------|----------------------|----------| | 48 i | 72 i | LDI XH,i | The Op-code is LDI XH, i. - 3. The 'i' in the op-code tells us that this instruction requires another value to be complete. - A quick check in the alphabetic listing gives this listing for LDI XH,i: | Mnemonic | Symbolic Operation | Hex<br>Op-Code | Byte | |----------|--------------------|----------------|------| | LDI XH,i | $i \rightarrow XH$ | 48 i | 2 | Mnemonic is just another word for op-code. The symbolic operation tells us that the value 'i' is stored into 'XH' (the high 8-bits of the 16-bit X register). We already knew the Hex Op-Code. The 'Byte' information tells us that this instruction requires two bytes (two values.) Since this command requires a second value, we go back to line 50 in the BASIC program and get the next value (118). I now have two values (72 118) which represent an instruction to the computer. The instruction translates as: Load the high portion of the X register with the decimal value 118. I would now go back to line 50, get the next available value (74) and continue with steps 2-5 until I had used all of the available values in lines 50 and 60. The result of the disassembly is: | Decimal<br>Values | Hex<br>Codes | Op-Code<br>Translation | |-------------------|--------------|------------------------| | 72 118 | 48 76 | LDI XH, 76H | | 74 0 | 4A 00 | LDI XL, 00H | | 5 | 05 | LDA (X) | | 189 255 | BD FF | EAI FFH | | 65 | 41 | SIN X | | 78 78 | 4E 4E | CPI XL, 4EH | | 153 8 | 99 08 | BZR - 08H | | 76 119 | 4C 77 | CPI XH, 77H | | 139 6 | 8B 06 | BZS+ 06H | | 72 119 | 48 77 | LDI XH, 77H | | 74 0 | 4A 00 | LDI XL, 00H | | 158 18 | 9E 12 | BCH-12H | | 154 | 9A | RTN | You should have noticed that I included the hex equivalents of the decimal values as I went along, and noticed that I used the hex values in my disassembled list (with an 'H' after those values for clarity.) The reason for doing this is that it will make comparisons with the PC-2 memory map a little easier. Also, most assembly language listings you read will use hex, so now is the time to start getting used to hex codes (if you aren't already.) The simplest way of getting the hex codes is to get them from the numerical listing of op-codes that was presented earlier in this article. Great, you say, but what do I do with all of this stuff? We will look at each line of the listing and see if we can make sense of it. To help the process, I am going to give each line a number (starting with 100 and incrementing by 10) to make referring to the lines a little easier. | Line | Decimal | Hex | Op-Code | |------|---------|-------|-------------| | 100 | 72 118 | 48 76 | LDI XH, 76H | | 110 | 74 0 | 4A 00 | LDI XL, 00H | | 120 | 5 | 05 | LDA (X) | | 130 | 189 255 | BD FF | EAI FFH | | 140 | 65 | 41 | SIN X | | 150 | 78 78 | 4E 4E | CPI XL, 4EH | | 160 | 153 8 | 99 08 | BZR - 08H | | 170 | 76 119 | 4C 77 | CPI XH, 77H | | 180 | 139 6 | 8B 06 | BZS + 06H | | 190 | 72 119 | 48 77 | LDI XH, 77H | | 200 | 74 0 | 4A 00 | LDI XL, 00H | | 210 | 158 18 | 9E 12 | BCH - 12H | | 220 | 154 | 9A | RTN | Lines 100 and 110 load the X register with the hex value 7600 Line 120 then tells the computer to load the A register with the value stored in the memory location that the X register is pointing to (7600). A quick glance at the PC-2 memory map (March MCN, pg. 26) shows us that the memory locations beginning at 7600H and continuing to 764DH are part of the PC-2's LCD display. What the computer has done is to look at the first byte of LCD memory (which corresponds to the first column of dots in the main LCD display area) and then place a copy of the value in that location into the MPU's A register. Line 130 tells the computer to take the value in the A register and exclusive OR (XOR) it with the immediate value FFH. The bit pattern for FFH is: 1111 1111. The exclusive OR operation compares each bit of the display value (stored in A) with a one bit from the FFH (a solid black, all on, column). If both bits are ones the computer stores a zero (0). If one bit is a one and the other is a zero, the computer stores a one. The net result is that after the EAI (XOR) operation, the A register contains a reversed copy of the original display byte. Line 140 contains the one byte instruction SIN X. This single instruction tells the computer to take the value which is currently in the A register (our reversed column image) and store that value in the memory location pointed to by the X register. If you remember (the computer does), this is currently the first byte of LCD RAM. Once the value from A has been stored, the computer will add one to the value currently in the X register. Let's pause a moment and see what has happened. With only eight bytes of memory we have told the computer where the first column of LCD memory is (7600H), we have made a copy of that column, reversed the copy, stored the result back into the first column of LCD memory (7600H) and we have incremented our counter (the X register) so that it now points to the second column of the LCD. No wonder machine language is so fast! Line 150 tells the computer to compare the lower 8-bits of the X register with the value 4EH. The computer will set its 'flags' based on whether the value in XL is 4EH or not. Recall that the X register is pointing to LCD memory. A glance back to the PC-2 memory map shows us that if X contains 764EH, it is pointing just past the end (764DH) of LCD display sections 1 and 3. Line 160 instructs the computer to examine the flags which were set by the CPI instruction in line 150. If the Z flag is zero (Z = 0), meaning that XL did NOT contain the value 4EH, then the computer is instructed to count backwards eight bytes and continue executing the program from that point. If Z = 1 the computer will continue to the instruction in line 170. To count back eight bytes the way the computer will do it, we have to understand that the program counter (which is what will be reduced by eight) is already pointing to the first byte of the instruction in line 170. Count back eight from that point. You should have stopped on the 05H in line 120. The computer would continue executing instructions beginning with line 120. What the programmer did was to create a loop. The purpose of the loop is to have the computer move one byte at a time through the memory of LCD chips 1 and 3 (7600H - 764DH) reversing each byte in memory as the computer comes to them. Line 170 tells the computer that if the value in XL was 4EH (from the test and compare in lines 150 and 160), then test the value in XH (the upper 8-bits of X) to see if a 77H is present. The first time the computer executes line 170 the value in XH will be a 76H (put there in line 100.) Line 180 tells the computer to move its program counter forward six bytes if the value in XH WAS a 77H. Remembering that the program counter is currently pointing to the first byte in line 190, adding six would move the pointer forward to the single byte in line 220. Line 190 is executed only if the value XH was not a 77H. Line 200 will put a 00H into XL. A quick glance at the memory map shows us that 7700H if the first byte of LCD display memory for chips 2 and 4. Line 210 tells the computer to subtract 12H (18 decimal) from its current program counter value. Since the program counter would be pointing at the 9AH in line 220, moving back 18 decimal would make the program counter point to line 120 again. We already know that this will cause the computer to move through this new section of LCD memory (starting at 7700H this time) until the value in XL reaches 4EH. When XL reaches 4EH (this would be the second time), the computer would find 77H in XH (line 170) and the program counter would be moved forward to point at line 220 (line 180). Line 220 is very important in any program which began by BASIC executing a CALL command. If you will look back to the BASIC program which loaded the machine code into memory, you will find the CALL command in line 80. The purpose of the RTN instruction in line 220 of our machine language program is to return control of the computer to BASIC and the program which contained the CALL command. If you forget to do this, you may have to push the ALL RESET button on the back of the PC-2 to regain control of the computer. By Bruce Elliott This is the fifth in a series of articles which describe the MPU (microprocessor unit) used in the Radio Shack PC-2 pocket computer. It is our intention to include specific information about the 8-bit CMOS microprocessor, the machine code used by the microprocessor, as well as information about the PC-2 memory map, and certain ROM calls which are available. Please realize that much of what we are talking about refers to the overall capabilities of the MPU, and does not imply that all of these things can be done with a PC-2. The information provided in these articles is the only information which is available. We will try to clarify any ambiguities which occur in the articles, but cannot reply to questions outside the scope of these articles. Further, published copies of TRS-80 Microcomputer News are the only source of this information, and we will not be maintaining back issues. Parts One, Two, Three and Four of this series were published in the March, April, May, and September 1983 issues, respectively. The first three articles described the MPU used in the PC-2, including information on the MPU's structure and its machine language. We also gave you details on the PC-2 memory map and the locations of ROM routines which are available. In the fourth article we presented two lists to make finding a particular machine language instruction easier. We also provided some information on how you might begin to use the information we have published. In this fifth article we want to present information on how to create your own machine language routines, and begin describing how to use the PC-2 ROM calls which are available. #### CREATING YOUR OWN PROGRAMS Last month we looked at an existing machine language program and described a procedure (disassembly) for determining how the program did what it was supposed to do. This month I want to define a program and then describe the procedure for creating a workable program that fits the definition. To make things simple, the program we are going to design will do only one thing—display on the LCD the key you press on the keyboard. I know that this program may sound silly. After all, doesn't the PC-2 automatically display the key you press? The answer is no, it doesn't. Try using the INKEY\$ command. With INKEY\$, if you want the character displayed you must display it yourself. What we are really doing is designing a program which will accept characters from the PC-2 keyboard and display them on the LCD. This program should show you how to do three important things in assembly language: first, how to get information from the keyboard into the computer; second, how to take information that is in the computer and display it on the LCD; and third, how to use the PC-2's ROM subroutines. In Part 1 of this series (March, 1983, pg. 26) we published a PC-2 memory map. It is in this section of PC-2 memory that we find ROM subroutines. #### WHY DO ROM SUBROUTINES EXIST? In general, any computer consists of similar basic parts. To function, a computer must have a processing unit, input and output functions, working memory to store temporary results, and some sort of control mechanism or program. In the PC-2, the processing unit is the MPU which we have been describing in this series. The input function is handled primarily by the keyboard, and the output function is handled primarily by the LCD. The working memory is RAM (Random Access Memory), and the control mechanism is in the form of programs stored in ROM (Read Only Memory). In order to make the PC-2 behave so that you can use it, the manufacturer wrote an operating system to control the various functions of the computer. Part of this operating system is instructions which control the keyboard, the LCD, and BASIC. This is where ROM subroutines come from. To function properly, the PC-2 has to have a routine which looks at the keyboard and stores any key which may be pressed. Likewise, there has to be a routine somewhere which takes a character and displays it on the LCD. The PC-2 memory map tells us where some of these routines are located, and we will use this information to create our machine language program. ### IS THIS INFORMATION AVAILABLE ON OTHER COMPUTERS? Radio Shack has received permission from the original manufacturer of the PC-2 to disclose the information which we are presenting in this series of articles. The information is fixed, and we do not expect it to change. If you happen to own a different TRS-80 you may have tried to get similar information for that computer and you were told "I am sorry, but we cannot provide you with that information." Why? Well, there are two major reasons. The first and largest reason is that most computers are evolving products. As a computer evolves, the contents of its operating systems also change. If we give you information about where a particular routine is located in the first version of a program or operating system, you are going to expect that information to be true in the second version of that program or operating system also. With few exceptions, every change of a machine language program such as an operating system means a relocation of ALL of the contents of that program. Because the contents of programs are subject to change with each revision, what Radio Shack typically does is to publish certain "published entry points." These published entry points won't normally change, even if the rest of the program does change. Other than the published entry points, Radio Shack, in general, will not provide you with other information about the contents of the program. Using only published entry points protects your software from becoming obsolete as soon as Radio Shack issues a new version of the program. The second major reason for not providing the information is that Radio Shack often does not have permission from the copyright holder to release the information. As an example, Microsoft BASIC on any of our machines is owned by Microsoft. Since Microsoft owns the code, they have the right to tell us what we can and cannot publish. #### **BACK TO THE PC-2** The stated function of our machine language program is to accept keyboard entries and display the pressed key on the LCD. A quick glance at the memory map for System Program ROM shows two keyboard scan routines and two routines which output single characters to the LCD. E243H Keyboard Scan-Wait for Character E42CH Keyboard Scan-No Wait ED4DH Output one character to LCD and increment cursor position by one ED57H Output one character to LCD (Remember that the H after the address, as in E243H, indicates that the number is in Hexadecimal notation and not decimal.) E243H My information on the E243H Keyboard scan routine tells me that the PC-2 will wait for a key to be pressed. Once a key has been pressed, the key's code will be placed in the MPU Accumulator. If a key is not pressed within about seven minutes, the PC-2 will be turned off automatically. Once power-down has occurred, pressing the ON key will return the computer to the keyboard scan routine. E42CH The information on the E42CH routine states that if a key has been pressed, the key code will be in the accumulator. If a key has not been pressed the accumulator will contain 00H. ED4DH To output a character using ED4DH, the ASCII code of the character to be displayed is placed in the accumulator and the routine is executed. The character will be placed at the current cursor position, and then the cursor position will be updated. The current cursor position is stored in memory location 7875H. According to our information, if the old cursor position (before the call to ED4DH) was less than 96H the new cursor position (stored in 7875H) will be the old position plus 6H. If the old cursor position was 96H or greater, the new position will be 00H. ED57H To display a character using the ROM routine at ED57H, place the ASCII value of the character to be displayed into the accumulator and execute the ED57H routine. The character will be displayed at the current cursor location and the cursor position will not be updated. #### LET'S WRITE THE PROGRAM I try to program conservatively when I use machine language. What I mean by this is that I try to disturb as few things as I can. So, the first part of my program will "save the MPU registers." What I mean by this is that I will save a copy of the various registers so I can restore the MPU when I am finished with my program. This is done by using the appropriate push (PSH) instructions to "push" the register values onto the stack. FD C8 PSH A FD 88 PSH X FD 98 PSH Y FD A8 PSH U Now that I have saved a copy of the registers, I want to set the PC-2's cursor position to the left side of the LCD. This would make the cursor position (stored in 7578H) zero (0). B5 ØØ LDI A, ØØH 4A 75 LDI XL, 75H 48 78 LDI XH, 78H ØE STA (X) Notice that I used three LoaD Immediate (LDI) instructions. The first LDI puts the cursor position (00H) into the MPU's Accumulator (A register.) The next two LDIs load the X register with the address which stores cursor position (7578H). The fourth instruction (STA) tells the MPU to put the value currently in the A register into the memory location which is currently in the X register. Now that the cursor is where I want it, it is time to get a keystroke from the keyboard. Since the only thing I want to do is to get a keystroke, I choose to use the routine which waits for a key to be pressed before returning. A ROM routine is executed by using the Subroutine Jump (SJP) command. BE E2 43 SJP E243H We learned earlier that once a key is pressed, the PC-2 stores the ASCII value of the key in the A register. Both display routines I am considering require the ASCII value of the character I want displayed to be in the A register. Since the keyboard scan routine already put the ASCII value in the A register, all I need to do is use a subroutine jump to the proper display routine. BE ED 4D SJP ED4DH I chose to display each character in cursor position 0, so I used the display routine at ED4DH. The purpose of this program was to get a character from the keyboard and to display it on the LCD. My program has done that, so I restore the registers by POPping their values (in reverse order) off the stack. FD 2A POP U FD 1A POP Y FD ØA POP X FD 8A POP A There is one final task which any machine language program which is called from BASIC (as this one will be) must perform and that is to return control of the PC-2 to BASIC. This is accomplished by executing a return command. 9A RTN Here is the completed machine language program along with various comments so I can remember what is happening. FD C8 PSH A 'Save Registers FD 88 PSH X FD 98 PSH Y | FD | A8 | PSH U | | |------------|-------|-------------|--------------------| | <b>B</b> 5 | ØØ | LDI A, ØØH | 'Cursor Position | | 4A | 75 | LDI XL, 75H | 'Cursor Storage | | 48 | 78 | LDI XH, 78H | ' Location | | ØE | | STA (X) | 'Store Cursor | | BE | E2 43 | SJP E243H | 'Read Keyboard | | BE | ED 4D | SJP ED4DH | 'Display Character | | FD | 2A | POP U | 'Restore Registers | | FD | 1 A | POP Y | | | FD | ØA | POP X | | | FD | 8A | POP A | | | 9A | | RTN | 'Return to BASIC | #### TURN IT INTO A BASIC PROGRAM Now that I have the machine code for my program, I need a way to get the program into the PC-2 and executed. A very straight forward way to do this in the PC-2 is to put the machine language program into a BASIC program shell like the following: ``` 10 WAIT Ø 20 DATA &FD, &C8, &FD, &88 3Ø DATA &FD, &98, &FD, &A8 4Ø DATA &B5, &ØØ, &4A, &75 5Ø DATA &48, &78, &ØE 6Ø DATA &BE, &E2, &43 70 DATA &BE, &ED, &4D 8Ø DATA &FD, &2A, &FD, &1A 9Ø DATA &FD, &ØA, &FD, &8A 100 DATA &9A 11Ø M=16999 12Ø FOR I=1 TO 3Ø 13Ø READ A 140 POKE M+I, A 150 NEXT I 160 M=M+1 17Ø PRINT " READY" 18Ø CALL M 19Ø GOTO 18Ø ``` Line 10 simply sets the PC-2 PRINT command delay time to 0. Lines 20-100 contain DATA statements into which I have placed the hexadecimal values for my machine language Op-Code program. Notice the use of a leading '&' to indicate that the values are in Hex. Line 110 contains the address (minus one) where I will begin storing the machine language program in memory. Lines 120-150 POKE the machine language routine into PC-2 RAM memory. Line 160 updates the memory pointer from line 110 so that it contains the actual starting address of my routine (17000 decimal). Line 170 tells me that the machine language program has been put into memory and will begin executing with the next instruction. Line 180 tells BASIC to turn control of the PC-2 over to the machine language program which begins at location M (my memory pointer). The PC-2 will set the cursor position to zero, wait for a key to be pressed on the keyboard, display the proper character and return to BASIC. Line 190 tells BASIC to go back to line 180 and execute the machine language program again. #### THAT IS ALL THERE IS TO IT! If you have followed this series of articles all the way through, you now have enough information about the PC-2 and how it operates to begin writing your own programs in machine language. Next month we plan on giving you some additional information about the various ROM subroutines which are available to you in the PC-2. #### A CLOSING GIFT Operation codes (op-codes, mnemonics) are short names which programmers give to machine language commands to make them more readable, and more rememberable. We have given you several lists with op-codes and have provided some detail on what the commands do. At least one person has asked "How am I supposed to pronounce those funny looking things?" Below is a listing of the various PC-2 op-codes and a recommended "name" or pronunciation for each. Op-Code | Op-Code | Suggested Name | |-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADC ADI DCA ADR SBC SBI DCS AND ANI ORA ORI | Add with Carry Add Immediate Decimal Add Add Register Subtract with Carry Subtract Immediate Decimal Subtract AND Accumulator AND Immediate OR Accumulator OR Immediate Exclusive OR Accumulator | | INC<br>DEC<br>CPA<br>CPI<br>BIT<br>BII | Exclusive OR Accumulator Immediate Increment Decrement Compare Accumulator Compare Immediate Bit Bit Immediate | | LDA<br>LDE<br>LIN<br>LDI<br>LDX<br>STA<br>SDE<br>SIN<br>STX | Load Accumulator Load and Decrement Load Increment Load Immediate Load X Store Accumulator Store and Decrement Store and Increment Store X | | PSH | Push | |------|---------------------------------| | POP | Pop | | ATT | Accumulator to T Register | | TTA | T Register to Accumulator | | TIN | Transfer and Increment | | CIN | Compare and Increment | | ROL | Rotate Left | | ROR | Rotate Right | | SHL | Shift Left | | SHR | Shift Right | | DRL | Decimal Rotate Left | | DRR | | | | Decimal Rotate Right | | AEX | Accumulator Nibble Exchange | | SEC | Set Carry | | REC | Reset Carry | | CDV | Clear Divider | | ATP | Accumulator to Port | | ITA | Port Input to Accumulator | | SPU | Set PU | | RPU | Reset PU | | RDP | Resets display flip-flop | | SDP | Sets display flip-flop | | SPV | Set PV | | RPV | Reset PV | | SIE | Set Interrupt Enable | | RIE | Reset Interrupt Enable | | AMO | Accumulator to Timer, Bit 9=0 | | AM1 | Accumulator to Timer, Bit 9 = 1 | | NOP | No Operation | | INOI | No operation | Suggested Name | | 33 | | |-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------| | HLT | Halt | Name of the last | | OFF | OFF | To the | | JMP | Jump | Į. | | BCH | Branch . | | | BCS | Branch Carry Set | | | BCR | Branch Carry Reset | | | BHS | Branch Half Carry Set | | | BHR | Branch Half Carry Reset | | | BZS | Branch Zero Set | | | BZR | Branch Zero Reset | | | BVS | Branch Overflow Set | ă | | BVR | Branch Overflow Reset | Shire | | LOP | Loop on Positive | | | SJP | Subroutine Jump | ğ | | VEJ | Vector Jump | 100 | | VMJ | Vector Unconditional | | | VCS | Vector Carry Set | | | VCR | Vector Carry Reset | | | VHS | Vector Half Carry Set | | | VHR | Vector Half Carry Reset | | | VZS | Vector Zero Set | N/A | | VZR | Vector Zero Reset | September 1 | | VVS | Vector Overflow Set | ğ | | VVR | Vector Overflow Reset | Stare | | RTN | Return from Subroutine | ä | | RTI | Return from Interrupt | | | ME0 | Memory Enable 0 | | | ME1 | Memory Enable 1 | | | | Market and the second s | ı | Suggested Name By Bruce Elliott This is the sixth in a series of articles which describe the MPU (microprocessor unit) used in the Radio Shack PC-2 pocket computer. It is our intention to include specific information about the 8-bit CMOS microprocessor, the machine code used by the microprocessor, as well as information about the PC-2 memory map, and certain ROM calls which are available. Please realize that much of what we are talking about refers to the overall capabilities of the MPU, and does not imply that all of these things can be done with a PC-2. The information provided in these articles is the only information which is available. We will try to clarify any ambiguities which occur in the articles, but can not reply to questions outside the scope of these articles. Further, published copies of TRS-80 Microcomputer News are the only source of this information, and we will not be maintaining back issues. In this article we want to present information on some of the PC-2 ROM calls which are available. When you are going to use a ROM call, there are four items which you want to be concerned with: - Entry Address - 2. Entry Conditions - 3. Exit Conditions The Entry Address is the address you use in the CALL statement from BASIC or a SJP call from machine language. The Entry Conditions are conditions you must fulfill if the routine is to function properly. Normally, entry conditions specify where information must be and what information you must put in the MPU registers for the routine to function properly. The Exit Conditions tell you where you will find the result of the operation (if there is a result) or provide you with other information about how things will change as a result of using a particular ROM call. If a ROM call makes particular changes to any of the machine's flags, this information will be noted so you can properly interpret the results you get. #### **A CAUTION** I have not had time to test the information which is provided below on ROM calls. The information provided is as accurate as I could make it from the materials I am working with. Test any ROM call for proper operation BEFORE you use it in a program. Remember that the 'H' following a numeral indicates hexadecimal notation. #### **CURSOR INFORMATION** The PC-2 cursor pointer is located at 7875H. This location is used by the PC-2 to keep track of where the cursor should be. If you are working exclusively in machine language, updating 7875H is all that is needed for cursor location. If you are working from BASIC, and wish to update the cursor location directly using POKEs or CALLs, you must also set bit 0 of location 7874H. Setting this bit from machine language can be accomplished by: ORI 7874H, 01H This operation is done automatically when you use the CURSOR or GCURSOR BASIC commands. If you execute a ROM call which resets the cursor pointer and are going to return to BASIC, you must set bit 0 of location 7874H as described above. If you wish to reset the cursor from machine language, you can use the following code: ANI 7874H, OFEH ANI 7875H, 00H To increment the cursor pointer, use the following: If you are displaying characters: (7875H) = (7875H) + 06H If you are displaying graphics: (7875H) = (7875H) + 01H Note: (7875H) must be between 00H and 9BH. #### SYSTEM CALLS FOR THE LCD DISPLAY Output one character to the LCD - System call address: ED57H - 2. Entry Conditions: - a. The ASCII character code for the character to be displayed must be in the ACC (Accumulator) before making the call. - b. The location where the character will be placed is determined by the content of the cursor pointer. - 3. Exit Conditions: The cursor pointer does not change. - 4. Flags: Carry = 0 The cursor stays between 00H and 95H - = 1 The cursor stays in 96H on the call. Output one character to the LCD and increment the cursor position by one character (6H). - 1. System call address: ED4DH - 2. Entry Conditions: The ASCII character code for the character to be displayed must be in the ACC (Accumulator) before making the call. - 3. Exit Conditions: If the cursor position before the call was in the range 00H to 95H, then the new cursor position equals the old position plus 6H. If the cursor position before the call was 96H or larger, then the new cursor position is set equal to zero. - 4. Flags: Outputting n characters to the LCD. - System call address: ED00H - 2. Entry Conditions: - a. The 16 bit starting address for the string to be displayed is placed in the U register (0000H <= U <= FFFFH). - b. The length of the character string is placed in the Accumulator (01H $\langle$ = ACC $\langle$ = 1AH). - c. The cursor pointer indicates where on the LCD the computer is to begin displaying the string. - 3. Exit Conditions: The cursor pointer is updated. - Flags: Carry = 0 The cursor position is set to the rightmost end of the displayed character string on the LCD. - The specified character string ended in the 26th LCD column, or the string was too long to be displayed within 26 columns. The cursor will be steady, indicating the last character displayed. The number of characters specified in the accumulator is output from consecutive addresses beginning with the address specified in the U register. The characters will be placed on the LCD beginning with the position indicated by the cursor pointer. The cursor pointer can be set from machine language, or by using the BASIC CURSOR or GCURSOR commands. If the information to be displayed exceeds the 156th dot on the LCD, the excess information will not be displayed. Outputting n characters to the LCD beginning from character position 1. - 1. System call address: ED3BH - 2. Entry Conditions: - a. The 16 bit beginning address location of the string to be displayed is stored in the U register (0000H \( \) = U \( \) = FFFFH). - b. An 8 bit number indicating the length of the character string is stored in XL (The lower half of the X register. 01H \( = XL \( = 1AH \). - 3. Exit Conditions: - Flags: Carry = 0 The character string has been displayed in 25 or fewer columns. - = 1 The character string reached or exceeded the 26th column. Transferring 1 byte of data (1 dot column of graphic information) to the current cursor position. - 1. System call address: EDEFH - Entry Conditions: The byte representing the graphic pattern to be displayed is placed in the accumulator. - 3. Exit Conditions: - a. The data is transferred to the current cursor position, which does not change. - b. The contents of ACC and the X and U registers may change. - c. The content of the Y register will not change. - 4. Flags: #### DATA CONVERSIONS Converting two bytes of ASCII code (0 - 9, A - F only) into a one byte hexadecimal value. - 1. System call address: ED95H - Entry Conditions: The X register should contain the address of the first of two consecutive bytes in memory which contain the ASCII characters. - 3. Exit Conditions: - a. The X register will be incremented by 2 - b. The U and Y registers will be unchanged - c. The ACC will contain the converted hex value. - 4. Flags: #### **DISPLAY THROUGH A BUFFER** Data can be placed into an 80-byte buffer (7BB0H - 7BFFH) and then displayed as needed by specifying the proper cursor address in the buffer. - 1. System call address: E8CAH - 2. Entry Conditions: - a. Any character string which is placed in the buffer must have a 0DH code as the last character. This means that the longest allowable character string is 79 characters plus the 0DH end code. - b. The Y register holds the cursor pointer for the buffer. The documentation does not specify what value goes into Y. Since Y is 16 bits long, I presume that you would use the actual memory address within the buffer. - c. Address 7880H contains a parameter which determines how the contents of the buffer are to be displayed: If the binary content of 7880H is 0100 0000, then the character string stored in the buffer is output to the LCD using the content of the Y register as the cursor pointer. Note: If the number of characters in the buffer is 26 or less, then all of the characters are displayed on the LCD starting from the left side of the LCD. The cursor pointer (7875H) has no effect on this operation. If the number of characters in the buffer is greater than 26, the character in the address specified by the Y register and the PRECEDING 25 characters are displayed on the LCD starting at the left side of the LCD. If the binary content of 7880H is 0000 0000, then the cursor pointer in the Y register is ignored and he first 26 characters stored in the buffer are output to the LCD. If the binary content of 7880H is 0010 0000, then numeric data stored in memory addresses 7A00H - 7A07H are output to the LCD. Note: See below for a discussion of the 7A00H - 7A07H buffer. - 3. Exit Conditions: - 4. Flags: The 7A00H - 7A07H Buffer The PC-2 documentation describes three possible sets of data for the 7A00H buffer: Decimal Values: A decimal value may fall into the range $9.99999999 \times 10E99 = x = 9.999999999 \times 10E99$ . 7A00H contains the exponent (negative exponents are expressed as complements: $03H = \times 10E3$ , $1FH = \times 10E31$ , and $FFH = \times 10E-1$ ) 7A01H contains the sign of the mantissa (00H = +, 80H = -) 7A02H - 7A06H contains the mantissa. 7A07H contains 00H. Examples 7A00H 7A07H 0.0 = H00 H00 H00 H00 H00 H00 H00 00H 00H 12H 34H 50H 00H 00H 00H = 1.2345 FEH 00H 98H 76H 54H 32H 12H 00H = 0.9876543212 08H 80H 54H 32H 00H 00H 00H 00H = -5.432 × 10 Integer Values: An integer value may fall into the range -32768 $\langle = \times \langle = 32767 \rangle$ . 7A00H-7A03H - Don't Care 7A04H-B2H 7A05H—7A06H Binary number in complements (e.g. 00H 00H = 0, FFH FBH = -5, 7FH FFH = 32767) 7A07H—Don't Care Character Strings: 7A00H-7A03H-Don't Care 7A04H-D0H 7A05H—Upper two bytes of string address in memory 7A06H—Lower two bytes of string address in memory (string address can be in the range 0000H - FFFFH) 7A07H—Length of the string (range 01H - 50H) Note: This last set of conditions (for strings) seems to imply that a string buffer can be anyplace in memory, rather than being restricted to 7BB0H - 7BFFH. Test this before relying on it. #### **CASSETTE I/O AND CONTROL** During tape I/O activities, the paper feed action of the printer is inhibited. Turn Tape Drive On 1. System call address: BF11H Entry Conditions: Memory address 7879H is used to specify certain conditions: Bit 7: 0 = CMT input port closes; select 0 for CMT input. 1 = CMT input port opens; select 1 for CMT input. Bit 4: 0 = Remote 0 1 = Remote 1 3. Exit Conditions: 4 Flags: #### Turn Tape Drive Off 1. System call address: BF43H 2. Entry Conditions: - Exit Conditions: Remote drive 0 is turned off unconditionally. Remote drive 1 is turned off or on depending on bit 7 of an unspecified address (probably 7879H). If bit 7 is 0 the drive is OFF, and if bit 7 is a 1 then, the drive is ON. This bit can be set using the BASIC commands RMT ON and RMT OFF. - 4. Flags: #### Construct Tape Synchronization Header The header, a 40-byte data set, consists of the synchronization header, a file name, file mode, and other data. This header is created inside the computer (addresses 7B60H - 7B87H) and output to tape. 1. System call address: BBD6H - Entry Conditions: The file mode (00 = Machine Object, 01 = Program, 02 = Reserve, 04 = Data) must be placed in the accumulator. - 3. Exit Conditions: - a. An 8 byte synchronization header will be in 7B60H 7B67H - b. File mode will be in 7B68H - c. 00H characters will be placed in locations 7B69H 7B87H. #### 4. Flags: A program file name (16 or fewer characters) can be placed in memory locations 7B69H - 7B78H, if you wish. Address locations 7B79H - 7B87H may be used for your own purposes. #### Output Tape Synchronization Header - 1. System call address: BCE8H - 2. Entry Conditions: - a. Bit seven of address 7879H must be zero and bit four will be a zero for remote 0 and a one for remote 1. - b. Whether the PC-2 will beep or not during cassette I/O is controlled by the BASIC commands BEEP ON and BEEP OFF, or by setting bit zero of 786BH. - 3. Exit Conditions: - 4. Flags: #### Send a Character to Tape - System call address: BDCCH - Entry Conditions: Character to be output is placed in the Accumulator. The call to write the synchronization header must be used before outputting data using this system call. - 3. Exit Conditions: - 4. Flags: #### Write a tape file Files can be written by specifying the start address of the data and the number of bytes to be output. - 1. System call address: BD3CH - 2. Entry Conditions: - a. The X register should contain the start address (0000H \( = X \( < = FFFFH \)) for the file to be written.</p> - b. The U register should contain the number of bytes to be written minus one (0000H \( = U \) = FFFFH). - Exit Conditions: Check sum data is output at the rate of 2 bytes for each 80 bytes written. The number of check sum bytes is not included in the U register number of bytes to be output. - 4. Flags: CARRY = 0 if Output ended normally= 1 if BREAK key was pressed #### Read Tape Synchronization Header Before the header can be read from tape, you must construct a header using the BBD6H call. This will specify the file type. If you are searching for a particular file, you may place the file name in address locations 7B69H - 7B78H. If you specify a file name, the tape will be searched for a matching name. If you do not specify a file name (file name = all 00H characters) then file names will be ignored during input. - System call address: BCE8H - 2. Entry Conditions: - a. build a header with file type - b. specify a file name if you wish. - c. Set 7879H: Bit Seven = 1 Bit Four = 0 for Remote 0 = 1 for Remote 1 - 3. Exit Conditions: - a. 7B91H 7BA0H will contain the 16 character file name (padded with 00H characters if file name was less than 16 characters) - b. 7BA1H 7BAFH will contain whatever was in 7B79H -7B87H when the file was written to tape. - 4. Flags: Carry = 0 Reading finished - = 1 BREAK key pressed #### Read a Character from Tape - 1. System call address: BDF0H - 2. Entry Conditions: - Exit Conditions: The data value read from the tape is placed in the accumulator. - 4. Flags: Carry = 0 Byte read properly - = 1 BREAK key was pressed #### Read a file from tape - 1. System call address: BD3CH - 2. Entry Conditions: - a. The X register contains the first memory address (0000H \( = X \( \) = FFFFH) that the file is to be loaded into. - b. The U register contains the number of bytes minus one (0000H \( \) = U \( \) = FFFFH) to be read from tape. - c. Address 7879H bit seven contains zero bit six = 0 for data read = 1 for data verify - 3. Exit Conditions: - a. Check sum information is automatically checked during tape input. - b. The X register contains the address of the last data byte plus one. - 4. Flags: Carry = 0 if loading ended normally - = 1 abnormal end, check H and V flags H = 1 if C = 1 then BREAK key pressed = 0 check V flag - V = 1 if C = 1 and H = 0 then data in memory and the data from the tape did not verify properly. - = 0 if C = 1 and H = 0 then a check sum error occurred. #### Finishing Tape I/O Activities When you are finished using tape I/O you should inform the system. - 1. System call address: BBF5H - Entry Conditions: Bit seven of 7879H should be a zero to terminate data output or a one to terminate data input. - 3. Exit Conditions: - a. The serial port is reset - b. Printer Paper Feed is enabled - c. Cassette motor drives are turned off. - 4. Flags: #### **BASIC Program Tapes** The PC-2 creates and reads tapes for BASIC program files using the file read and write routines described here. Before the synchronization header is written to tape, the PC-2 stores the length of the program (in bytes) minus one in locations 7B85H and 7B86H. This information is then recorded as part of the synchronization information for later use in reading the file. When the header information is read back during a synchronization header read, the length information is in 7BACH and 7BADH. #### **KEYBOARD INPUT CALLS** Scan Keyboard, wait for a key to be pressed - 1. System call address: E243H - 2. Entry Conditions: - 3. Exit Conditions: - a. Key code is in the accumulator - b. **SHIFT**, **DEF**, and **SML** do not cause this routine to return. - Auto power off will occur after about seven minutes if no key is pressed. - d. If the BREAK key is entered, execute the following: ANI #F00BH, 0FDH (FDH E9H F0H 0BH FDH) - 4. Flags: Carry 0 = Accumulator has key code - 1 = BREAK key, Accumulator = 0EH | Code lab | ole | | | | | | | |----------|---------------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | | SPACE | 0 | @ | | | p | | (SHIFT) | F1 | 1 | 1 | A | Q | a | q | | (SML) | F2 | 14 | 2 | В | R | b | r | | | F3 | # | 3 | C | S | C | S | | | F4 | \$ | 4 | D | T | d | t | | | F5 | % | 5 | | U | е | u | | | F6 | & | 6 | | V | f | V | | | | | 7 | G | W | g | W | | ← | CL | ( | 8 | H | X | h | × | | 4 | RCL | ) | 9 | 1 | Y | i | У | | 1 | CA | • | * | J | Z | j | Z | | 1 | (DEF) | + | ; | K | rad | k | | | - | | y . | < | L | | 1 | | | ENTER | DEL | | = | M | π | m | | | BREAK | | • | > | N | ^ | n | | | OFF | MODE | 1 | ? | 0 | | 0 | | | | 0<br>(SHIFT)<br>(SML)<br>↓<br>↑<br>ENTER<br>BREAK | (SML) F2<br>F3<br>F4<br>F5<br>F6<br>← CL<br>↑ RCL<br>↓ CA<br>↑ (DEF)<br>NS<br>ENTER DEL<br>BREAK | 0 1 2 SPACE (SHIFT) F1 ! (SML) F2 " F3 # F4 \$ F5 % F6 & ← CL ( RCL ) | 0 1 2 3 SPACE 0 (SHIFT) F1 ! 1 (SML) F2 2 F3 # 3 F4 \$ 4 F5 % 5 F6 & 6 ← CL ( 8 ← RCL ) 9 ← CA ↑ : ↑ (DEF) + ; ↑ INS . < ENTER DEL - = BREAK > | 0 1 2 3 4 SPACE 0 @ (SHIFT) F1 ! 1 A (SML) F2 2 B F3 # 3 C F4 \$ 4 D F5 % 5 E F6 & 6 F 7 G ← CL ( 8 H ♣ RCL ) 9 I ↓ CA • : J ↑ (DEF) + ; K ENTER DEL - = M BREAK > N | 0 1 2 3 4 5 SPACE 0 @ P (SHIFT) F1 ! 1 A Q (SML) F2 2 B R F3 # 3 C S F4 \$ 4 D T F5 % 5 E U F6 & 6 F V 7 G W ← CL (8 H X ↑ RCL ) 9 I Y ↓ CA ↑ J Z ↑ (DEF) + ; K rad ENTER DEL - = M π BREAK - > N Λ | 0 1 2 3 4 5 6 SPACE 0 @ P (SHIFT) F1 ! 1 A Q a (SML) F2 " 2 B R b F3 # 3 C S c F4 \$ 4 D T d F5 % 5 E U e F6 & 6 F V f 7 G W g ← CL (8 H X h ↑ RCL ) 9 I Y i ↑ CA * : J Z j ↑ (DEF) + ; K rad k ENTER DEL - = M π m BREAK . > N Λ n | Scan keyboard and Return - 1. System call address: E42CH - 2. Entry Conditions: - 3. Exit Conditions: - a. If no key was pressed, accumulator = 00H - b. If a key was pressed, Key code is in accumulator - 4. Flags: #### **NUMERIC FUNCTION CALLS** From the documentation, it appears that numeric functions are called with the X register pointing to 7A00H - 7A07H and the Y register pointing to 7A10H - 7A17H if Y is needed. Results appear to always be stored in 7A00H - 7A07H. Numeric data is stored in these memory areas as previously described. | Two Variable | Numeric Functions | |--------------|-------------------| | Addition | V + V - V | | Addition | $X + Y \rightarrow X$ | EFBAH | |----------------|----------------------------|-------| | Subtraction | X - Y→X | EFB6H | | Multiplication | . X * Y → X | F01AH | | Division | $X/Y \rightarrow X$ | F084H | | Exponentiation | $X \wedge Y \rightarrow X$ | F89CH | #### Single Variable Numeric Function | Square Root | SQR X→X | F0E9H | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------| | Logarithm | LN X→X | F161H | | | LOG X→X | F165H | | Exponentials | EXP X→X | F1CBH | | .enteros • o considerado de la considerada del considerada del considerada de la del considerada del considerada del considerada del considerada | 10∧X→X | F1D4H | | Sine | SIN X→X | F3A2H | | Cosine | COS X→X | F391H | | Tangent | TAN X→X | F39EH | | Arcsine | ASN X→X | F49AH | | Arccosine | ACS X→X | F492H | | Arctangent | ATN X→X | F496H | | | DEG X→X | F531H | | | DMS X→X | F564H | | Absolute Value | ABS X→X | F597H | | Signum Function | SGN X→X | F59DH | | Integer Function | INT X→X | F5BEH | #### **OPERATIONS WITH STRINGS** #### ASC and LEN Subroutines - 1. System call address: D9DDH - 2. Entry Conditions: - a. Character string information is stored in 7A04H 7A07H as previously described. - b. YL = 60H for ASC = 64H for LEN - 3. Exit Conditions: - a. The result is in 7A00H 7A07H - b. UH contains the error code (00H is a normal finish) if an error occurred. - 4. Flags: #### **CHR\$** Subroutine - 1. System call address: D9B1H - 2. Entry Conditions: - a. Integers from 0 255 are placed into 7A07H. - b. 7894H = 10H - 3. Exit Conditions: - a. If UH = 0 then a proper exit occurred, otherwise UH contains the error code. - b. 7B10H contains the ASCII code - c. 7A04H 7A06H contain C1H 7BH 10H - d. If the ASCII code was 00H then 7A07H contains 00H otherwise, 7A07H contains 01H. - 4. Flags: #### **VAL Subroutine** - 1. System call address: D9D7H - 2. Entry Conditions: string information is in 7A00H 7A07H. - 3. Exit Conditions: - a. The result is in 7A00H 7A07H - b. UH contains the error code (00H is a normal finish) if an error occurred. - 4. Flags: #### STR\$ Subroutine 1. System call address: D9CFH - 2. Entry Conditions: - a. numeric value to be converted is in 7A00H 7A07H - b. 7894H = 10H - 3. Exit conditions: - a. The string pointer is in 7A00H 7A07H - The actual character string is stored at 7B10H and following. - UH contains the error code (00H is a normal finish) if an error occurred. - 4. Flags: ### RIGHT\$(X\$,Y), LEFT\$(X\$,Y), and MID\$(X\$,Y.Z) Subroutines - 1. System call address: D9F3H - 2. Entry Conditions: | | RIGHT\$ | LEFT\$ | MID\$ | |--------------|-------------|--------|--------------| | (7890H) | ((7891H)-8 | same | ((7891H)-16 | | (7892H) | (7890H) + 8 | same | (7890H) + 16 | | (7894H) | 10H | 10H | 10H | | 7A00H- | Υ | Y | Z | | 7A07H | | | | | (7890H)- | X\$ | X\$ | X\$ | | (7890H) + 7 | | | | | (7890H) + 8- | | | Y | | (7890H) + 15 | | | | | YL | 02H | 7AH | 7BH | | | | | | - 3. Exit Conditions: - a. The string pointer is in 7A00H 7A07H - The actual character string is stored at 7B10H and following. - UH contains the error code (00H is a normal finish) if an error occurred. - 4. Flags: Note: (7890H) and (7891H) cannot be overwritten or changed. If these are changed, the routine will not function properly. #### String Concatenation - 1. System call address: D925H - 2. Entry Conditions: - a. 7894H = 10H - Information on the first character string is stored in 7A00H 7A07H - Information of the second character string is stored in 7A10H - 7A17H in the same format as previously described. - 3. Exit Conditions: - a. Information on the new character string is placed in 7A00H 7A07H. - Actual concatenated string is put in 7B10H and following memory locations. - c. If an error occurs, UH contains the error code. - 4. Flags: