### **FOREWORD** Since the release of the PC-1500 on market, we have had great number of questions from users regarding the machine language of the PC-1500. To meet with such demand from ardent users, we are now sending this text for study of the machine language of the Sharp's original design LH5801 Microprocessor and LH5811 Peripheral Control LSI in concern with the PC-1500 system. Because the text is edited on the basis of user questions, it may not support quality as a guidebook. In such an event, you are suggested to make reference to microprocessor guidebooks published on market, in addition to this text. Your opinions and questions are welcome through our products distributor. NOTE: Machine language program, which controls hardware directly, gives you more various functions than BASIC programs. However, you should check your machine language program enough to make no error before executing it because single wrong key operation may upset the program or occasionally make the machine break down. Sharp Corporation assumes no liability or responsibility of any kind arising from the use of programs or program materials or any part thereof. #### SPECIAL NOTICE TO PC-1500A CUSTOMERS Because the PC-1500A provides more RAM than the PC-1500, some of the descriptions of the CHIP SELECT SIGNAL, MEMORY MAP, and 40-PIN CONNECTOR (for memory modules) require modifications to suit the PC-1500A. A summary of the differences between the PC-1500A and the PC1500 is given in the addendum on the page 161. Take notice of these differences when using machine language. # CONTENTS | 1. | Machine La | anguage | 1 | |----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|------| | 2. | LH5801 Mic | croprocessor | 5 | | | 2-1. Outline | e of LH5801 | 6 | | | 2-2. Interna | al structure | 7 | | | 2-2-1. | Block diagram | 7 | | | 2-2-2. | | 8 | | | 100000000000000000000000000000000000000 | Status flags | 8 | | | | CPU pin description | 9 | | | | ons | 14 | | | | Timer | 14 | | | | Interrupts | 17 | | | | Reset | 20 | | | | CPU system sequence | 21 | | | 2-3-4. | | 22 | | | | WAIT function. | 23 | | | | | 24 | | | | 1 instructions | 0.77 | | | | Outline | 24 | | | 2-4-2. | | 25 | | | 2-4-3. | | 31 | | | 2-4-4. | Transfer and search instructions | 33 | | | 2-4-5. | Block transfer and search instructions | 38 | | | 2-4-6. | Rotate and shift instructions | 39 | | | 2-4-7. | CPU control instructions | 42 | | | 2-4-8. | Jump instructions | 45 | | | 2-4-9. | Subroutine jump instructions | 49 | | | 2-4-10 | Return instructions | 53 | | | 2-5. Comm | and list | 54 | | | 2-6. Electri | cal characteristics and timings | 63 | | | | | | | 3. | LH5810/LH | 15811 I/O port controller | 67 | | | 3-1. Outline | B | 68 | | | 3-2. Function | ons | 68 | | | | al structure | 70 | | | | Block diagram | 70 | | | 3-3-2 | Internal registers | 70 | | | 3-3-3 | Pin description | 73 | | | | ons | 74 | | | | Operation | 74 | | | 3-4-2. | | 75 | | | 3-4-3. | Serial data input | 76 | | | 3-4-4. | | 77 | | | | | 78 | | | Note that the state of stat | I/O port controller input/output circuits | 78 | | | | I/O port controller input/output circuits | | | | 3-5-2. | | 79 | | | 3-5-3. | Electrical characteristics | 79 | | 4. | PC-1500 h | ardware description | 85 | |----|---------------------------------------|-----------------------------------------------------------------------|-----| | | 4-1. PC-15 | 00 system configuration | 86 | | | 4-1-1. | Outline | 86 | | | 4-1-2. | Block diagram | 87 | | | • 4-1-3. | Power supplies (PC-1500, CE-150, CE-158, CE-159) | 87 | | | | 600 | 89 | | | | Outline | 89 | | | | Block diagram | 90 | | | | Chip select circuit | 91 | | | | PC-1500 system memory map | | | | | ector signals/LSI signals | | | | | 40-pin connector | | | | | 60-pin connector | | | | | LH5801 Microprocessor | | | | | I/O PC | | | | | natrix and key code chart | | | | · · · · · · · · · · · · · · · · · · · | | | | 5 | PC-1500 s | oftware | 111 | | ٠. | | C command related PC-1500 machine language | | | | | NEW | | | | | STATUS | | | | | PEEK | | | | | POKE | | | | | CALL | | | | | CSAVE M | | | | | CLOAD M | | | | | al code chart | | | | | ssion of variable and program | | | | | Expression of decimal number | | | | | Expression of decimal number | | | | | Expression of character string | | | | | Structure of variable name | | | | 5-3-4. | | | | | 7.7.7. | Structure of program Structure of reserve area | | | | | | | | | - | m subroutines | | | | | Character functions | | | | | Arithmetic subroutines | | | | | Comparison | | | | | Search | | | | 5-4-5. | | | | | | Printer | | | | | Cassette tape | | | | 5-4-8. | Caution for system subroutine call | 141 | | c | Machine ! | anguago programming overwhite | 4 | | 0. | | anguage programming examples | | | | | y to hexadecimal conversion | | | | | ay inversion | | | | | e display dot left shift | | | | _ | e display dot right shift | | | | | ersion of USING format expressed numerical data into character string | | | | u-o. Powe | OIL MAL DOES NOT ACTIVATE THE DRINTER UDON DOWER ON | 140 | | [REFERENCE] | | |------------------------------------------------------|-----| | 1. Determining printing character size and direction | 150 | | 2. Restoration of array and two-character variable | 150 | | 3. Knowing the use of CE-150 | 150 | | 4. CMT format | 151 | | 5. Circuit diagram | 153 | | 5-1. PC-1500 | 154 | | 5-2. CE-150 | 155 | | 5-3. CE-151 | 156 | | 5-4. CE-153 | | | 5-5. CE-155 | 157 | | 5-6. CE-158 | 158 | | 5-7. CE-159 | 159 | | [ADDENDUM] | | | Differences between the PC-1500A and the PC-1500 | 161 | 1 # Machine Language # 1. Machine language There are many program languages for each purpose. PC-1500, for example, is designed to carry out both BASIC and machine language. BASIC is easy to use, however, execution speed is slow. On the other hand, machine language is difficult to understand but execution speed is fast. Usually, machine language program would be written with the assemble language, which consists of mnemonic codes, and then the assemble language will be translated into machine language. #### [EXAMPLE] DISPLAY REVERSE PROGRAM Prepare the program with assemble language consisting of mnemonic codes. ``` LDI UH,78H prepare for assignment of the first display buffer address. UL.4DH LDI DEC UH advance the address LDA U take data in the accumulator FFH EAL take the complement STA U return data into memory LOP 06H CPI UH,77H make the loop BCS -0EH return to BASIC RTN ``` Translate the above program into machine language. The assembler translates the assemble language into the machine language automatically according to the list. However, a short program can be translated manually. (hand assemble) The above program can be translated as follows: ``` 68 78 6A 4D FD 62 25 BD FF 2E 88 06 6C 77 93 0E 9A ``` After the completion of the machine language program, write it in PC-1500 by using POKE instruction. And execute the program together with BASIC by CALL instruction. Execute the following program. You can run the BASIC program with F A and the machine language program with F B. Display reverse in machine language program is faster than that of BASIC. You would know how functional the machine language program is. EX. Write the following program after executing NEW &4100 [MTR] . ``` 10 "A" WAIT O PRINT" sharp pocket computer" 20 30 FOR A=0 TO 155 40 GCURSOR A GPRINT 255-POINT A 50 60 NEXT A 70 GOTO 30 80 END 100 "B" WAIT 0 PRINT "sharp pocket computer" 110 POKE &40C5, &68, &78, &6A, &4D, &FD,&62,&25,&BD,&FF,&2E,&88,&06 130 POKE &40D1 . &6C . &77 . &93 . &0E . &9A CALL &40C5 140 WAIT 20: PRINT: GOTO 140 150 160 END ``` This manual is divided into three major sections; description of LSI (pp. 5~84: LH5801 Microprocessor & LH5810/LH5811 I/O port controller), PC-1500 hardware description (pp. 85~109), and PC-1500 software description (pp. 111~141). If you want to know about PC-1500 system first, read from p. 86. 2 LH5801 Microprocessor # 2-1. Outline of LH5801 The LH5801 Microprocessor is a CMOS static 8-bit microprocessor that features low power dissipation performance inherent to CMOS LSI and large capacity data processing. Not only that, it enables to to configure a variety of systems with a few additional chips because such as the LCD backplate signal generator, input port, external latch clock, and timer are built in the LH5801. ### Features of the LH5801 - 8-bit parallel data processing - ② Direct accessing of 128K bytes - ① Use of a 6-byte general purpose register, in addition to the accumulator, allows to comprise three pairs of 2-byte date pointers. - 4 9-bit timer capability - (5) Three kinds of interrupts - · Non-maskable interrupt - Maskable interrupt - Timer interrupt - 6 82 instruction set - WAIT function (memory access control possible) - (8) Clock P $\phi$ for input port (8-bit) and external latch - Memory backup function (BFI, BFO) - (i) LCD backplate signal control - (1) External crystal connection for clock generation - (2) Reducing program steps by means of 28-kind single step vector subroutine jump # 2-2. Internal Structure # 2-2-1. Block diagram Fig. 1-1 Block diagram of LH5801 Fig. 1-2 Internal register & flipflops ## 2-2-2. Internal registers | Symbol<br>P | | Name | Bit size | Description | | | | | |-------------|-----|-------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | | Program counter 1 | | Indicates the address next to the address the C is now in execution. It will be incremented by "when the next instruction is fetched. | | | | | | | S | Stack<br>pointer | 16 | Indicates the stack address. | | | | | | Α | | Accumulator | 8 | Used for retention of operational result or for data transfer with the external memory. | | | | | | Xreg XL XH | | | 8 | XL, XH, YL,YH,UL, UH comprise independent 8- | | | | | | | | | 8 | bit registers. Also, used as 16-bit data pointers, Xreg, Yreg, and | | | | | | Yreg | YL | Data register | 8 | Ureg, when used in a pair. | | | | | | | YH | | 8 | | | | | | | | UL | | - 8 | | | | | | | Ureg | UH | | 8 | 1 | | | | | | ТМ | | Timer counter | 9 | When "0" is set to the TM, it stops the counter action. When anything other than "0" is set, it puts the counter into action. When the TM turns full of "1" with the interrupt enable signal IE on, CPU executes an interrupt processing. | | | | | | F | ,U | | 1 | General purpose flip-flop. | | | | | | PV | | | 1 | | | | | | | DI | ISP | | 1 | LCD on/off control. | | | | | | 8 | Т | Status register | 8 | Low order 5 bits represent one of five status of operational result. | | | | | # 2-2-3. Status flags Status flags, C, V, H, Z, IE are contained in the 8-bit status register. In general, flags other than IE change their state after the execution of arithmetical instruction. #### ① Carry flag C Carry flag C is set when there is a carry from the MSB and reset when there is no carry. For SUBTRACT, the flag is set when there is no borrow or reset when there is. #### ② Half carry flag H Half carry flag H is set when there is a carry from the bit position "3" (digit-to-digit carry) and reset when there is no carry. #### ③ Zero flag Z Zero flag Z is set when the operational result is zero and reset when not. #### Overflow flag V Overflow flag V is set or reset depending on the operational result of "C6⊕C7"; where, the carry from the bit position 6 of a single byte data is assumed to be C6 and the carry from the bit position 7 to be C7. | Single byte data | | | | | | |------------------|-------|-------|-------|----|----| | | B7 B6 | B5 B4 | B3 B2 | B1 | BO | ### 2-2-4. CPU pin description | | 112<br>113<br>113<br>113<br>113<br>113<br>113<br>113<br>113<br>113 | | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | | NC<br>AD13<br>AD13<br>AD11<br>AD11<br>AD10<br>AD6<br>AD6<br>AD7<br>AD6<br>AD7<br>AD7<br>AD7<br>AD7<br>AD10<br>AD7<br>AD7<br>AD7<br>AD7<br>AD7<br>AD7<br>AD7<br>AD7<br>AD7<br>AD7 | | | | 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 | les . | | R/W | 58 38 | D7 | | PΦ | 59 37 | D6 | | PV | 60 36 | D5 | | PU | 61 35 | D4 | | <b>Ø</b> OS | 62 34 | D3 | | XL0 | 63 33 | D2 | | XL1 | 64 32 | D1 | | WAIT | 65 31 | D0 | | IN7 | 66 LH5801 30 | ME0 | | IN6 | 67 | ME1 | | IN5 | 68 (TOP VIEW) 28 | OD | | IN4 | 69 27 | H0 | | IN3 | 70 26 | H1 | | IN2 | 71 25 | H2 | | IN1 | 72 24 | H3 | | INO | 73 23 | H4 | | NC | 74 22 | H5 | | NC | 75 21 | Н6 | | NC | 76 20 | J H7 | | | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | | | | E | ×. | | | RESET NC BRQ BRI BRI VGG OPF VGG VVM VDIS VA VVB NNMI HIN HA DIS | | #### ① XL0, XL1 These are external crystal connection pins. XL0 is the input pin and XL1 is the output pin. Clock frequency is divided by two inside the CPU. When the 2.6MHz crystal is connected, the CPU operates under 1.3MHz of internal machine cycle. #### ② AD0~AD15 Address bus. Outputs from these pins are 3-state (three output states of high, low and high impedance) and go high impedance with BRQ (Bus ReQuest). Basically, 64K bytes of memory area is supported for direct accessing, but it is made possible to access even 128K area of memory area when ME0 and ME1 are used. #### ③ D0~D7 Bidirectional data bus which is used to write or data to/from the external memory. #### 4 ME0, ME1 Memory enable signals. As memory area of 64K bytes is accessed by ME0 and another 64K bytes by ME1, it permits direct access of memory area of 128K bytes in total. Since ME0 is used for instruction fetch and stack operation, accessing by means of the program counter P and stack pointer S is limited to a maximum of 64K bytes. As for data accessing, both memory areas covered by ME0 and ME1 can be controlled by a CPU instruction. #### ⑤ ΦOS Through this line can be supplied the clock to an external system since the clock in the same phase as the CPU internal basic clock is on this line. Connection of the 2.6MHz crystal oscillator to XL0 and XL1 will supply the clock of 1.3MHz. #### 6 R/W Memory write signal. A low on this line causes the CPU to send data on the data bus. #### ① OD Output disable signal. A high on this line causes the CPU to prohibit data output to the external device. It is used in writing data to the memory. #### ® RESET CPU reset input. High state of this signal resets the CPU and the contents of the address FFFEH is set to the register PH and the contents of the address FFFFH to the register PL. When it turns from high to low level, it starts program execution from the address of the program counter. #### (9) NMI Non-maskable interrupt input. High state of this signal causes interrupt to the CPU, to which the CPU unconditionally responds and starts the interrupt processing routine of which high order byte address is represented by the address FFFCH and low order byte address by FFFDH. #### (10) MI Maskable interrupt input. When the interrupt enable flag IE is active, a high on the pin M1 requests interrupt, to which the CPU starts to execute the interrupt processing routine whose high order byte address is represented by the address FFF8H and low order byte address by FFF9H. # How instruction execution address is determined against the reset and interrupt input #### (II) BRQ Bus request signal. #### 12 BAK Bus request ackowledge signal. When BRQ goes high, the CPU issues a high level of signal on BAK in response to it. The CPU keeps address bus (AD0~AD15), data bus (D0~D7), ME0, ME1, R/W, and OD high impedance when BAK is in high level. #### (i) OPF Operation code fetch signal which is sent out when CPU fetches operation code (instruction code). OPF is issued only when operation code is fetched and will not be issued in fetching address data, immediate data, and second byte of the two-step instruction. #### (14) INO~IN7 Input port through which the CPU receives 8-bit data into the accumulator. As internal pullup resistor is used, the CPU assumes it to be high level when not connected. #### (15) P Ø External latch clock. With high level of this clock, the contents of the accumulator is sent on the data bus. Addition of IC will comprise an output port. REFERENCE: ATP instruction. #### (6) PU, PV These are CPU internal flipflop outputs. PU and PV are furnished with set and reset instructions. #### (I) WAIT CPU wait signal. A high on this line stops the clock $\phi$ so that the CPU halts its operation. As soon as WAIT turns low, the CPU resumes the operation. NOTE: WA is the flipflop dedicated to WAIT, by which the WAIT input is received at the falling edge of the clock ΦOS. Because the CPU operating clock φ stops when WA is high, it makes the CPU stopped, consequently. #### (18) HO~H7 LCD backplate signal output. As the liquid crystal display (LCD) is driven by backplate signals and segment signals, the CPU controls the backplate signals. #### 19 VA, VB, VM, VDIS LCD backplate power supply inputs. #### (20) HIN Input signal to the counter from which the LCD backplate signals H0~H7 are generated. Normally, connected to pin HA of the CPU. #### (21) HA CPU internal divider output pin. It is used for the basic clock that drives the LCD that connected with HIN and the segment signal generating LSI. #### (22) DISP LCD on/off control signal output which can be set or reset by means of instruction. #### 23 BFO, BFI BF flipflop output (BFO) and input (BFI). The BF flipflop is reset by the OFF instruction from the CPU, and will be set when the input BFI is turned to high level. BFO is in low level when the BF flipflop is set and in high level when reset. As VGG is power supply to the BF flipflop, the contents of the flipflop are retained as long as VGG is in supply. Normally, it is used for memory backup system. # 2-3. Functions ### 2-3-1. Timer The timer is a 9-bit polynominal counter. The counter value can be set by the AM0 or AM1 instruction of the CPU. Shown in "POLINOMINAL COUNTER" is the list of hexadecimal data of counter with decimal count number. The timer operates continuously at all times. When the counter value reaches 1FFH, it issues interrupt request to the CPU. If IE (Interrupt Enable) flag is active at that point, the CPU jumps to the timer interrupt processing routine whose high order byte address is represented by the contents of the address FFFAH and low order byte address by the contents of the address FFFBH. The timer has to be set to 000H when it is not used. Since it counts in synchronization with the clock $\Phi$ F, each one cycle of $\Phi$ F increments the counter one step. When the 4MHz crystal oscillator is in connection, the timer is incremented at each $32\mu$ sec, because $\Phi$ F is 31.25kHz. ### "POLINOMINAL COUNTER" | COUNT<br>NUMBER | DATA OF<br>COUNTER | COUNT<br>NUMBER | DATA OF<br>COUNTER | COUNT<br>NUMBER | DATA OF<br>COUNTER | COUNT<br>NUMBER | DATA OF<br>COUNTER | COUNT<br>NUMBER | DATA OF<br>COUNTER | |-----------------|--------------------|-----------------|--------------------|-----------------|--------------------|-----------------|--------------------|-----------------|--------------------| | 511 | 1FF | 459 | 0B7 | 407 | 1AB | 355 | 0A7 | 303 | 1E5 | | 510 | 0FF | 458 | 05B | 406 | 1 D5 | 354 | 153 | 302 | 1F2 | | 509 | 07F | 457 | 02D | 405 | 0EA | 353 | 0A9 | 301 | 1F9 | | 508 | 03F | 456 | 116 | 404 | 075 | 352 | 154 | 300 | OFC | | 507 | 01F | 455 | 18B | 403 | 03A | 351 | 1AA | 299 | 17E | | 506 | 00F | 454 | 1C5 | 402 | 11D | 350 | 0D5 | 298 | 1BF | | 505 | 107 | 453 | 1E2 | 401 | 08E | 349 | 06A | 297 | 0DF | | 504 | 183 | 452 | 0F1 | 400 | 047 | 348 | 035 | 296 | 06F | | 503 | 101 | 451 | 078 | 399 | 123 | 347 | 01 A | 295 | 137 | | 502 | 1E0 | 450 | 13C | 398 | 191 | 346 | 10D | 294 | 09B | | 501 | OF0 | 449 | 19E | 397 | 008 | 345 | 186 | 293 | 04D | | 500 | 178 | 448 | 1CF | 396 | 064 | 344 | 003 | 292 | 126 | | 499 | 1BC | 447 | 1E7 | 395 | 032 | 343 | 161 | 291 | 093 | | 498 | 1DE | 446 | 1F3 | 394 | 119 | 342 | 180 | 290 | 049 | | 497 | 1EF | 445 | 0F9 | 393 | 08C | 341 | 1D8 | 289 | 124 | | 496 | 1F7 | 444 | 07C | 392 | 046 | 340 | 1EC | 288 | 092 | | 495 | 0FB | 443 | 13E | 391 | 023 | 339 | 0F6 | 287 | 149 | | 494 | 07D | 442 | 19F | 390 | 111 | 338 | 17B | 286 | 1A4 | | 493 | 03E | 441 | OCF | 389 | 088 | 337 | OBD | 285 | 0D2 | | 492 | 11F | 440 | 167 | 388 | 044 | 336 | 05E | 284 | 169 | | 491 | 08F | 439 | 183 | 387 | 022 | 335 | 12F | 283 | 184 | | 490 | 147 | 438 | 009 | 386 | 011 | 334 | 197 | 282 | 1DA | | 489 | 1A3 | 437 | 06C | 385 | 008 | 333 | OCB | 281 | 1ED | | 488 | 1D1 | 436 | 036 | 384 | 004 | 332 | 165 | 280 | 1F6 | | 487 | 0E8 | 435 | 11B | 383 | 002 | 331 | 1B2 | 279 | 1FB | | 486 | 074 | 434 | 08D | 382 | 001 | 330 | 1D9 | 278 | OFD | | 485 | 13A | 433 | 146 | 381 | 100 | 329 | OEC | 277 | 07E | | 484 | 19D | 432 | 0A3 | 380 | 080 | 328 | 076 | 276 | 13F | | 483 | 0CE | 431 | 151 | 379 | 040 | 327 | 13B | 275 | 09F | | 482 | 067 | 430 | 0A8 | 378 | 020 | 326 | 09D | 274 | 04F | | 481 | 133 | 429 | 054 | 377 | 010 | 325 | 04E | 273 | 127 | | 480 | 099 | 428 | 12A | 376 | 108 | 324 | 027 | 272 | 193 | | 479 | 04C | 427 | 095 | 375 | 084 | 323 | 113 | 271 | 009 | | 478 | 026 | 426 | 04A | 374 | 042 | 322 | 089 | 270 | 164 | | 477 | 013 | 425 | 025 | 373 | 021 | 321 | 144 | 269 | 0B2 | | 476 | 009 | 424 | 112 | 372 | 110 | 320 | 0A2 | 268 | 159 | | 475 | 104 | 423 | 189 | 371 | 188 | 319 | 051 | 267 | OAC | | 474 | 082 | 422 | 104 | 370 | 0C4 | 318 | 028 | 266 | 056 | | 473 | 041 | 421 | 0E2 | 369 | 062 | 317 | 014 | 265 | 128 | | 472 | 120 | 420 | 071 | 368 | 031 | 316 | 10A | 264 | 195 | | 471 | 090 | 419 | 038 | 367 | 018 | 315 | 085 | 263 | 0CA | | 470 | 148 | 418 | 11C | 366 | 10C | 314 | 142 | 262 | 065 | | 469 | 0A4 | 417 | 18E | 365 | 086 | 313 | 0A1 | 261 | 132 | | 468 | 052 | 416 | 007 | 364 | 043 | 312 | 150 | 260 | 199 | | 467 | 129 | 415 | 163 | 363 | 121 | 311 | 1A8 | 259 | occ | | 466 | 194 | 414 | 181 | 362 | 190 | 310 | 0D4 | 258 | 066 | | 465 | 1CA | 413 | 008 | 361 | 108 | 309 | 16A | 257 | 033 | | 464 | 0E5 | 412 | 16C | 360 | 0E4 | 308 | 0B5 | 256 | 019 | | 463 | 172 | 411 | 0B6 | 359 | 072 | 307 | 05A | 255 | 00C | | 462 | 189 | 410 | 153 | 358 | 139 | 306 | 12D | 254 | 006 | | 461 | ODC | 409 | 0AD | 357 | 09C | 305 | 196 | 253 | 003 | | 460 | 16E | 408 | 156 | 356 | 14E | 304 | 1CB | 252 | 101 | | COUNT<br>NUMBER | DATA OF<br>COUNTER | COUNT | DATA OF<br>COUNTER | COUNT<br>NUMBER | DATA OF<br>COUNTER | COUNT<br>NUMBER | DATA OF<br>COUNTER | COUNT<br>NUMBER | DATA OF<br>COUNTER | |-----------------|--------------------|-------|--------------------|-----------------|--------------------|-----------------|--------------------|-----------------|--------------------| | 251 | 180 | 199 | 09A | 147 | 141 | 95 | 00E | 43 | 01C | | 250 | 0C0 | 198 | 14D | 146 | 1A0 | 94 | 007 | 42 | 10E | | 249 | 060 | 197 | 1A6 | 145 | 0D0 | 93 | 103 | 41 | 087 | | 248 | 030 | 196 | 0D3 | 144 | 168 | 92 | 181 | 40 | 143 | | 247 | 118 | 195 | 069 | 143 | 0B4 | 91 | 1C0 | 39 | 1A1 | | 246 | 18C | 194 | 134 | 142 | 15A | 90 | 0E0 | 38 | 1D0 | | 245 | 006 | 193 | 19A | 141 | 1AD | 89 | 070 | 37 | 1E8 | | 244 | 063 | 192 | 1CD | 140 | 1D6 | 88 | 138 | 36 | 0F4 | | 243 | 131 | 191 | 1E6 | 139 | 1ER | 87 | 19C | 35 | 17A | | 242 | 098 | 190 | 0F3 | 138 | 1F5 | 86 | 1CE | 34 | 1BD | | 241 | 14C | 189 | 079 | 137 | 0FA | 85 | 0E7 | 33 | 0DE | | 240 | 0A6 | 188 | 03C | 136 | 17D | 84 | 173 | 32 | 16F | | 239 | 053 | 187 | 11E | 135 | 0BE | 83 | 089 | 31 | 187 | | 238 | 029 | 186 | 18F | 134 | 15F | 82 | 05C | 30 | 0DB | | 237 | 114 | 185 | 107 | 133 | 0AF | 81 | 12E | 29 | 06D | | 236 | 18A | 184 | 1E3 | 132 | 157 | 80 | 097 | 28 | 136 | | 235 | 0C5 | 183 | 1F1 | 131 | 0AB | 79 | 04B | 27 | 19B | | 234 | 162 | 182 | 0F8 | 130 | 155 | 78 | 125 | 26 | 0CD | | 233 | 0B1 | 181 | 17C | 129 | 0AA | 77 | 192 | 25 | 166 | | 232 | 058 | 180 | 1BE | 128 | 055 | 76 | 1C9 | 24 | 0B3 | | 231 | 12C | 179 | 1DF | 127 | 02A | 75 | 1E4 | 23 | 059 | | 230 | 096 | 178 | 0EF | 126 | 015 | 74 | 0F2 | 22 | 02C | | 229 | 14B | 177 | 177 | 125 | 00A | 73 | 179 | 21 | 016 | | 228 | 1 A5 | 176 | 0BB | 124 | 005 | 72 | OBC | 20 | 10B | | 227 | 1D2 | 175 | 05D | 123 | 102 | 71 | 15E | 19 | 185 | | 226 | 1E9 | 174 | 02E | 122 | 081 | 70 | 1AF | 18 | 1C2 | | 225 | 1F4 | 173 | 017 | 121 | 140 | 69 | 1D7 | 17 | 0E1 | | 224 | 1FA | 172 | 00B | 120 | 0A0 | 68 | 0EB | 16 | 170 | | 223 | 1FD | 171 | 105 | 119 | 050 | 67 | 175 | 15 | 1B8 | | 222 | OFE | 170 | 182 | 118 | 128 | 66 | OBA | 14 | 1DC | | 221 | 17F | 169 | 0C1 | 117 | 094 | 65 | 15D | 13 | 1EE | | 220 | 0BF | 168 | 160 | 116 | 14A | 64 | 0AE | 12 | 0F7 | | 219 | 05F | 167 | 0B0 | 115 | 0A5 | 63 | 057 | 11 | 07B | | 218 | 02F | 166 | 158 | 114 | 152 | 62 | 02B | 10 | 03D | | 217 | 117 | 165 | 1AC | 113 | 1A9 | 61 | 115 | 9 | 01E | | 216 | 08B | 164 | 0D6 | 112 | 1D4 | 60 | 08A | 8 | 10F | | 215 | 145 | 163 | 16B | 111 | 1EA | 59 | 045 | 7 | 187 | | 214 | 1A2 | 162 | 185 | 110 | 0F5 | 58 | 122 | 6 | 1C3 | | 213 | 0D1 | 161 | 0DA | 109 | 07A | 57 | 091 | 5 | 1E1 | | 212 | 068 | 160 | 16D | 108 | 13D | 56 | 048 | 4 | 1F0 | | 211 | 034 | 159 | 186 | 107 | 09E | 55 | 024 | 3 | 1F8 | | 210 | 11A | 158 | 1DB | 106 | 14F | 54 | 012 | 2 | 1FC | | 209 | 18D | 157 | 0ED | 105 | 1A7 | 53 | 109 | 1 | 1FE | | 208 | 106 | 156 | 176 | 104 | 1D3 | 52 | 184 | 0 | 1FF | | 207 | 0E3 | 155 | 188 | 103 | 0E9 | 51 | 0C2 | | | | 206 | 171 | 154 | ODD | 102 | 174 | 50 | 061 | | | | 205 | 0B8 | 153 | 06E | 101 | 1BA | 49 | 130 | | | | 204 | 15C | 152 | 037 | 100 | 1DD | 48 | 198 | | | | 203 | 1AE | 151 | 01B | 99 | 0EE | 47 | 1CC | | | | 202 | 0D7 | 150 | 00D | 98 | 077 | 46 | 0E6 | | | | 201 | 06B | 149 | 106 | 97 | 03B | 45 | 073 | | | | 200 | 135 | 148 | 083 | 96 | 01D | 44 | 039 | 1.5 | | | | A84000 | | ACADEMI U | | 100000000 | | A1000 UN | | | # 2-3-2. Interrupts There are following three kinds of interrupt for the LH5801 CPU. #### Non-maskable interrupt When NMI is turned from low to high level, it sets the flipflop IR0 active, upon which time interrupt is requested to the CPU, so that the CPU starts executing the interrupt processing after completion of current instruction execution. Since the non-maskable interrupt is given with the highest priority order, the interrupt will be acknowledged at once, regardless of its internal state. 1R0 will be reset in a course of the interrupt process. As the NIM input is sampled by the clock $\phi$ H, it will become 250kHz when the 4MHz crystal oscillator is connected. When NMI is turned high, the CPU creates synchronizing pulse at the rising edge of the clock $\Phi$ H, which sets IR0 active. If IR0 is active when the CPU acknowledged the interrupt after completion of execution, it goes into the interrupt routine and IR0 is reset in a course of the interrupt processing. #### Non-maskable interrupt processing sequence #### ② Maskable interrupt When MI is turned from low to high level, it sets the flipflop IR2 active. If the interrupt enable IE is active at this point, interrupt is requested to the CPU, so that the CPU starts executing the interrupt processing after completion of current instruction execution. IR2 will be reset in a course of the interrupt process. When interrupt request is issued while IE is inactive, the interrupt will be ignored even though IR2 is set. MI input is sampled in the same manner as in the case of NMI #### Maskable interrupt processing sequence #### 3 Timer interrupt When interrupt is requested from the timer, it sets the flipflop IR1 active. If the interrupt enable IE is active at this point, the CPU starts executing the interrupt processing after completion of current instruction execution, and IR1 will be reset in a course of the interrupt process. When interrupt is requested while IE is inactive, the interrupt will be ignored even though IR1 is set. #### Timer interrupt processing sequence #### Return to main routine The RTI instruction is used for returning from the interrupt processing routine to the main routine. Because the contents of the T register and the program counter are stored in the stack at the beginning of the interrupt processing routine, the contents of the T register in the stack returns by the RTI instruction. Since the interrupt enable flag IE is contained in the T register, the contents of IE immediately before the interrupt returns by the RTI instruction. To disable maskable or timer interrupt by the main routine after returning from the interrupt processing routine, the bit in the stack corresponding to the flag IE must be reset. #### Priority order of interrupts Non-maskable interrupt responds to the interrupt request whatever the CPU internal state may be. Also, it responds in the first priority even during execution of interrupt routine by other interrupt. # 2-3-4. CPU system sequence # 2-3-5. BF flipflop The CPU has two supplies of power; VCC and VGG. As the BF flipflop is driven by VGG, the state of the BF flipflop is retained as long as VGG is in supply, even if VCC supply is out. The BF flipflop is set when the BFI input is turned from low to high level and reset when the OFF instruction is issued from the CPU. Low state of signal is on the BF flipflop output BFO when the flipflop is active and high state of signal when inactive. It is possible to comprise a memory backup system using this BF flipflop. # 2-3-6. WAIT function (interfacing with the slow access time memory) Because the CPU access time is very fast, the CPU must be held with the wait signal in order to access a slow access time memory. Basically, the wait signal is created by the externally provided counter, but the I/O port controller with the programmable wait time control feature (LH8511) is used for this purpose. For more details of this function, refer to the section discussing the I/O port controller. Shown in the next page is the connection of the CPU with the I/O port controller. # 2-4. LH5801 instructions ### 2-4-1. Outline This section deals with function of each instruction. #### Symbols used in discussing operand, function, and operation . A: Contents of the accumulator (8 bits) XL: Contents of the low order 8 bits of X reg YL: Contents of the low order 8 bits of Yreg UL: Contents of the low order 8 bits of Ureg (RL represents either of XL, YL, or UL.) XH: Contents of the high order 8 bits of Xreg YH: Contents of the high order 8 bits of Yreg Contents of the high order 8 bits of Ureg UH: (RH represents either of XH, YH, or UH.) Xreg: Contents of the X register (16 bits) Contents of the Y register (16 bits) Yreg: Contents of the U register (16 bits) Ureg: (Rreg represents either of Xreg, Yreg, or Ureg.) P: Contents of the program counter (16 bits) PL: Contents of low order 8 bits of the program counter PH: Contents of high order 8 bits of the program counter S: Contents of the stack pointer (16 bits) SL: Contents of low order 8 bits of the stack pointer SH: Contents of high order 8 bits of the stack pointer Contents of the memory represented by Rreg (accessed with ME0) #(Rreg): Contents of the memory represented by Rreg (accessed with MEI) Contents of the memory represented by 16 bits of ab (accessed by ME0); where a (ab): represents high order 8 bits of the address and b low order 8 bits - #(ab): Contents of the memory represented by 16 bits of ab (accessed by ME1); where a represents high order 8 bits of the address and b low order 8 bits - i: 8-bit immediate data - i, j: 16-bit immediate data of which high order 8 bits are represented by i and low order 8 bits by j - C: Carry flag - IE: Interrupt enable flag - Z: Zero flag - V: Overflow flag - H: Half carry flag - → Data flow direction - A AND - V OR - ⊕ Exclusive OR - + ADD - SUBTRACT # 2-4-2. Add, subtract, and logical instructions ① ADC (ADd with Carry) Either the contents of the internal register or external memory are 8-bit added with the accumulator including carry, and its result is stored in the accumulator. C, H, Z, and V may change. | • Format | Operation | |-------------|-----------------------------------| | ADC RL | | | ADC RH | | | ADC (Rreg) | $A + [operand] + C \rightarrow A$ | | ADC #(Rreg) | | | ADC (ab) | | | ADC #(ab) | | (EX) ADC XL Value of the XL register is added to the accumulator, providing "C=0". #### ② ADI (ADd Immediate) To either the accumulator or the external memory is added the immediate data. In the case of ADI to the accumulator, carry is included in the operation. C, H, Z, and V may change. #### Format Operation ADI A,i $$A + i + C \rightarrow A$$ ADI (Rreg),i [operand] $$+ i -$$ [operand] ADI #(Rreg),i ADI (ab),i ADI #(ab),i 20H is added to the memory represented by X register. Xreg=4F00H #### 3 DCA (DeCimal Add) Decimal addition is carried out between the external memory and the accumulator including carry, and its result is stored in the accumulator. C, H, Z, and V may change. #### Format DCA (Rreg) DCA #(Rreg) #### Operation 2) $$A + [operand] + C \rightarrow A$$ (C, H, Z, and V may change.) Where, DA is used for compensation of decimal number which is dependent on the value of flags C and H in regard to Item 2). | С | Н | DA | |---|---|-----| | 0 | 0 | 9AH | | 0 | 1 | A0H | | 1 | 0 | FAH | | 1 | 1 | 00H | #### (EX) DCA (Yreg) Decimal addition is carried out between the memory represented by the Y register and the accumulator. Y reg = 4700H | Α | Contents | C | Contents After execution of DCA | | After execution of DCA | | | Decimal addition | |-----|----------|---|---------------------------------|---|------------------------|------------------|--|------------------| | | of 4700H | | С | н | Α | Decimal addition | | | | 35H | 27H | 0 | 0 | 1 | 62H | 35+27+0=62 | | | | 35H | 27H | 1 | 0 | 1 | 63H | 35+27+1=63 | | | | 35H | 67H | 0 | 1 | 1 | 02H | 35+67+0=102 | | | | 35H | 67H | 1 | 1 | 1 | 03H | 35+67+1=103 | | | #### ( ADR (ADd Rreg) Contents of the accumulator are added to the R register. C, H, Z, and V may change. #### Format #### Operation ADR Rreg 1) $$RL + A \rightarrow RL$$ (C, H, Z, and V may change.) 2) $$RH + C \rightarrow RH$$ Contents of the accumulator are added to X register. #### SBC (SuBtract with Carry) The contents of the accumulator are subtracted by the internal register or external memory including $\overline{C}$ , and its result is stored in the accumulator. This operation may also be expressed in the following manner. Complement of the internal register or external memory is obtained first, addition is carried out including carry, then its result is stored in the accumulator. C, H, Z, and V may change. •Format •Operation SBC RL $$A = [operand] - \overline{C} \rightarrow A$$ SBC RH $(C, H, Z, and V may change.)$ SBC (Rreg) or, SBC #(Rreg) SBC (ab) SBC (ab) (C, H, Z, and V may change.) SBC #(ab) Contents of XL register are subtracted from the accumulator. #### 6 SBI (SuBtract Immediate) The contents of the accumulator are subtracted by the immediate data including $\overline{C}$ . C, H, Z, and V may change. •Format SBI A,i •Operation A $$-i - \overline{C} \rightarrow A$$ (C, H, Z, and V may change.) or, A $+\overline{i} + C \rightarrow A$ (C, H, Z, and V may change.) (EX) SBI A, 07H $$A = \begin{bmatrix} 0 & 0 & 1 & 0 & 0 & 1 & 0 & 0 \end{bmatrix}$$ $$i = \begin{bmatrix} 0 & 0 & 0 & 0 & 0 & 1 & 1 & 1 \\ \hline{C} = 1 & & & & \\ \hline{A} = \begin{bmatrix} 0 & 0 & 1 & 0 & 0 & 1 & 0 & 0 \\ \hline{i} = \begin{bmatrix} 1 & 1 & 1 & 1 & 1 & 0 & 0 & 0 \\ \hline{C} = 0 & & & \\ \hline \end{bmatrix}$$ $$Execute$$ $$C = \begin{bmatrix} 1 & 1 & 1 & 1 & 1 & 0 & 0 & 0 \\ \hline C = 0 & & & \\ \hline$$ #### ① DCS (DeCimal Subtract) The contents of the accumulator are decimal subtracted by the external memory including $\overline{C}$ , and its result is stored in the accumulator. C, H, Z, and V may change. #### • Format DCS (Rreg) DCS #(Rreg) #### Operation (C, H, Z, and V may change.) Where, DA is used for compensation of decimal number which is dependent on the value of flags C and H in regard to item 1). | | C | н | DA | |---|---|---|-----| | | 0 | 0 | 9AH | | 9 | 0 | 1 | A0H | | | 1 | 0 | FAH | | | 1 | 1 | 00H | #### (EX) DCS (Xreg) The contents of the memory represented by the X register are decimal subtracted from the accumulator. Xreg = 4700H | Α | Contents<br>of 4700H | С | After execution of DCS | | | Decimal subtraction | |-----|----------------------|---|------------------------|---|-----|---------------------| | | | | С | Н | A | Decimal subtraction | | 42H | 31H | 1 | 1 | 1 | 11H | 42-31-0=11 | | 12H | 31H | 0 | 1 | 1 | 10H | 42 - 31 - 1 = 10 | | 23H | 54H | 1 | 0 | 0 | 69H | 23-54-0=69-100 | | 23H | 54H | 0 | 0 | 0 | 68H | 23-54-1=68-100 | #### ® AND The contents of the accumulator are ANDed with the value of the external memory, and its result is stored in the accumulator. Only the flag Z changes. #### ANI (ANd Immediate) The contents of the accumulator or external memory are ANDed with the immediate data, and its result is stored in the accumulator or the external memory. Only the flag Z changes. #### (III) ORA (OR Acc) The contents of the accumulator are ORed with the value of the external memory, and its result is stored in the accumulator. Only the flag Z changes. #### (II) ORI (OR Immediate) The contents of the accumulator or external memory are ORed with the immediate data, and its result is stored in the accumulator or the external memory. Only flag Z changes. •Format •Operation OR1 A,i [Operand] $\vee$ $i \rightarrow$ [operand] OR1 (Rreg),i (Z changes.) OR1 #(Rreg),i (OR1 (ab),i OR1 #(ab),i #### (2) EOR (Exclusive OR) The contents of the accumulator are exclusively ORed with the value of the external memory, and its result is stored in the accumultor. Only the flag Z changes. #### (13) EAI (Exclusive or Acc and Immediate) The contents of the accumulator are exclusively ORed with the immediate data, and its result is stored in the accumulator. Only the flag Z changes. • Format • Operation EAl $$i$$ $A \oplus i \rightarrow A$ (Z changes.) #### (4) INC (INCrement) The value of the accumulator or the register is INCremented by one. In the case of the 8-bit register (A, RL, RH), it makes flags C, V, H and Z changed. In the case of the 16-bit register Rreg, no flag change takes place. | • Format | <ul> <li>Operation</li> </ul> | |----------|---------------------------------------| | INC A | $[Operand] + 1 \rightarrow [operand]$ | | INC RL | (C, V, H, and Z changed.) | | INC RH | | | INC Rreg | $[Operand] + 1 \rightarrow [operand]$ | #### (§) DEC (DECrement) The value of the accumulator or register is DECremented by one. In the case of the 8bit register (A, RL, RH), it makes flags C, V, H and Z changed. In the case of the 16-bit register Rreg, no flag change takes place. ### 2-4-3. Compare and bit test #### (6) CPA (ComPare Acc) The contents of the accumulator are compared with register or external memory, and its result is represented by flags C, V, H, and Z. | • Format | <ul> <li>Operation</li> </ul> | | | | | | | |-------------|-------------------------------------------------------------------|-----|---|---|---|--|--| | CPA RL | $A = [operand] \rightarrow change in C, V, H, and Z$ | | | | | | | | CPA RH | or | | | | | | | | CPA (Rreg) | $A + \overline{[operand]} + I \rightarrow change in C, V, H, and$ | | | | | | | | CPA #(Rreg) | | 1 0 | _ | | 1 | | | | CPA (ab) | Comparison | С | Z | V | Н | | | | CPA #(ab) | A>[operand] | 1 | 0 | * | * | | | | CIA H(uo) | A=[operand] | 1 | 1 | * | * | | | | | A<[operand] | 0 | 0 | * | | | | \* : Flags V and H may change according to the condition mentioned in "Status flag", but it has no meaning with the CPA instruction. (EX) CPA XL $$A = \begin{bmatrix} 0 & 1 & 0 & 1 & 0 & 1 & 0 & 0 \\ & & & & & & & \\ & & & & & & \\ & & & & & & \\ & & & & & \\ & & & & & \\ & & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & \\ & & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\$$ #### (I) CPI (ComPare Immediate) The contents of the accumulator or register are compared with the immediate data, and its result is represented by flags C, V, H, and Z. | • Format | Operation | |----------|-------------------------------------------------| | CPI RL,i | [Operand] $-i \rightarrow$ change in C, V, H, Z | | CPI RH,i | | | CPI A,i | | | Comparison | С | Z | V | Н | |---------------|---|---|---|---| | [Operand]>i | 1 | 0 | * | * | | [Operand] = i | 1 | 1 | * | * | | [Operand] < i | 0 | 0 | * | * | <sup>\* :</sup> Refer to "CPA instruction". #### (8) BIT (test BIT) The accumulator is ANDed with the external memory, and its result is represented by the flag Z. #### (9) BII (test BIt Immediate) The contents of the accumulator or the external memory are ANDed with the immediate data, and its result is represented by state of the flag Z. # •Format •Operation BII A,i [Operand] $\land i \rightarrow Z$ flag change BII (Rreg),i BII #(Rreg),i BII (ab),i BII (ab),i ## 2-4-4. Transfer and search instructions #### 20 LDA (LoaD Acc) The contents of the RL register, RH register, or the internal memory are transferred to the accumulator. Only the flag Z changes. •Format LDA RL LDA RH LDA (Rreg) LDA #(Rreg) LDA (ab) LDA #(ab) •Operation [Operand] → A Flag Z 1: when [operand] = 00H 0: when [operand] ≠ 00H #### 2) LDE (Load and DEcrement) The contents of the external memory (R register) are transferred to the accumulator, then "1" is decremented from R register. Only the flag Z changes. •Format LDE Rreg (Rreg) → A Rreg − 1 → Rreg Flag Z 1: when (Rreg) = 00H 0: when (Rreg) ≠ 00H #### 22 LIN (Load and INcrement) The contents of the external memory (R register) are transferred to the accumulator, then "1" is added to the R register. Only the flag Z changes. #### (3) LDI (LoaD Immediate) The immediate data is loaded in the accumulator, RL register, RH register, or stack pointer S. The flag Z changes when transfer is done to the accumulator and no flag change occurs in otherwise case. Two bytes of the immediate value are transferred in the case of the stack pointer. #### (4) LDX (LoaD Xreg) The contents of the R register, stack pointer, or program counter are transferred to the X register. [Operand] → Xreg No change takes place in flags. #### Format #### Operation LDX Rreg DA KIEG LDX S LDX P #### STA (STore Acc) The contents of the accumulator are transferred to the RL register, RH register, or the external memory. A → [operand] No change takes place in flags. #### • Format Operation STA RL STA (Rreg) STA #(Rreg) STA (ab) STA #(ab) ## (EX) STA XL $$A = \begin{bmatrix} 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \end{bmatrix} \xrightarrow{Execute} XL = \begin{bmatrix} 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \end{bmatrix}$$ #### 26 SDE (Store and DEcrement) The contents of the accumulator are transferred to the external memory (Rreg), then "1" is decremented from Rreg. No change takes place in flags. #### Format Operation SDE Rreg $A \rightarrow (Rreg)$ $$Rreg - 1 \rightarrow Rreg$$ (EX) SDE Yreg Yreg=4700H #### ③ SIN (Store and INcrement) The contents of the accumulator are transferred to the external memory (Rreg), then "1" is incremented to Rreg. No change takes place in flags. • Format • Operation SIN Rreg $A \rightarrow (Rreg)$ Rreg $+ 1 \rightarrow Rreg$ #### (3) STX (STore Xreg) The contents of Xreg are transferred to the R register, stack pointer, or program counter. No change takes place in flags. #### PSH (PuSH) The contents of the accumulator or R register are stacked in the memory specified by the stack pointer. In the case of the accumulator, the stack pointer is decremented by one. In the case of the R register, the stack pointer is decremented by two. | • Format | <ul> <li>Operation</li> </ul> | |------------|-------------------------------| | ① PSH A | $A \rightarrow (S)$ | | | $S-1 \rightarrow S$ | | ② PSH Rreg | $RL \rightarrow (S)$ | | | S-I-S | | | $RH \rightarrow (S)$ | | | S-1-S | #### 39 POP (POP) The contents of the stack pointer transferred by the PSH instruction are returned to the accumulator or the R register. In the case of the accumulator, the stack pointer is added by one. In the case of the R register, the stack pointer is added by two. #### (3) ATT (Acc To T) The contents of the accumulator are transferred to the T register. | <ul><li>Format</li></ul> | <ul> <li>Operation</li> </ul> | |--------------------------|-------------------------------| | ATT | $A \rightarrow T$ | #### 32 TTA (T To Acc) The contents of the T register are transferred to the accumulator. The flag Z changes. • Format Operation $T \rightarrow A$ Flag Z 1: when T = 00H 0: when $T \neq 00H$ ## 2-4-5. Block transfer and search instructions #### 33 TIN (Transfer and INcrement) Format The contents of the external memory (Xreg) are transferred to the external memory (Yreg), then both Xreg and Yreg are added by one. No change takes place in flags. Operation TIN $$(Xreg) \rightarrow (Yreg)$$ $$Xreg + 1 \rightarrow Xreg$$ $$Yreg + 1 \rightarrow Yreg$$ $$(EX) TIN$$ $$Xreg = 4700H$$ $$Yreg = 4800H$$ $$Xreg = 4701H$$ $$Yreg = 4800H$$ $$Xreg = 4701H$$ $$Yreg = 4801H$$ $$(Contents) \Rightarrow Yreg = 4801H$$ #### 34 CIN (Compare and INcrement) of 4700H The contents of the accumulator are compared with that of the external memory (Xreg), its result is represented by flag states, then Xreg is incremented by one. of 4800H Relation between the comparison result (A with Xreg) and flags (C, H, Z, V) is the same as in (6) CPA. ## 2-4-6. Rotate and shift instructions #### 35 ROL (ROtate Left) The accumulator contents are rotated left through the flag C. • Format ROL Operation ## 36 ROR (ROtate Right) The accumulator contents are rotated right through the flag C. Format ROR Operation #### 37 SHL (SHift Left) The contents of the accumulator are shifted left. • Format SHL Operation C ← ← ← ← ← ← ← + C ← ← ← ← ← ← ← ← "0" #### 38 SHR (SHift Right) The contents of the accumulator are shifted right. #### 39 DRL (Digit Rotate Left) Left rotation takes between the accumulator and the external memory (Xreg) or #(Xreg) in unit of digit (4 bits). In other words, the low order 4 bits of the external memory are moved to the high order 4 bits of the external memory, the high order 4 bits of the external memory are moved to the high order 4 bits of the accumulator, the high order 4 bits of the accumulator are moved to the low order 4 bits of the external memory, and the low order 4 bits of the accumulator are moved to the low order 4 bits of the external memory at all times. No change takes place in flags. #### (ii) DRR (Digit Rotate Right) Right rotation takes between the accumulator and the external memory (Xreg) or #(Xreg) in unit of digit (4 bits). In other words, the low order 4 bits of the external memory are moved to the low order 4 bits of the accumulator, the low order 4 bits of the accumulator are moved to the high order 4 bits of the external memory, the high order 4 bits of the external memory are moved to the low order 4 bits of the external memory, and the high order 4 bits of the external memory are moved to the high order 4 bits of the accumulator memory at all times. No change takes place in flags. #### (4) AEX (EXchange Acc) The high order 4 bits of the accumulator are swapped with the low order 4 bits. No change takes place in flags. # 2-4-7. CPU control instructions #### SEC (SEt Carry) Sets the carry flag. No change takes place in flags. • Format • Operation SEC 1 → C #### (1) REC (REset Carry) Resets the carry flag. No change takes place in flags. • Format • Operation REC $0 \rightarrow C$ #### 4 CDV (Clear DiVider) Clears the internal divider. In other words, since the CPU clock is supplied through the divider, it makes clock reset by the CDV instruction. • Format • Operation CDV 0 → divider #### (5) ATP (Acc To Port) The contents of the accumulator are sent on the data bus. As the clock $P\Phi$ is sent out from the CPU at this moment, it may be used for the clock of the latch IC to comprise an output port. No change takes place in flags. NOTE: Though data is output with high state of OD (output disable) during memory write, OD is low state in the case of the ATP instruction. #### 6 SPU (Set PU) Sets the general purpose flipflop PU. No change takes place in flags. Format Operation SPU 1 - PU #### @ RPU (Reset PU) Resets the general purpose flipflop PU. No change takes place in flags. Format Operation RPU $0 \rightarrow PU$ ## (8 SPV (Set PV) Sets the general purpose flipflop PV. No change takes place in flags. Format Operation SPV 1 → PV #### 49 RPV (Reset PV) Resets the general purpose flipflop PV. No change takes place in flags. Format Operation RPV $0 \rightarrow PV$ #### (50 SDP (Set DisP) Sets the LCD on/off control flipflop DISP. Format Operation SDP 1 → DISP On pattern signal is generated from the CPU internal LCD backplate signal lines (H0~H7). #### (3) RDP (Reset DisP) Resets the LCD on/off control flipflop DISP. •Format •Operation RDP 0 → DISP Off pattern signal is generated from the CPU internal LCD backplate signal lines (H0~H7). #### ITA (In To Acc) The contents of the input port (INO~IN7) are transferred to the accumulator. Only the flag Z changes. • Format • Operation ITA IN0~7 → Accumulator (S) SIE (Set IE) Sets the interrupt enable flag IE. After this, it becomes ready for maskable interrupt and timer interrupt acknowledge. No change takes place in other flags. • Format • Operation SIE 1 → IE #### § RIE (Reset IE) Resets the interrupt enable flag IE. After this, maskable interrupt and timer interrupt are disabled. No change takes place in other flags. • Format • Operation RIE 0 → IE #### (5) AM0 (Acc to Tm and 0) The contents of the accumulator are transferred to the timer register (TM). Since the timer register consists of 9 bits, the accumulator contents are transferred to the low order 8 bits of the register and "0" is entered in the highest order bit. No change takes place in other flags. • Format AM0 AM0 A → TM (TM0~TM7) 0 → TM8 #### 6 AM1 (Acc to Tm and 1) Same as AM0, but "1" is entered in the highest order bit. No change takes place in other flags. • Format AM1 A → TM (TM0~TM7) 1 → TM8 #### (57) NOP (No Operation) #### ® HLT (HaLT) Stops CPU operation. (Only the divider is in operation.) Released from stop by interrupt. No change takes place in flags. #### (9) OFF BF flipflop reset instruction. No change takes place in flags. # 2-4-8. Jump instructions #### 60 JMP (JuMP) Jumps to a new program step represented by the second and third bytes of the immediate data i, j. No change takes place in flags. | <ul><li>Format</li></ul> | <ul><li>Operation</li></ul> | |--------------------------|-----------------------------| | JMP i, j | $i \rightarrow PH$ | | | $j \rightarrow PL$ | #### BCH (BranCH) Jumps to a new program step which is indicated by the program counter of which value is added/subtracted by the value of the immediate data i, j. It will be possible to jump within a range of -255 < i < 255. No change takes place in flags. #### @ BCS (Branch if C Set) Conditional relative address jump. When C=1, it jumps to a program step represented by the program counter of which value is added/subtracted with the value of the immediate data. If C=0, the control proceeds directly to a next program step without causing jump. No change takes place in flags. • Format BCS+ $$i$$ • Operation $$C = \begin{cases} 1: P + i \rightarrow P \\ 0: P \text{ not changed.} \end{cases}$$ BCS- $i$ $$C = \begin{cases} 1: P - i \rightarrow P \\ 0: P \text{ not changed.} \end{cases}$$ #### (3) BCR (Branch if C Reset) If C=0, it jumps by relative address. If C=1, it executes the next program step. No change takes place in flags. #### Format BCR+i BCR-i #### 64 BHS (Branch if H Set) If H=1, it jumps by relative address. If H=0, it executes the next program step. No change takes place in flags. #### Format BHS+i BHS-i #### 65 BHR (Branch if H Reset) If H=0, it jumps by relative address. If H=1, it executes the next program step. No change takes place in flags. #### Format BHR+i BHR-i #### 66 BZS (Branch if Z Set) If Z=1, it jumps by relative address. If Z=0, it executes the next program step. No change takes place in flags. #### Format BZS+i BZS-i #### (i) BZR (Branch if Z Reset) If Z=0, it jumps by relative address. If Z=1, it executes the next program step. No change takes place in flags. #### Format BZR+i BZR-i #### (8) BVS (Branch if V Set) If V=1, it jumps by relative address. If V=0, it executes the next program step. No change takes place in flags. #### Format $BVS \pm i$ BVS-i #### 69 BVR (Branch if V Reset) If V=0, it jumps by relative address. If V=1, it executes the next program step. No change takes place in flags. #### Format BVR+i BVR-i #### 100 LOP (LOoP) If borrow is not produced after subtracting "1" from the UL register, the program counter is subtracted by the immediate data, then it jumps to relative address for next program execution. If there is borrow, (UL<0), it proceeds to the succeeding program step. No change takes place in flags. # 2-4-9. Subroutine jump instructions #### (1) SJP (Subroutine JumP) The contents of the program counter, which show the next program executing address, are stored in the stack pointer, then the control jumps to the subroutine address represented by i and j of the 16-bit immediate data. No change takes place in flags. #### 7 VEJ (VEctor subroutine Jump) One step subroutine jump instruction that jumps to the address indicated by the twobyte vector, whose high order address byte is represented by FFH and low order address byte by the operand of the instruction. The flag Z is reset. There are 28 kinds of VEJ operand within two bytes range of 11000000 (C0H) to 11110110 (F6H). Therefore, the vector address table contains the address area of FFC0H to FFF6H. • Format VEJ i• Operation PL $\rightarrow$ (S) S $-1 \rightarrow$ S PH $\rightarrow$ (S) S $-1 \rightarrow$ S (FF00H+i) $\rightarrow$ PH (FF00H+i+1) $\rightarrow$ PL NOTE: i has 28 kinds of VEJ operands. #### (1) VMJ (Vector 2 byte Subroutine Jump) Jumps to the address indicated by the two-byte vector address, whose high order address byte is represented by FFH and low order address byte by the immediate data. The flag Z is reset. Vector address table contains FF00H thru FFF6H. Immediate value i may take even number of 00H thru F6H. • Format VMJ i• Operation PL $\rightarrow$ (S) S $-1 \rightarrow$ S PH $\rightarrow$ (S) S $-1 \rightarrow$ S (FF00H+i) $\rightarrow$ PH (FF00H+i+1) $\rightarrow$ PL #### W VCS (Vector subroutine jump if C Set) Conditional vector subroutine jump instruction. If C=1, it performs the vector subroutine jump, the same as in the VMJ instruction. If C=0, the control proceeds to the succeeding program step. #### Format VCS i #### VCR (Vector subroutine jump if C Reset) If C=0, it performs the vector subroutine jump, the same as in the VMJ instruction. If C=1, the control proceeds to the succeeding program step. #### Format VCR i #### (%) VHS (Vector subroutine jump if H Set) If H=1, it performs the vector subroutine jump, the same as in the VMJ instruction. If H=0, the control proceeds to the succeeding program step. #### Format VHS i #### VHR (Vector subroutine jump if H Reset) If H=0, it performs the vector subroutine jump, the same as in the VMJ instruction. If H=1, the control proceeds to the succeeding program step. #### Format VHR i #### VZS (Vector subroutine jump if Z Set) If Z=1, it performs the vector subroutine jump, the same as in the VMJ instruction. If Z=0, the control proceeds to the succeeding program step. #### Format VZS i #### (9) VZR (Vector subroutine jump if Z Reset) If Z=0, it performs the vector subroutine jump, the same as in the VMJ instruction. If Z=1, the control proceeds to the succeeding program step. #### Format VZR i #### 80 VVS (Vector subroutine jump if V Set) If V=1, it performs the vector subroutine jump, the same as in the VMJ instruction. If V=0, the control proceeds to the succeeding program step. #### • Format VVS i ## 2-4-10. Return instructions #### (81) RTN (ReTurN from subroutine) The instruction used to return from the subroutine to the main routine. No change takes place in flags. The previous program address is gotten from the external memory stack to be transferred to the program counter. The next instruction will be fetched from the address indicated by the program counter. | • Format | Operation | |----------|-----------------------| | RTN | $S + 1 \rightarrow S$ | | | $(S) \rightarrow PH$ | | | $S+1 \rightarrow S$ | | | (S) → PL. | #### ® RTI (ReTurn from Interrupt) The instruction used to return from the interrupt service routine to the main routine. After executing the same procedure as in the RTN instruction, then the contents of the T register at the time of interrupt are gotten from the external memory stack to be transferred to the T register. Flags are also set to their previous states. | <ul><li>Format</li></ul> | <ul><li>Operation</li></ul> | |--------------------------|-----------------------------| | RTI | $S+1 \rightarrow S$ | | | $(S) \rightarrow PH$ | | | $S + 1 \rightarrow S$ | | | $(S) \rightarrow PL$ | | | $S + 1 \rightarrow S$ | | | $(S) \rightarrow T$ | # 2-5. Command list List of LH5801 Microprocessor will be shown in pages to follow. There are following nine types of commands. # Single byte command (1) op code #### Two-byte command #### Three-byte command #### Four-byte command | 13 | 1 1 | 1 | 1 | 1 | 1 | 0 | 1 | op code | address H | address L | |----|-----|----|---|----|----|---|---|-----------|-----------|-----------| | Ī | | | | | | | | | (a) | (b) | | | | op | C | 00 | de | | | address H | address L | immediate | | | | | | | | | | | 100.000 | 100000 | #### Five-byte command | (9) | 11111101 | op code | address H | address L | immediate | |-----|----------|---------|-----------|-----------|-----------| | | No. | | (a) | (b) | (1) | ## 8-bit CPU command list (1) ## Arithmetic/logical | EMONIC | SYMBOLIC OPERATION | STATUS | RYTE | CYCLE | COMMENT | | | |------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------|-----------------------------|----------------------------------------------------------------------------|--| | LMUNC | SIMBOLIC OPERATION | CVHZIE | 76543210 | BILE | LILLE | COMMENT | | | Ri | $A+R_L+C\to A$ | 0000- | 0 0RL 0 0 1 0 | 1 | 6 | | | | RH | $\mathbf{A} + \mathbf{R}_H + \mathbf{C} \rightarrow \mathbf{A}$ | | 10Rm 0010 | 1 | 6 | • 85 84 Rt RH R | | | (R) | A+(R)+C→A | | 00R 0011 | 1 | 7 | 0 0 X: XH X | | | (a,b) | $A + (a,b) + C \rightarrow A$ | | 10100011 | 3 | 13 | O 1 YL YH Y | | | | | | | 1000 | 1868 | 1 0 Ut UH U | | | #(R) | A + #(R) + C → A | | FD | 2 | 11 | 11 * * * | | | | | | FACILIAN TOTAL OFFI | | | | | | #(a,b) | A + ≡ (a,b) + C → A | | FD | 4 | 17 | | | | | | | 10100011 | | | Address of (a,b) | | | Α. | A+(+C→A | | 10110011 | 2 | 7 | | | | **** | 10.11.4.00 | | 10110011 | | | 15 87 0 | | | (D) | (D) de (ca) D) | | 018 1111 | 2 | 12 | a b | | | 187,2 | (K) + r-(K) | | GIR TITT | - | 13 | (High order) (Low order | | | 1 . 2 | (at) Day to | | 11101111 | | 10 | | | | (a.b),t | (a,b) + 1 - (a,b) | | | 4 | 19 | ●(R)···MEO accessed | | | | | | FD | | | #(R)···ME1 accesses | | | #(R),t | #(R) + (→#(R) | | 01 R 1111 | 3 | 17 | 167 | | | | and the second | | FD | | | | | | # (a,b),1 | $\mathbb{F}(a,b) + i \rightarrow \mathbb{F}(a,b)$ | | 11101111 | 5 | 23 | | | | | | | | 1 | | | | | (1221) | AND THE PERSON NAMED IN | | Three training and the second | | 1000 | | | | #(R) | A + #(R) + C → A(BCD) | | 1000 | 2 | 19 | | | | | 2.5 | | 0.0000000000000000000000000000000000000 | | | | | | | | | Estate Control | 2 | - 11 | | | | | operation) | | 11 R 1010 | | | | | | | RH+1→RH · if C7 | | | | | | | | RL | A-RL-Č→A | 0000- | 0 0 Rt 0 0 0 0 | 1 | 6 | | | | Rec | A −R <sub>H</sub> − Č → A | | 1 ORH 0 0 0 0 | 1 | 6 | | | | (R) | $A-(R)-\overline{C}\rightarrow A$ | | 00 R 0001 | 1 | 7 | | | | (a,b) | $A = (a,b) = \overline{C} \rightarrow A$ | | 10100001 | 3 | 13 | | | | #(R) | $A - \#(R) - \overline{C} \rightarrow A$ | | 00 R 0001 | 2 | - 11 | | | | $\sharp(a,b)$ | $A - \#(a,b) - \overline{\mathbb{C}} \rightarrow A$ | | 10100001 | 4 | 17 | | | | A.i | $A - i - \overline{C} \rightarrow A$ | | 10110001 | 2 | 7 | | | | (R) | $\mathbf{A} \! = \! (\mathbf{R}) \! = \! \overrightarrow{\mathbf{C}} \! \rightarrow \! \mathbf{A}(\mathbf{BCD})$ | | 00 R 1100 | 1 | 13 | | | | 170000 | $A = \#(R) = \overline{C} \rightarrow A(BCD)$ | | 00 R 1100 | 2 | 17 | | | | #(R) | | | | | - | | | | #(R) | $A \wedge (R) \rightarrow A$ | 0- | 00 R 1001 | 1 | 7 | | | | TARREST . | $A \wedge (R) \rightarrow A$<br>$A \wedge (a,b) \rightarrow A$ | 0- | 10101001 | 3 | 13 | | | | (R) | A TEN MARKOT MARKET | 0- | 10101001<br>FD<br>00 R 1001 | 1 (4.55) | 1.00 | | | | (R)<br>(a,b) | $A \wedge (u,b) \rightarrow A$ | 0- | 10101001<br>FD | 3 | 13 | | | | (R)<br>(a,b)<br>#(R) | $A \wedge (u,b) \rightarrow A$<br>$A \wedge \#(R) \rightarrow A$ | 0- | 10101001<br>FD<br>00 R 1001<br>FD | 3 2 | 13<br>11 | | | | (R)<br>(a,b)<br>#(R)<br>#(a,b) | $A \wedge (u,b) \rightarrow A$<br>$A \wedge \# (R) \rightarrow A$<br>$A \wedge \# (u,b) \rightarrow A$ | 0- | 10101001<br>FD<br>00 R 1001<br>FD<br>10101001 | 3<br>2<br>4 | 13<br>11<br>17 | | | | (R)<br>(a,b)<br>#(R)<br>#(a,b)<br>A,i<br>(R),i | $\begin{array}{l} A \wedge (u,b) \to A \\ \\ A \wedge \# (R) \to A \\ \\ A \wedge \# (u,b) \to A \\ \\ \\ A \wedge i \to A \end{array}$ | 0- | 10101001<br>FD<br>00 R 1001<br>FD<br>10101001<br>10111001 | 3<br>2<br>4<br>2 | 13<br>11<br>17<br>7<br>13 | | | | (R) (a,b) #(R) #(a,b) A,i | $A \wedge (u,b) \rightarrow A$<br>$A \wedge \# (R) \rightarrow A$<br>$A \wedge \# (u,b) \rightarrow A$<br>$A \wedge i \rightarrow A$<br>$(R) \wedge i \rightarrow (R)$ | 0- | 10101001<br>FD<br>00 R 1001<br>FD<br>10101001 | 3<br>2<br>4<br>2<br>2 | 13<br>11<br>17<br>7 | | | | | (R) (a,b) #(R) #(a,b) A,i (B),i #(R),i #(R),i (R) #(R) #(R) | Rt $A+Rt+C\rightarrow A$<br>RH $A+Rt+C\rightarrow A$<br>(R) $A+(R)+C\rightarrow A$<br>(a,b) $A+(a,b)+C\rightarrow A$<br>#(R) $A+\#(R)+C\rightarrow A$<br>#(a,b) $A+\#(a,b)+C\rightarrow A$<br>A,i $A+i+C\rightarrow A$<br>(R),i $(a,b)+i\rightarrow \#(a,b)$<br>#(R),i $\#(R)+i\rightarrow \#(R)$<br>#(a,b),i $\#(a,b)+i\rightarrow \#(a,b)$<br>#(R) $A+(R)+C\rightarrow A(BCD)$<br>#(R) $A+\#(R)+C\rightarrow A(BCD)$<br>#(R) $A+\#(R)+C\rightarrow A(BCD)$<br>#(R) $A+\#(R)+C\rightarrow A(BCD)$<br>#(R) $A+\#(R)+C\rightarrow A(BCD)$<br>Rt A(BCD)$<br>#(R) $A+\#(R)+C\rightarrow A(BCD)$<br>Rt $A+\#(R)+C\rightarrow A(BCD)$<br>Rt $A+\#(R)+C\rightarrow A(BCD)$<br>Rt $A+\#(R)+C\rightarrow A(BCD)$<br>Rt $A+\#(R)+C\rightarrow A(BCD)$<br>Rt $A+\#(R)+C\rightarrow A(BCD)$<br>Rt $A-Rt-C\rightarrow A$<br>Rt A$ | EMONIC SYMBOLIC OPERATION $C Y H Z IE$ Ri | EMONIC SYMBOLIC OPERATION C Y H ZIE 7 6 5 4 3 2 1 0 | EMONIC SYMBOLIC OPERATION | EMONIC SYMBOLIC OPERATION C Y H Z E 7 6 5 4 3 2 1 0 BYTE CICLE | | ## 8-bit CPU command list (2) | | EMONIC | SYMBOLIC OPERATION | STATUS | MACHINE LANGUA | GE BYTE | CYCLE | COMMENT | |-----|------------------|------------------------------------------------|--------|----------------|---------|-------|---------| | MI | EMONIC | SIMBOLIC OF ERATION | CVHZIE | 76543210 | BILE | CHOLE | | | ORA | (R) | $A \lor (R) \rightarrow A$ | 0- | 00 R 1011 | 1 | 7 | | | | (a,b) | $A \lor (a,b) \to A$ | | 10101011 | 3 | 13 | | | | #(R) | $A \lor \sharp (R) \rightarrow A$ | | 00 R 1011 | 2 | 11 | | | | # (a,b) | $A \lor \sharp (a,b) \rightarrow A$ | | 10101011 | 4 | 17 | | | ORI | A,i | $A \lor i \rightarrow A$ | | 10111011 | 2 | 7 | | | | (R), i | $(R) \lor i \rightarrow (R)$ | | 01 R 1011 | 2 | 13 | | | | (a,b),i | $(a,b) \lor i \rightarrow (a,b)$ | | 11101011 | 4 | 19 | | | | #(R),i | $\sharp(R) \lor i \rightarrow \sharp(R)$ | | 01 R 1011 | 3 | 17 | | | | $\sharp (a,b),i$ | $\sharp (a,b) \lor i \rightarrow \sharp (a,b)$ | | 11101011 | 5 | 23 | | | EOR | (R) | $A \oplus (R) \rightarrow A$ | 0- | 00 R 1101 | 1 | 7 | | | | (a,b) | $A \oplus (a,b) \rightarrow A$ | | 10101101 | 3 | 13 | | | | #(R) | A ⊕ #(R) → A | | 00 R 1101 | 2 | 11 | | | | # ( a,b) | $A \oplus \sharp (a,b) \rightarrow A$ | | 10101101 | 4 | 17 | | | EAI | i | $A \oplus i \rightarrow A$ | | 10111101 | 2 | 7 | | | INC | Α | A+1→A | 0000- | 11011101 | 1 | 5 | | | | RL | R <sub>L</sub> + I → R <sub>L</sub> | | 01 RL 0 0 0 0 | 1. | 5 | | | | Rн | R <sub>H</sub> +1→R <sub>H</sub> | | 0 1 RH 0 0 0 0 | 2 | 9 | | | | R | R+1→R | - | 01 R 0100 | 1 | 5 | | | DEC | Α | A-1→A | 0000- | 11011111 | 1 | 5 | | | | RL | R <sub>L</sub> − 1 → R <sub>L</sub> | | 01 Rt 0010 | 1 | 5 | | | | Rн | R <sub>H</sub> -1→R <sub>H</sub> | | 0 1 RH 0 0 1 0 | 2 | 9 | | | | R | R-1→R | | 01 R 0110 | 1 | 5 | | ## Compare and bit test | CPA | RL | A-R <sub>L</sub> | 0000- | 00 Rt 0110 | 1 | 6 | |-----|------------------|---------------------------------------|-------|----------------|----|----| | | RH | A-RH | | 10 RH 0 1 1 0 | 1 | 6 | | | (R) | A-(R) | | 00 R 0111 | 1 | 7 | | | (a,b) | A -( a,b) | | 10100111 | 3 | 13 | | | #(R) | A-#(R) | | 00 R 0111 | 2 | 11 | | | $\sharp (a,b)$ | A — # ( a,b) | | 10100111 | 4 | 17 | | CPI | RL,i | $R_L = i$ | | 01 Rt 1110 | 2 | 7 | | | RH,i | R <sub>H</sub> -i | | 0 1 RH 1 1 0 0 | 2 | 7 | | | A,i | A-i | | 10110111 | 2 | 7 | | BIT | (R) | $A \wedge (R) \rightarrow Z$ | 0- | 00 R 1111 | 1. | 7 | | | (a,b) | $A \wedge (a,b) \rightarrow Z$ | | 10101111 | 3 | 13 | | | # (R) | $A \wedge \#(R) \rightarrow Z$ | | 00 R 1111 | 2 | 11 | | | $\sharp (a,b)$ | $A \wedge \sharp (a,b) \rightarrow Z$ | | 10101111 | 4 | 17 | | BII | A,i | A∧i→Z | | 10111111 | 2 | 7 | | | (R), i | $(R) \land i \rightarrow Z$ | | 01 R 1101 | 2 | 10 | | | (a,b),i | $(a,b) \land i \rightarrow Z$ | | 11101101 | 4 | 16 | | | $\sharp(R),i$ | $\sharp(R) \wedge i \rightarrow Z$ | | 01 R 1101 | 3 | 14 | | | $\sharp (a,b),i$ | $\sharp (a,b) \land i \rightarrow Z$ | | 11101101 | 5 | 20 | ## 8-bit CPU command list (3) #### Load and store | 345 | EMONIC | SYMBOLIC ODERATION | STATUS MACHINE LANGUAGE | | | CYTIC | COMMENT | |-----|--------------------|----------------------------------------------------|-------------------------|-----------------|------|-------|---------| | mil | EMONIC | SYMBOLIC OPERATION | CVHZIE | 76543210 | BYTE | CYTLE | COMMENT | | LDA | RL | R∟→A | 0- | 00 Rt 0100 | 1 | 5 | | | | R <sub>H</sub> | R <sub>H</sub> →A | | 1 0 RH 0 1 0 0 | 1 | 5 | | | | (R) | (R)→A | | 00 R 0101 | 1 | 6 | | | | (a,b) | $(a,b) \rightarrow A$ | | 10100101 | 3 | 12 | | | | #(R) | #(R) →A | | 00 R 0101 | 2 | 10 | | | | $\sharp(a,b)$ | $\sharp(a,b) \rightarrow A$ | | 10100101 | 4 | 16 | | | DE | R | $(R) \rightarrow A, R-1 \rightarrow R$ | | 01 R 0111 | 1 | 6 | | | .IN | R | (R)→A,R+1→R | | 01 R 0101 | 1 | 6 | | | DI | $R_{L,\bar{\ell}}$ | i→Rt. | W | 01 Rt 1010 | 2 | 6 | | | | $R_{H_i}i$ | i→Rn | | 0 1 RH 1 0 0 0 | 2 | 6 | | | | A,i | i→A | 0- | 10110101 | 2 | 6 | | | | S, <i>i,j</i> | ij→S | | 10101010 | 3 | 12 | | | LDX | R | R → X | | 00 R 1000 | 2 | 11 | | | | s | s→x | CAT | 01001000 | 2 | 11 | | | | Р | P→X | | 01011000 | 2 | - 11 | | | STA | RL | A→R <sub>L</sub> | | 00 Rt 1010 | 1_ | 5 | | | | RH | A→RH | | 0 0 RH 1 0 0 0 | 1 | 5 | * * | | | (R) | A→(R) | | 00 R 1110 | 1 | 6 | | | | (a,b) | $A \rightarrow (a,b)$ | | 10101110 | 3 | 12 | | | | #(R) | $A\to \sharp(R)$ | | 00 R 1110 | 2 | 10 | ¥ | | | $\sharp (a,b)$ | $A \to \sharp \ (\ a,b)$ | | 10101110 | 4 | 16 | | | SDE | R | $A \rightarrow (R), R-1 \rightarrow R$ | | 01 R 0011 | 1 | 6 | | | SIN | R | $A \rightarrow (R), R+1 \rightarrow R$ | | 01 R 0001 | 1 | 6 | | | XT | R | X →R | | 01 R 1010 | 2 | 11 | | | | s | x→s | | 01001110 | 2 | 11 | | | | Ρ | X→P | | 01011110 | 2 | 11 | | | SH | Α | $A \rightarrow (S), S-1 \rightarrow S$ | | 1 1 0 0 1 0 0 0 | 2 | 11 | | | | R | $R_L \rightarrow (S)_*RH \rightarrow (S-1)_*$ | | 10 R 1000 | 2 | 14 | | | | | S-2→S | | | | | | | POP | Α | $(S+1) \rightarrow A, S+1 \rightarrow S$ | 0- | 10001010 | 2 | 12 | | | | R | $(S+1) \rightarrow RH_{*}(S+2) \rightarrow RL_{*}$ | | 00 R 1010 | 2 | 15 | | | | | S+2→S | | 50 | | | | | ATT | | A→T(STATUS) | 00000 | 11101100 | 2 | 9 | | | TTA | | T(STATUS) →A | 0- | 10101010 | 2 | 9 | | #### Block transfer and search | TIN | $(x) \rightarrow (y), \begin{array}{c} X+1 \rightarrow X \\ Y+1 \rightarrow Y \end{array}$ | | 11110101 | 1 | 7 | | |-----|--------------------------------------------------------------------------------------------|-------|----------|---|---|--| | CIN | $A \rightarrow (X), X + 1 \rightarrow X$ | 0000- | 11110111 | 1 | 7 | | ## 8-bit CPU command list (4) #### Rotate and shift | MNEMONIC | SYMBOLIC OPERATION | STATUS | MACHINE LANGUAGE | BYTE | ONO! E | COMMENT | |----------|--------------------|--------|------------------|------|--------|---------| | MNEMONIC | SIMBOUG OPERATION | CVHZIE | 76543210 | BILE | CYCLE | COMMENT | | ROL | C ← 7 ← 0 ← | 0000- | 11011011 | 1 | 8 | | | ROR | C → 7 → 0 | | 11010001 | 1 | 9 | | | SHL | C ← 7 ← 0 ← 0 | | 11011001 | 1 | 6 | | | SHR | 0 → 7 → 0 → C | | 11010101 | 1 | 9 | | | DRL | A L (x) | | 11010111 | 1 | 12 | | | DRL # | ME1 Area | | 1 1 0 1 0 1 1 1 | 2 | 16 | | | DRR | A 1 (x) | | 11010011 | 1 | 12 | | | DRR ♯ | ME1 Area | | 1 1 0 1 0 0 1 1 | 2 | 16 | | | AEX | | | 11110001 | 1 | 6 | | #### **CPU** control | AM0 | A→TIMER(T0~T7),0→T8 | | 11001110 | 2 | 9 | | |------|---------------------------------|----|---------------------------------------|---|-----|----| | AM1 | * 1 →T8 | | 11011110 | 2 | 9 | 3: | | CDV | divider clear | | 10001110 | 2 | 8 | | | ATP | A→Output port<br>(Clock output) | | 11001100 | 2 | 9 | | | SDP | 1 →Disp | | 11000001 | 2 | 8 | | | RDP | 0→Disp | | 1 1 0 0 0 0 0 0 | 2 | 8 | | | SPU | 1.→PU | | 11100001 | 1 | 4 | | | RPU | 0→PU | | 11100011 | 1 | 4 | | | SPV | 1 →PV | | 10101000 | 1 | 4 - | | | RPV | 0-PV | | 10111000 | 1 | 4 | | | ITA | IN→A | 0- | FD<br>10111010 | 2 | 9 | | | RIE | O→IE | 0 | FD<br>10111110 | 2 | 8 | | | SIE | 1 →1È | 0 | 10000001 | 2 | 8 | | | HLT | | | FD<br>10110001 | 2 | 9 | | | OFF | | | 60<br>01001100 | 2 | 8 | | | NOP | | | 17 (0.00) 7 (0.00) 4 (0.00) 10 (0.00) | 1 | 5 | | | NOP: | | | 00111000 | 1 | 5 | | | SEC | 1 → C | 0 | 11111011 | 1 | 4 | | | REC | 0 → C | 0 | 11111001 | 1 | 4 | | ## 8-bit CPU command list (5) #### Jump | MACHONIC | CVMPOLIC OPERATION | STATUS | MACHINE LANGUAGE | OVER | CVCLE | COMMENT | | |----------|------------------------------------|--------|------------------|------|---------|---------------------------------------|--| | MNEMONIC | SYMBOLIC OPERATION | CVHZIE | 76543210 | BYTE | CYCLE | COMMENT | | | JMP | ij→P | | 10111010 | 3 | 12 | | | | | | | | | | s=0:+i | | | всн | $s=0$ : $P+i\rightarrow P$ | | 10081110 | 2 | 8 | s=1:-i | | | | $s=1: P-i\rightarrow P$ | | | | 9 | (Includes one more | | | BCS | if $C=1$ , $P\pm i\rightarrow P$ | | 10080011 | 2 | 8/10/11 | cycle) | | | | if C=0, continue | | | | | | | | BCR | $if C = 0, P \pm i \rightarrow P$ | | 100 8 0 0 0 1 | 2 | 8/10/11 | 83 92 81 Condition | | | | if C=1, continue | - 80 | | | | 0 0 0 NC: non carry<br>0 0 1 C: carry | | | BVS | if $V=1$ , $P\pm i\rightarrow P$ | | 100s1111 | 2 | 8/10/11 | 0 1 0 NH: non harf | | | | if V=0, continue | | | + | | 0 1 1 H: half<br>1 0 0 NZ: non zero | | | BVR | if $V=0$ , $P\pm i\rightarrow P$ | | 100 s 1 1 0 1 | 2 | 8/10/11 | 1 0 1 NV: zero | | | | if V=1, continue | | | | | 1 1 0 NV: non overflow | | | BHS | if H=1, P±i→P | | 10080111 | 2 | 8/10/11 | 1 1 1 V: overflow | | | | if H=0, continue | | | | | | | | BHR | if H=0, $P \pm i \rightarrow P$ | CAT | 100 8 0 1 0 1 | 2 | 8/10/11 | | | | | if H=1, continue | | | | | | | | BZS | $if Z = 1, P \pm i \rightarrow P$ | | 10081011 | 2 | 8/10/11 | | | | | if Z=0, continue | | | | | 74 | | | BZR | if $Z=0$ , $P\pm i\rightarrow P$ | | 100 8 1 0 0 1 | 2 | 8/10/11 | | | | | if Z=1, continue | | | | | | | | LOP UL,i | UL-1→UL | | 10001000 | 2 | 8/11 | | | | | $if Borrow = 0, P-i \rightarrow P$ | | | | | | | | | if Borrow=1,continue | ž. | | | | | | #### Cal | SJP | $P_L \rightarrow (S), P_H \rightarrow (S-1),$ | | 10111110 | 3 | 19 | • Vector address (q) | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------|----|-----------------|---|------|---------------------------------| | AE1 | $S-2\rightarrow S$ , $ij\rightarrow P$<br>$P_L\rightarrow (S),PH\rightarrow (S-1)$<br>$S-2\rightarrow S,(q)\rightarrow P_H,(q+1)\rightarrow P_L$ | 0- | 1 1 ← i → 0 | 1 | 17 | VEJ: FF→qH<br>1170→qL | | vcs | $if C = 1,(q) \rightarrow P_H \rightarrow (S-1)$ $(q+1) \rightarrow P_L \rightarrow (S), S-2 \rightarrow S$ | | 11000011 | 2 | 8/21 | VM J: FF → qH<br>etc.<br>i → qL | | VCR | if C=0, | | 11000001 | 2 | 8/21 | | | VHS | if H=1, → | | 11000111 | 2 | 8/21 | Ψ. | | VHR | if H=0, | | 11000101 | 2 | 8/21 | | | vzs . | if Z=1, → | | 11001011 | 2 | 8/21 | | | vzr . | if Z=0, | | 1 7 0 0 1 0 0 1 | 2 | 8/21 | | | vvs | <i>if</i> <b>V</b> =1, | | 11001111 | 2 | 8/21 | | | VMJ | $(q) \rightarrow P_H \rightarrow (S-1), S-2 \rightarrow S$<br>$(q+1) \rightarrow P_L \rightarrow (S)$ | S | 11001101 | 2 | 20 | | #### Return | RTN | $(S+1) \rightarrow PH_{*}(S+2) \rightarrow PL_{*}$ | | 10011010 | 1 | 11 | | |-----|----------------------------------------------------|-------|----------|---|----|--| | | S+2→S | | | | | | | RTI | $(S+1) \rightarrow PH, (S+2) \rightarrow PL$ | 00000 | 10001010 | 1 | 14 | | | | (S+3)→T,S+3→S | | | | | | NOTE: P in above list indicates a succeeding byte. For a command accompanying the immediate value, it indicates the byte that follows to the immediate value. #### LH5801 | MNE | MONIC | MACHINE LANGUAGE | MNE | MONIC | MACHINE LANGUAGE | MNE | MONIC | MACHINE LANGUAGE | |-----|-------|------------------|-----|--------|------------------|-----|-------|------------------| | ADC | XL | 02 | ANI | (ab) | E9 a b i | BVR | - | 9D i | | | YL | 12 | | #(X) | FD 49 i | BZS | + | 8B i | | | UL | 22 | | #(Y) | FD 59 i | | т. | 9B i | | | хн | 82 | | #(U) | FD 69 i | BZR | + | 89 i | | | YH | 92 | | #( ab) | FD E9 a b i | | - | 99 i | | | UH | A2 | AM0 | | FD CE | CDV | | FD 8E | | | (X) | 03 | AM1 | | FD DE | CIN | | F7 | | | (Y) | 13 | ATP | | FD CC | CPA | XL | 06 | | | (U) | 23 | ATT | | FD EC | | YL | 16 | | | (ab) | A3 a b | всн | + | 8E i | | UL | 26 | | | #(X) | FD 03 | | | 9E i | | ХН | 86 | | | #(Y) | FD 13 | BCS | + | 83 <i>i</i> | | YH | 96 | | | #(U) | FD 23 | | - | 93 i | | UH | A6 | | | #(ab) | FD A3 a b | BCR | + | 81 i | | (X) | 07 | | ADI | Α | B3 i | | - | 91 i | | (Y) | 17 | | | (X) | 4F i | BHS | + | 87 i | | (U) | 27 | | | (Y) | 5F <i>i</i> | | - | 97 i | | ( ab) | A7 a b | | | (U) | 6F i | BHR | + | 85 i | | #(X) | FD 07 | | | (ab) | EF a b i | | - | 95 i | | #(Y) | FD 17 | | | #(X) | FD 4F i | BII | Α | BF i | | #(U) | FD 27 | | | #(Y) | FD 5F i | | (X) | 4D i | | #(ab) | FD A7 a b | | | #(U) | FD 6F i | | (Y) | 5D i | CPI | А | B7 i | | | #(ab) | FD EF a b i | | (U) | 6D i | | XL | 4E i | | ADR | х | FD CA | | (ab) | ED a b i | | YL | 5E i | | | Y | FD DA | | #(X) | FD 4D i | | UL | 6E i | | | U | FD EA | | #(Y) | FD 5D i | | ХН | 4C i | | AEX | | F1 | | #(U) | FD 6D i | | YH | 5C i | | AND | (X) | 09 | | #( ab) | FD ED a b i | | UH | 6C i | | | (Y) | 19 | BIT | (X) | OF | DCA | (X) | 8C | | | (U) | 29 | | (Y) | 1F | | (Y) | 9C | | | (ab) | A9 a b | | (U) | 2F | | (U) | AC | | | #(X) | FD 09 | | (ab) | AF a b | | #(X) | FD 8C | | | #(Y) | FD 19 | | #(X) | FD QF | | #(Y) | FD 9C | | | #(U) | FD 29 | | #(Y) | FD 1F | | #(U) | FD AC | | | #(ab) | FD A9 a b | | #(U) | FD 2F | DCS | (X) | 0C | | ANI | A | B9 i | | #( ab) | FD AF a b | | (Y) | 1C | | | (X) | 49 i | BVS | + | 8F i | | (U) | 2C | | | (Y) | 59 i | | - | 9F i | | #(X) | FD OC | | | (U) | 69 i | BVR | + | 8D i | | #(Y) | FD 1C | | MNE | MONIC | MACHINE LANGUAGE | MNE | MONIC | MACHINE LANGUAGE | MNE | MONIC | MACHINE LANGUAGE | |------|-------|------------------|-----|-------|------------------|-----|-------|------------------| | DCS | #(U) | FD 2C | LDA | UL | 24 | ORA | #(Y) | FD 1B | | DEC | A | DF | | хн | 84 | | #(U) | FD 2B | | | XL | 42 | | YH | 94 | | #(ab) | FD AB a b | | | YL | 52 | | UH | A4 | ORI | Α | BB <i>i</i> | | | UL | 62 | | (X) | 05 | | (X) | 4B <i>i</i> | | | хн | FD 42 | | (Y) | 15 | | (Y) | 5B <i>i</i> | | | YH | FD 52 | | (U) | 25 | | (U) | 6B i | | | UH | FD 62 | | ( ab) | A5 a b | | ( ab) | EB a b i | | | х | 46 | | #(X) | FD 05 | | #(X) | FD 4B | | | Y | 56 | | #(Y) | FD 15 | | #(Y) | FD 5B | | | U | 66 | | #(U) | FD 25 | | #(U) | FD 6B | | DRL | (X) | D7 | | #(ab) | FD A5 a b | | #(ab) | FD EB a b i | | | #(X) | FD D7 | LDI | A | B5 i | POP | Α | FD 8A | | DIRR | (X) | D3 | | XL | 4A i | | x | FD 0A | | | #(X) | FD D3 | | YL | 5A <i>i</i> | | Y | FD 1A | | E AI | | BD i | | UL | 6A i | | U | FD 2A | | EOR | (X) | 0D | | хн | 48 i | PSH | A | FD C8 | | | (Y) | 1D | | YH | 58 i | | x | FD 88 | | | (U) | 2D | | UH | 68 i | | Y | FD 98 | | | (ab) | AD a b | | S | AA_i j | | U | FD A8 | | | #(X) | FD 0D | LDE | X | 47 | RDP | | FD CO | | | #(Y) | FD 1D | | Υ | 57 | REC | | F9 | | | #(U) | FD 2D | | U | 67 | RIE | | FD BE | | | #(ab) | FD AD a b | LDX | X | FD 08 | ROL | | DB | | HLT | | FD B1 | | Y | FD 18 | ROR | | D1 | | INC | Ą | DD | | U | FD 28 | RPU | | E3 | | | XL | 40 | | S | FD 48 | RPV | | B8 | | | YL | 50 | | Р | FD 58 | RTI | | 8A | | | UL | 60 | LIN | x | 45 | RTN | | 9A | | | хн | FD 40 | | Y | 55 | SBC | XL | 00 | | | YH | FD 50 | | U | 65 | | YL | 10 | | | UH | FD 60 | LOP | UL : | 88 i | | UL | 20 | | | Х | 44 | NOP | | 38 | | хн | 80 | | | Y | 54 | OFF | | FD 4C | | YH - | 90 | | | U | 64 | ORA | (X) | ОВ | | UH | AO | | ITA | | FD BA | | (Y) | 1B + | | (X) | 01 | | JMP | | BA i j | | (U) | 2B | 1 | (Y) | 11 | | LDA | XL | 04 | | ( ab) | AB a b | | (U) | 21 | | | YL | 14 | | #(X) | FD 0B | 1 | (ab) | A1 a b | | MNE | MONIC | MACHINE LANGUAGE | MNE | MONIC | MACHINE LANGUAGE | MNEMONIC | MACHINE LANGUAG | |-----|---------|------------------|-----|-------|------------------|----------|-----------------| | SBC | #(X) | FD 01 | TTA | | FD AA | | | | | #(Y) | FD 11 | vcs | | C3 i | | | | | #(U) | FD 21 | VCR | | C1 i | | | | | # ( ab) | FD A1 a b | VEJ | со | CO | | | | SBI | | B1 i | | C2 | C2 | | | | SDE | Х | 43 | | C4 | C4 | | | | | Υ | 53 | | C6 | C6 | | | | | U | 63 | | C8 | C8 | | | | SDP | | FD C1 | | CA | CA | | | | SEC | | FB | | cc | cc | | 2 | | SHL | | D9 | | CE | CE | | | | SHR | | D5 | 1 | DO | D0 | | | | SIE | | FD 81 | 1 | D2 | D2 | | | | SIN | х | 41 | 1 | D4 | D4 | | | | | Y | 51 | | D6 | D6 | | | | | U | 61 | | D8 | D8 | | | | SJP | | BE ij | | DA | DA | | | | SPU | | E1 | | DC | DC | | | | SPV | | A8 | | DE | DE | | | | STA | XL | 0A | | EO | EO | | | | | YL | 1A | | E2 | E2 | | | | | UL | 2A | | E4 | E4 | | | | | XH | 08 | | E6 | E6 | | | | | YH | 18 | | E8 | E8 | | | | | UH | 28 | | EA | EA | | | | | (X) | 0E | | EC | EC | | | | | (Y) | 1E | | EE | EE | | | | | (U) | 2E | | FO | FO | | | | | (ab) | AE a b | | F2 | F2 | | | | | #(X) | FD OE | | F4 | F4 | | | | | #(Y) | FD 1E | | F6 | F6 | | | | | #(U) | FD 2E | VMJ | | CD i | | | | | #(ab) | FD AE a o | vvs | | CF i | | | | STX | х | FD 4A | vzs | | CB i | | | | | Υ | FD 5A | VZR | | C9 i | | | | | U | FD 6A | VHR | | C5 i | | | | | S | FD 4E | VHS | | C7 i | | | | | Р | FD 5E | | | | | | | TIN | | F5 | | | | | | # 2-6. Electrical characteristics and timings #### Absolute maximum ratings | Parameter | Symbol | Limits | Unit | |-----------------------|-----------------|-------------|------| | Supply voltage | Vcc | -0.3 to +7 | v | | Input voltage | V <sub>IN</sub> | -0.3 to +7 | ٧ | | Output voltage | Vour | -0.3 to +7 | V | | Operating temperature | Topr | 0 to +40 | °C | | Storage temperature | Tstg | -55 to +150 | °C | #### **Electrical characteristics** #### DC characteristics (Ta=0 to 40°C, Vcc=Vgg=4.5V ±0.5V) | Parameter | Symbol | Min. | Тур. | Max. | Unit | Test conditions | Applicable pins | |------------------------------------------|-----------------|---------|------|------|------|------------------------------------------------|-----------------------------------------------| | Supply<br>current<br>during<br>operation | lcc | | 7 | 15 | mA | 3.80MHz<br>crystal in<br>connection | * | | Supply<br>current<br>during halt | ber | | 4 | | mA | 0 | | | Input voltage | V <sub>H</sub> | Vcc-1.0 | | | ٧ | | D0~7, BFI, RESET, HIN, | | | V <sub>IL</sub> | | | 0.4 | ٧ | | WAIT, NMI, MI, IN0~7 | | Output | Vон | 2.4 | | | ν | I <sub>OH</sub> = 400 <i>μ</i> A | AD0~15, OPF, BFO, R/W | | voltage | Voc | | | 0.4 | ٧ | loc=1.6mA | OD, ME0~1, PΦ, PU, PV,<br>ΦOS, HA, DISP, D0~7 | | Input current | [6] | | | 1.0 | μΑ | V <sub>IH</sub> =V <sub>CC</sub> | Input pins other than<br>RESET, BFI | | | | | | 5.0 | μΑ | | RESET, BFI | | | | | | 1.0 | μΑ | V <sub>E</sub> =0 | Input pins other than IN0~7, RESET, BFI | | | | | 30 | 60 | μΑ | | IN0~7 | | Power switch | Rva | | | 300 | Ω | | VA | | ON resistance | Rva | | | 300 | Ω | | VB | | LCD drive ON | Rн | | | 3.5 | kΩ | Hi~Vcc | H0~7 | | resistance | Rw | | | 3.5 | kΩ | Hi~Vм | | | | RL | | | 5.0 | kΩ | Hi~Vois | | | Supply<br>current<br>during<br>standby | İst | | | 5 | μΑ | V <sub>cc</sub> = 0V<br>V <sub>oc</sub> = 5.5V | | | 3-state output<br>leakage<br>current | llol | | | 1.0 | μΑ | | ADO~15, DO~7, R/W,<br>MEO~1, OD | # AC characteristics | Parameter | Symbol | Min. | Max. | Unit | Test conditions | |-----------|--------------------------|-------------------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ΦOS | Tc<br>tr<br>tf<br>twn | 220 | 150<br>40 | nS | $\begin{aligned} & C_L: 20pF \\ & tr: (V_{cc} \times 0.1) V \rightarrow (V_{cc} \times 0.9) V \\ & tf: (V_{cc} \times 0.9) V \rightarrow (V_{cc} \times 0.1) V \end{aligned}$ | | AD0~15 | to<br>tr | 80 | 250 | nS | C <sub>L</sub> : 20pF<br>V <sub>OH</sub> : (V <sub>CC</sub> ×0.5)V<br>V <sub>OL</sub> : 0.4V | | ME0,1 | to<br>tr | 80 | 260<br>175 | nS | C <sub>L</sub> : 20pF<br>V <sub>OH</sub> : (V <sub>CC</sub> × 0.5)V<br>V <sub>OL</sub> : 0.4V | | OD | tox<br>tri<br>ton<br>ton | 170 | 250<br>370 | nS | C <sub>L</sub> : 20pF<br>V <sub>OH</sub> : (V <sub>CC</sub> ×0.8)V<br>V <sub>OL</sub> : 0.4V | | R/W | to<br>tr | -30 | 50<br>200 | nS | Ct: 20pF<br>Von: (Vcc×0.8)V<br>Vot: 0.4V | | D0~7 | to<br>tr<br>ts | 220<br>170<br>100 | 600 | nS | C <sub>L</sub> : 20pF<br>Vox: (Vcc×0.8)V<br>Vox: 0.4V | | РФ | to<br>tr | | 350<br>100 | nS | C <sub>L</sub> : 20pF<br>V <sub>OH</sub> : (V <sub>CC</sub> ×0.8)V<br>V <sub>OL</sub> : 0.4V | | INO~7 | ts<br>tu | 190<br>30 | | nS | C <sub>L</sub> : 20pF<br>V <sub>H</sub> : (V <sub>CC</sub> - 1.0)V<br>V <sub>L</sub> : 0.4V | | WAIT | ts<br>tu | 130<br>20 | | nS | C <sub>L</sub> : 20pF<br>V <sub>H</sub> : (V <sub>CC</sub> -1.0)V<br>V <sub>L</sub> : 0.4V | | PU, PV | to<br>tr | 50 | 340 | nS | C <sub>L</sub> : 20pF<br>V <sub>OH</sub> : (V <sub>CC</sub> ×0.8)V<br>V <sub>OL</sub> : 0.4V | | OPF | to<br>tr | | 310<br>190 | nS | C <sub>L</sub> : 20pF<br>V <sub>OH</sub> : (V <sub>CC</sub> ×0.8)V<br>V <sub>H</sub> : 0.4V | | RESET | tw | 2 | | mS | C <sub>L</sub> : 20pF | | BFI | tw | 250 | | nS | C <sub>L</sub> : 20pF | | BFO | to<br>te | | 150<br>360 | nS | C <sub>L</sub> : 20pF<br>V <sub>OH</sub> : (V <sub>CC</sub> ×0.8)V<br>V <sub>OL</sub> : 0.4V | Timing (1) Timing (2) 3 LH5810/LH5811 I/O PORT CONTROLLER ### 3-1. Outline The LH5810/LH5811 is a single chip CMOS static LS1 that features the following functions: - (1) two pairs of 8-bit bidirectional port - (2) one pair of 8-bit output port - (3) two interrupt request inputs (one of them port input) - (4) one interrupt request output - (5) CPU wait control - (6) serial data transfer control ### 3-2. Functions - ① Ports PA0~7 and PB0~7 can be programmed of their data flow direction in bit unit. Also, it can be accessed as one location of the memory, as seen from the CPU. - ② Latch clock PΦ can be directly given from the external source through output ports PC0~7. Also, it can be accessed as one location of the memory, as seen from the CPU. - 3 As there are two interrupt request inputs of IRQ and PB7, interrupt request can be issued to the CPU at the rising edge of the input when the corresponding bit of the MSK register is "1". PB7 must be in the input mode before using PB7 for the interrupt input. - Since there is the CPU wait control circuit, two memory enable signals can be output to the memory of slow access time. Besides, it has two inputs of wait conditions. Up to 8 varieties of access time can be programmed. - (5) It has the following functions to handle serial data transfer. #### A. Serial data transmit Serial data transfer takes place in a format of a start bit, 8 bits of data, and two stop bits. Transmission clock is selectable by means of internal and external clock select program, as well as the clock rate (1/1, 1/2, 1/128, 1/256, 1/512, 1/1024, 1/2048, and 1/4096 of the basic clock). #### B. Serial data receive When the start bit is received in an idle state, the serial data following to it is received. After receiving the data comprised of 8 bits, it is then stored in the internal register and the interrupt request flag is set active. Receive clock is furnished from the external source which becomes the receiving clock by itself. It must be in synchronization with the serial data input. #### C. Pulse waveform It is possible to have continuous output of pulse waveform. Frequency is programmable to eight kinds of 1/1, 1/2, 1/128, 1/256, 1/512, 1/1024, 1/2048, and 1/4096 of the basic clock. #### D. Data transfer to the audio cassette tape Format of data transferred to the audio cassette tape consists of a start bit, 8 bits of data, and two stop bits, with the modulation signal generated from the SDO output. Assume now that normal serial data output is to be SXO, the modulation clock to the data 1 to be FX, the modulation clock to the data 0 to be FY, and audio cassette tape data output to be SDO, then the following equation comprises: $$SDO = SXO \cdot FX + \overline{SXO} \cdot FY$$ Whereas, FX and FY can be set independently to 1/64, 1/128, 1/256, 1/512 or 1/1024 of the basic clock by means of programming. The serial transmit clock CLO can be programmed as discussed in Item A. ### 3-3. Internal structure ## 3-3-1. Block diagram The I/O port controller consists of nine internal registers, wait controller, serial controller, and interrupt controller, and each of internal registers can be accessed as one location of the memory as seen from the CPU. #### I/O port controller system block diagram ### 3-3-2. Internal registers #### ① G register (RS3~0=1001) The G register can read/write data when register is selected (1001). #### MSK register The MSK register can read/write data when register is selected (1010). NOTE: When the contents of the MSK register are read, the contents of CL1, SD1, PB7, and IRQ are stored in high order digit positions. Contents of MSK read #### ③ IF register IF0 and IF1 can read/write data when register is selected (1011). RD and TD are dedicated to read only. NOTE: During receive of serial data, RD is reset. Term "serial data receive" means the period during which an 8-bit data is in reception, with the start bit excluded. #### ODA register The register used to determine the direction of the port PA. #### i-th bit of the DDA register | When 0 | PAi is in the input mode. | |--------|-------------------------------------------------------------| | When 1 | PAi is in the output mode and outputs the contents of OPAi. | DDA can read/write when the register is selected (1100). #### ⑤ DDB register The register used to determine the direction of the port PB. Selection of the input/output port is the same as in the DDA register. DDB can read/write data when the register is selected (1101). #### 6 OPA register The OPA register is the buffer for input and output of data to the port PA. In the case of output, DDAi must be set to "1" (output mode) and the register must be selected (1110), then the data on the bus line is loaded intoOPAi, to be output on PAi. In the case of input, DDAi must be set to "0" (input mode) which prohibits output from OPAi, then the contents of PAi are loaded into OPAi and the data is sent on the bus line. #### OPB register The OPB register is the buffer for input and output of data to the port PB. It has the same function as the OPA register. OPB can read/write data when the register is selected (1111). #### ③ OPC register The OPC register can read/write data when the register is selected (1000). Also, the contents of the data bus can be latched to the OPC register at the falling edge of the external input clock $P\Phi$ . #### F register The F register can read/write data when the register is selected (0111). F0-2 determines the clock rate of the modulation clock FX and F3-5 the modulation clock of FY. # 3-3-3. Pin description ### (\*): See Pad layout and structure in 3-5-2. | No. | Signal name | Function | No. | Signal name | Function | |-----|-------------|------------------------------------|-----|-------------|-----------------------------------| | 1 | PA1 | Port input/output | 31 | RS2 | Register select input | | 2 | PA2 | Port input/output | 32 | RS3 | Register select input | | 3 | PA3 | Port input/output | 33 | R/W | Read/write input | | 4 | PA4 | Port input/output | 34 | ME0 | Memory enable input | | 5 | PA5 | Port input/output | 35 | ME1 | Memory enable input | | 6 | PA6 | Port input/output | 36 | wo | Wait condition input | | 7 | PA7 | Port input/output | 37 | W1 | Wait condition input | | 8 | GND | Power source | 38 | GND | Power source | | 9 | PB0 | Port input/output | 39 | VCC | Power source | | 10 | PB1 | Port input/output | 40 | DME0 | Memory enable output | | 11 | PB2 | Port input/output | 41 | DME1 | Memory enable output | | 12 | PB3 | Port input/output | 42 | WAIT | Wait output | | 13 | PB4 | Port input/output | 43 | INT | Interrupt output | | 14 | PB5 | Port input/output | 44 | RESET | Initialize output | | 15 | PB6 | Port input/output | 45 | IRQ | Interrupt input | | 16 | PB7 | Port input/output, Interrupt input | 46 | Øos | Basic clock input | | 17 | PΦ | Port PC latch clock | 47 | CL1 | Serial receive clock input | | 18 | PC0 | Port output | 48 | SD1 | Serial receive input | | 19 | PC1 | Port output | 49 | LC | Not used | | 20 | PC2 | Port output | 50 | CL0 | Serial rec/trn clock input/output | | 21 | PC3 | Port output | 51 | SD0 | Serial rec/trn input/output | | 22 | PC4 | Port output | 52 | D0 | Data bus input/output | | 23 | PC5 | Port output | 53 | D1 | Data bus input/output | | 24 | PC6 | Port output | 54 | D2 | Data bus input/output | | 25 | PC7 | Port output | 55 | D3 - | Data bus input/output | | 26 | CS0 | Chip select input | 56 | D4 | Data bus input/output | | 27 | CS1 | Chip select input | 57 | D5 | Data bus input/output | | 28 | CS2 | Chip select input | 58 | D6 | Data bus input/output | | 29 | RS0 | Register select input | 59 | D7 | Data bus input/output | | 30 | RS1 | Register select input | 60 | PA0 | Port input/output | # 3-4. Functions # 3-4-1. Operation #### I/O port controller operation | CS2 | CS1 | CS0 | RS3 | RS2 | RS1 | RS0 | R/W | Operation | | | | | |-----|-----|-----|-----|-----|-----|-----|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|-----------------------------------------------------------| | | | | 0 | 1 | 0 | 0 | 0 | Resets the divider internally contained in the I/O port chip. | | | | | | | | | 0 | 1 | 0 | 1 | 1 | Reads the contents of the U register and sends them on the data bus. At the same time, the receive flag RD is reset. | | | | | | | | | 0 | 1 | 1 | Ó | 0 | The contents of the data bus are converted into a serial data signal of start/data/stop structure. At the same time, the transmit flag TD is reset. | | | | | | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | The contents of the data bus are stored in the F register. | | | | | | | | | 1 | 0 | 0 | 0 | 0 | The contents of the data bus are stored in the OPC register. | | | | | | | | | | U | U | 0 | 1 | The contents of the OPC register are sent on the data bus. | | | | | | | | | 1 | 0 | 0 | 1 | 0 | The contents of the data bus are stored in the G register. | | | | | | | | | | | U | 3 | 1 | The contents of the G register are sent on the data bus. | | | | | | | | | 1 | 0 | 1 | 0 | 0 | The contents of the data bus are stored in the MSK register. | | | | | | | | | Ů | | | 1 | The contents of the MSK register are sent on the data bus. | | | | | | | | | | 9 | 0 | 1 | 1 | 0 | The contents of the data bus are stored in the IF register. | | | | | | | | | | | | | | v | 1 | | 1 | The contents of the IF register are sent on the data bus. | | | | | | | | | | | 1 | 1 | 0 | 0 | | | | | | | | U | 1 | The contents of the DDA register are sent on the data bus. | | | | | | | | | 1 | 1 | 0 | 4 | 0 | The contents of the data bus are stored in the DDB register. | | | | | | | | | | | J | d. | 1 | The contents of the DDB register are sent on the data bus. | | | | | | | | | 1 | 1 | 1 | 0 | 0 | The contents of the data bus are stored in the OPA register. | | | | | | | | | 8. | | | J | 1 | The contents of the PAi are sent on the data bus. | | | | | | | | | | , | 40 | | 0 | The contents of the data bus are stored in the OPB register. | | | | | | | | | 1 | 1 | 1 | 1 | 1 | The contents of the PBi are sent on the data bus. | | | | | ### 3-4-2. Wait control #### (1) Function Wait is a function applied in accessing a slow action memory. It makes the CPU operation temporarily halted until a complete access is done to the slow action memory. When the CPU makes access to the address where slow action memory is assigned, the condition "I" is entered to the wait condition inputs W0 and W1. W0 is the wait condition input which is applied to place wait to the memory area controlled by ME0, while W1 is the wait condition for the memory area controlled by ME1. When the wait condition is established, that is, when "W0·ME0+W1·ME1=1" is met, the WAIT signal is issued to the CPU. As the wait control counter is provided internally, it releases WAIT to the CPU when it is counted to the value set by the program, then the CPU proceeds to execute a next machine cycle. Since a slow access memory usually consists of dynamic logic, it needs a precharge time (tp). Thus, the I/O port controller issues the memory enable signals DME0 and DME1 to the dynamic memory, including the precharge time. DME0 is for ME0 and DME1 is for ME1. When the CPU accesses the I/O port controller, the signal WAIT is issued without the wait condition in W0 and W1. #### Wait time Wait time can be programmed by means of bit positions of G5, 6 and 7 of the G register. Relation of G5, 6,7 with tA and tP refer to page 70. #### 3 Wait time of I/O port controller itself When the CPU accesses the I/O port controller, wait of a single CPU machine cycle is automatically applied. If the W0 and W1 is in the wait state when the CPU accessed the I/O port controller, wait ends in one cycle. NOTE: When there is no wait condition in W0 and W1, the same waveform as ME0 and ME1 are sent on DME0 and DME1. tp' and ta' for actual ROM is as follows: $$tP' = tAP + tP + tD$$ $tA' = tA - tD - tS$ $tS = 200nS$ Since tAP and tD differ depending on the peripheral circuit configuration, they should be computed on the basis of load capacitance. ## 3-4-3. Serial data input SD1 is a serial data transfer input and CL1 serial data transfer clock. The I/O port controller reads the input data at the rising edge of CL1. Serial data goes into the receiving mode when it changes from an idle state (SDI=1) to low state and reads data from a next clock. When the 8-bit data is received, it sets the receive and flag RD active. If the mask bit is on at this point, interrupt request is issued to the CPU. RD will be reset upon reading the 8-bit data. RD will be reset in a course of serial data receiving, which is the period that the 8-bit data is being received, without including the start bit. ### 3-4-4. Reset When the RESET line is kept in "1" at least for three $\Phi$ OS clock cycles, it causes internal reset, by which all internal registers are cleared to "0" and ports PA and PB go into the input mode. The divider, however, will not be reset. Terminal states after the reset are as shown in Table below. | Pin name | In/Out | State after reset | |----------|--------|-------------------| | D0~D7 | In/Out | High impedance | | PA0~PA7 | " | .00 | | PB0~PB7 | ** | | | PC0~PC7 | Out | Low level | | WAIT | ** | (NOTE) | | DME0 | | ** | | DME1 | | * | | INT | | Low level | | SD0 | In/Out | High level | | CLO | | Low level | NOTE: WAIT, DME0, and DME1 are output dependent of W0, ME0, W1, and ME1 and do not have any connection with reset. # 3-5. Specification # 3-5-1. I/O port controller input/output circuits ### ① Input #### ② Input/output #### ③ Output #### ① Output ## 3-5-2. Pad layout and structure ### 3-5-3. Electrical characteristics #### Absolute maximum ratings | Parameter | Symbol | Limits | Unit | | |--------------------------|------------------|------------------|------|--| | Input apply voltage (*1) | V <sub>IN1</sub> | -0.3 to 6.5 | V | | | Input apply voltage (*2) | V <sub>PC</sub> | -0.3 to Vcc +0.3 | V | | | Operating temperature | Topr | -5 to +55 | °C | | | Storage temperature | Tstg | -55 to +150 | °C | | <sup>\*1:</sup> Applicable to Vcc and with respect to GND. #### ② Operating condition | Parameter | Symbol | Limits | Unit | |----------------|--------|------------|------| | Supply voltage | Vcc | 4.0 to 5.0 | V | <sup>\*2:</sup> Applicable to other than Vcc, GND, and with respect to GND. #### 3 Electrical characteristics #### ① - 1 - DC characteristics Ta=-5~55℃ Vcc=4.0~5.0V | | 0 | | Limits | | | T | | | |------------------------|-----------------|---------|--------|-----|------|---------------------------|------|--| | Parameter | Symbol | Min Typ | | Max | Unit | Test condition | Note | | | Input voltage | V <sub>E.</sub> | 0 | | 0.8 | V | | ١, | | | mput vonage | ViH | 2.4 | | Vcc | ٧ | | 1 | | | Output voltage 1 | Vol.1 | | | 0.4 | ٧ | Ioc=1.6mA | | | | | Voltt | 2.4 | | | ٧ | loн=0.4mA | 2 | | | Output voltage 2 | Vote | 1.5 | | | v | I <sub>OH</sub> =1.5mA | 3 | | | Output leakage current | ILO | | | 1.0 | μА | | 4 | | | Input current | Hul | | | 1.0 | μΑ | V <sub>N</sub> =OV or Vcc | 5 | | | Normal power | Icca | | 0.4 | 0.9 | mA | ΦOS=2MHz | 6 | | | dissipation | lccb | | | 5 | μA | ΦOS=OV | 7 | | NOTES: For Note number, refer to the list below. | Note<br>No. | Applicable terminals | |-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | PA0~7, PB0~7, D0~7, R/W, RS0~3, CS0, CS1, CS2, ME0, ME1, W0, W1, SD1, CL1, ΦOS, SD0, CL0, IRQ, RESET. | | 2 | PA0~7, PB0~7, PC0~7, D0~7, DME0, DME1, WAIT, CL0, INT | | 3 | PA0~7, CL0, SD0. | | 4 | All input terminals. | | 5 | All output terminals. | | 6 | The term "normal" applies to the reset state that the I/O port controller is not selected and the 2MHz clock should be supplied through the $\Phi$ OS pin. The following input terminals should be connected to 0V except $\overline{\text{CS2}}$ . PA0~7, PB0~7, D0~7, CS0, CS1, $\overline{\text{CS2}}$ =Vcc, R/W, RS0~3, P $\Phi$ , ME0, ME1, W0, W1, CL1, SD1, IRQ. | | 7 | Applied to the state that no clock is supplied to the #OS terminal in the normal condition. | ### 3 - 2 - AC characteristics (Ta=-5 to 55°C, Vcc=4.0 to 5.0V) | Parameter | Symbol | | Limits | | Unit | Test condition | |-------------------------------|-----------|--------------|--------|-----|----------|--------------------------------------------| | Farameter | Symbol | Min | Тур | Max | Oill | rest condition | | CS0, CS1, CS2, | to | | | 230 | ns | | | RS0~3 | tr | 80 | 5 | | ns | | | ME0, ME1 | to | | | 240 | ns | | | | tr | 80 | | 175 | ns | lì | | | tww | 250 | | | ns | | | WAIT | tws | 150 | | | ns | C <sub>L</sub> =50pF | | | twr | 50 | | 200 | ns | | | D0∼7 (input | to | | | 500 | ns | | | mode) | tr | 130 | T. | | ns | | | | tzo | 100 | | | ns | V <sub>0H</sub> =0.8 Vcc | | | tzr | | | 300 | ns | | | D0~7 (output | ts | 200 | | | ns | | | mode) | tr | 50 | | | ns | | | | tzм | 150 | | | ns | | | | tzr | | | 100 | ns | | | R/W | to | -30 | | 50 | ns | VoH=0.8Vcc | | 545 | tr | | | 150 | ns | | | <b></b> ØOS | tec | 500 | | | ns | | | | t | | | 150 | ns | 0.1→0.9Vcc | | | te | | | 40 | ns | 0.9-0.1Vcc | | PA0~7, PB0~7<br>(output mode) | toe | A 1011 48 11 | | 1 | μs | C <sub>L</sub> =100pF | | PC0~7 (register select) | tox | | | 1 | μs | C <sub>L</sub> =100pF | | PΦ | to | | lav-en | 350 | ns | VoH=0.8Vcc | | PC0~7 (PΦ latch) | tr<br>top | | | 100 | ns<br>µs | C <sub>L</sub> =100pF | | SD0 (input | ts | 100 | | | ns | | | mode)<br>SD1 | tн | 50 | | | ns | | | SD0 (output<br>mode) | to | | | 100 | ns | Ct=100pF | | DME0 | to | | | 120 | ns | C <sub>L</sub> =50pF | | DME1 | tr | | | 120 | ns | 400 CO | | SD0 | tz | | | 200 | ns | C <sub>L</sub> =100pF | | CL0 | t, | | | 100 | ns | 0.1-0.9 Vcc<br>Ct=50pF | | | t, | | | 100 | ns | 0.9→0.1 Vcc<br>C <sub>L</sub> =50pF | (\*): Unless otherwise specified, the criterion shall be $V_{OH}=2.0V$ , $V_{CM}=0.4V$ ### ③ - 3 - Timings 4 PC-1500 hardware description # 4-1. PC-1500 system configuration #### 4-1-1. Outline Around the PC-1500 Pocket Computer, the PC-1500 system can be configured with a variety of peripherals, which include the CE-150 Color Graphic Printer, CE-151 4KB Memory Module, CE-152 Cassette Tape Recorder, CE-153 Software Board, CE-154 System Carrying Case, CE-155 8KB Memory Module, CE-158 Serial and Parallel Interface, and CE-159 Program Module. #### PC-1500 Pocket Computer It is a pocket computer that features high speed processing with the CMOS 8-bit microprocessor in use, and it has memories of 16KB ROM and 3.5KB RAM on standard. It also permits expansion by the use of options. Four pieces of Type AA dry batteries are used for its power source and the $7 \times 156$ dot LCD is used for the display. #### ② CE-150 Color Graphic Printer It is a ball-point pen type four color printing X-Y plotter. It has 8KB ROM for the memory and is driven by five pieces of Type AA Ni-Cd batteries. It also has the cassette interface built in the unit. #### 3 CE-151 4KB Memory Module It is a 4KB option memory unit in which two chips of 2KB RAM are contained. #### 4 CE-152 Cassette Tape Recorder It is a cassette tape recorder dedicated for use with the PC-1500 system. It is driven by four pieces of Type AA dry batteries. #### (5) CE-153 Software Board It has 140 keys arranged on the keyboard and each key assignment is defined by means of programming. As it does not have power supply by itself, it is supplied from the PC-1500. #### 6 CE-154 System Carrying Case The carrying case exclusively designed for carrying of the PC-1500, CE-150, CE-152, CE-153. #### ① CE-155 8KB Memory Module It is an 8KB option memory unit in which four chips of 2KB RAM are contained. #### ® CE-158 Serial and Parallel Interface It has the RS-232C serial interface and the Centronics parallel interface with the builtin 16KB ROM. It is driven by four pieces of Type AA Ni-Cd batteries. It will be possible to interface with a normal type printer, computer, instrument, etc. #### © CE-159 Program Module It is a detachable memory module that consists of four chips of 2KB RAM, of which area can be partially or entirely used for the read only area. The contents of the memory can be retained by means of the internal lithium battery even if it was detached from the PC-1500. ### 4-1-2. Block diagram ### 4-1-3. Power supplies (PC-1500, CE-150, CE-158, CE-159) - ① PC-1500 and its peripheral units (CE-150, CE-158, CE-159) are driven independently by dry battery, Ni-Cd battery, or lithium battery. When the PC-1500 is connected with peripheral, RAM, ROM, I/O PC, CMT I/F, and UART are driven by VCC or VGG supplied from the PC-1500. - When the Ni-Cd battery of the CE-150 is charged capable to drive the PC-1500, power is supplied from the CE-150 to the PC-1500 and therefore the battery of the PC-1500 does not consume. In addition, it drives the driver of the printer and remote control relays. - 3 The Ni-Cd battery of the CE-158 drives the driver and receiver of the RS-232C serial interface and the Centronics parallel interface. - When the CE-159 is in connection with the PC-1500, it is operated by VGG of the PC-1500, and its memory contents can be retained by the internal lithium battery when disconnected from the PC-1500. # 4-2. PC-1500 ### 4-2-1. Outline #### ① CPU The LH5801 CMOS 8-bit Microprocessor is used. As it is operated by the clock frequency of 2.6MHz from the crystal oscillator, its internal machine cycle is 1.3MHz. BFI . . . . . . . Depression of the key turns it to high level so that VCC is supplied from BFO. IN0~IN7 ..... Input port for other than the M key. D0~D7..... Bidirectional data bus which is used to write and read data to/from the external memory. D0: LSB D7: MSB AD0~AD15....Address bus. AD0: LSB AD15: MSB XL0, XL1..... External crystal connection terminals, through which the 2.6MHz crystal is connected. XL0: Input XL1: Output #### ② I/O PC Either LH5810 or LH5811 is used. The same chip is used for I/O of CE-150, CE-153, and CE-158. PA0~PA7 ..... Key strobe output PB7..... ™ key input AD0~3, AD12~13, DME1 ..... Address of I/O port is set within F000H to F00FH of the ME1 area. #### (3) Timer IC μPD 1990AC is used and connected with the 32.768kHz crystal. #### 4 Chip select decoder It consists of two chips of TC40H139F and TC40H138F and it is used to select chip by means of $S0\sim4$ , S6, S7, $\overline{2Y2}$ and $\overline{2Y3}$ . For more details, refer to "Chip select circuit". #### ⑤ Display chip Because 4-bit SC882G is used, chip 1 is used in pair with chip 3 and chip 2 with chip 4. Select signal is commonly used by chip 1 and chip 3 or chip 2 and chip 4. Data bus is therefore divided into D0~D3 and D4~D7 in order to handle compatible with the 8-bit RAM. Address is within 7600H to 77FFH of the ME0 area and is used for the fixed variable area, in addition to the display buffer. #### System ROM It is the PC-1500 system program residing ROM for which the 8-bit×16K SC61328F is used. Address is within C000H to FFFFH of the ME0 area. #### System RAM Because the 4-bit×1K bytes TC5514 is used in a pair, the data bus is divided into two of D0~D3 and D4~D7 and the select signal S7 is commonly shared so as to be compatible with the 8-bit RAM. Address is within 7800H to 7BFFH of the ME0 area which is used for the system memory area and for the fixed variable area. #### (8) User RAM It is the user RAM for which 8-bit×2KB HM6116 is used. Address selected by S0 is within 4000H to 47FFH. #### 40-pin connector It is the connector used for the connection of one of optional memory modules and program module, on which provided signal terminals for address bus, data bus, and chip select. #### (ii) 60-pin connector It is the connector used for the connection of optional printer and interface, on which provided signal terminals of address bus and data bus for the control of peripherals. #### ① LCD The 7×156 dot LF8082GE multi-display is used. ### 4-2-2. Block diagram # 4-2-3. Chip select circuit - 1Y0~1Y3 is selected by the decoder IC (TC40H139F) when the gate signal input BFO (1G) is low. - Y0 ..... With low state of AD14 and AD15, the Y0 output goes low so as to select the - (1Y0) user memory area of the module unit. (Address assignment of 0000H~3FFFH) - Y1 ..... With high state of AD14 and low state of AD15, the Y1 output goes low so as - (IYI) to select the gate (G2A) of the IC (TC40H138F). (Address assignment of 4000H~7FFFH) - Y2 ..... With low state of AD14 and high state of AD15, the Y2 output goes low so as - (1Y2) to select the optional ROM area of the module unit. (Address assignment of 8000H~BFFFH) - Y3 ..... With high state of AD14 and AD15, the Y3 output goes low so as to select - (1Y3) the system program ROM (SC61328F) and the I/O port (LH5811 or LH5810). (Address assignment of C000H~FFFFH) - S0~S7 is selected by the decoder IC (TC40H138F) when the gate signal input ME0 (G1) is high, Y1 (G2A) low, and G2B is low (normally low). - S0 ..... With all of AD11, AD12 and AD13 in low state, the S0 output goes low so as - (Y0) to select the user RAM (HM6116). (Address assignment of 4000H~47FFH) - S1 ..... With high state of AD11 and low state of AD12 and AD13, the S1 output - (Y1) goes low so as to select the optional user RAM area. (Address assignment of 4800H~4FFFH) - S2 ..... With low state of AD11 and AD13 and high state of AD12, the S2 output - (\overline{Y2}) goes low so as to select the optional user RAM area. (Address assignment of 5000H~57FFH) - S3 ..... With low state of AD11 and AD12 and high state of AD13, the S3 output - (\overline{Y3}) goes low so as to select the user RAM area. (Address assignment of 5800H~5FFFH) - S4 ..... With high state of AD11 and AD13 and low state of AD12, the S4 output - (Y4) goes low so as to select the user RAM area. (Address assignment of 6000H~67FFH) - S5 . . . . . Do not use. - S6 ..... With low state of AD11 and high state of AD12 and AD13, the S6 output - (Y6) goes low so as to receive on the I/O port the data from the display chip RAM or interrupt input from the option. (Address assignment of 7000H~77FFH) - S7 ..... With all of AD11, AD12, and AD13 in high state, the S7 output goes low so - (\overline{Y7}) as to select the system RAM (TC5514) (Address assignment of 7800H~7FFFH) - 2Y2, 2Y3 is selected by the decoder IC (TC40H139) when the 2G gate becomes effective after the selection (low state) of the TC40H138F output S6 (Y6). - V2..... With low state of AD8 and high state of DME0, the $\overline{2Y2}$ output goes low and - (2Y2) makes the NAND gate output V2 high so as to select display chip I and 3.(Address assignment of 7600H~76FFH) - V3 ..... With high state of AD8 and DME0, the $\overline{2Y3}$ output goes low and makes the - (2Y3) NAND gate output V3 high so as to select display chip 2 and 4. (Address assignment of 7700H~77FFH) | | | | 0000H | | | |--------------------------|--------------------------|--------------|----------------|--------------------------------------------------------------------------------------|-------------------------------| | Y0<br>(1Y0) | | | ЗҒҒ | OPTIONAL USER MEMORY | | | | \$0<br>( <del>Y</del> 0) | | 4000H<br>47FFH | STANDARD USER MEMORY | | | | S1<br>(Y1) | | 4800H<br>4FFFH | | | | | \$2<br>( <u>Y2</u> ) | | 5000H<br>57FFH | | | | | S3 | | 5800H | OPTIONAL USER MEMORY | 80 | | 3 | (Y3)<br>S4 | | 5FFFH<br>6000H | MAY . | | | Y1<br>(1 <u>Y1</u> ) | (Y4)<br>S5 | | 67FFH<br>6800H | WW o | | | | (Y5) | | 7000H | | NOTE: S0~5 | | | | | 75FFH | INHIBITED | V3 are applie<br>for ME0 area | | | S6<br>(Y6) | V2<br>(2Y2) | 7600H<br>76FFH | | | | | | V3<br>(2Y2) | 7700H<br>77FFH | STANDARD USER AND SYSTEM MEMORY | | | | \$7<br>(Y7) | 60 (0.00 CM) | 7800H<br>7FFFH | INHIBITED | | | Y2<br>(1Y2) | 21576 | | 8000H | CE-150<br>SYSTEM PROGRAM, I/O PORT<br>CE-153<br>I/O PORT<br>CE-158<br>SYSTEM PROGRAM | | | | | | 8FFFH | | | | Y3<br>( <del>1Y3</del> ) | | | С000Н | PC-1500<br>SYSTEM PROGRAM<br>I/O PORT<br>CE-158<br>I/O PORT<br>UART | | | | | | FFFFH | | | NOTE: S0~S7, V2, and V3 are applicable only for ME0 area. ### 4-2-4. PC-1500 system memory map In the ME0 area is contained such as the system program and user RAM area and the ME1 is used for such as I/O port. Memory bank is assigned by PV and $\overline{PV}$ for the ME0 area of 8000H thru BFFFH, and PU and $\overline{PU}$ are used to assign the PV area of 8000H thru 9FFFH. Address 0000H thru 7FFFH is used for the user area and 8000H thru FFFFH for the system area. The system area is used by the mnemonic programming system by which the CPU, I/O PC, etc. are controlled, and the user area is used to store the program written in BASIC, mnemonic programming language, and data. With the PC-1500, ME0 memory area 4000H thru 47FFH and 7600H thru 7BFFH are used for the user memory and C000H thru FFFFH for the system program. When the CE-150 or CE-158 is connected, the system program, I/O port, and RAM are arranged as shown in the next page. ② Upon power on to the PC-1500, initialization starts for peripheral units according to the system program residing in the system area, and the user area ROM and RAM are checked, then it becomes ready for a key entry. #### MEMORY MAP I ### MEMORY MAP II #### MEMORY MAP when the CE-155 is used. Note: For MEMORY MAP when the CE—161 is used, refer to page 160. #### MEMORY MAP III , MEMORY MAP IV STANDARD USER & SYSTEM MEMORY (RAM) 1.5KB | LOW | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | |-----|---|----|-----|----|---|----|----|----|----|----|----|----|----|----|-----|----| | 0 | | | | | | | | | | | | | | | | | | 2 | | | | | | | | | | г | | | | | | | | 4 | | | | | | | | | | | | | | | | | | 6 | | DI | SP | LA | Υ | Ε | F | G | н | 1 | J | K | L | М | N | 0 | | 8 | | BL | JFF | ER | 8 | \$ | \$ | \$ | \$ | \$ | \$ | \$ | \$ | \$ | \$ | \$ | | Α | | | | | | | | | | | | | | | 25. | ľ | | C | | | | | | | | | | | | | | | | | | E | | | | | | | | | | | | | | | | | | HIGH | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | |------|------|-----|-----|-----|---|----|----|----|----|----|--------|----|-------|------|----|-----| | LOW | 0.00 | | 27 | 377 | | | | - | | | ranca. | | 0.000 | 2000 | | 100 | | 0 | | | | | | | | | | | | | | | | Ì | | 2 | | | | | | | | | | | | | | | | | | 4 | | | | | | | | | | | | | | | | | | 6 | 6 | DIS | SPI | A | | P | a | R | S | Т | U | V | W | х | Y | Z | | 8 | | BU | FF | ER | | \$ | \$ | \$ | \$ | \$ | \$ | \$ | \$ | \$ | \$ | \$ | | Α | | | | | | | | | | | | | | | | | | C | | | | | | | | | | | | | | | | | | Е | | | | | | | | | | | | | | | | | | 7800 | H- | ~ | 78F | FH | 1 | | | | | | | | | | | | |------|----|--------|-----|----|---|---|--------|----|----|-----|---|---|----|----|----|-----| | LOW | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | | 0 | | | | | | | | | | | | П | | Г | | Г | | 2 | | | | | | | | | | | | | | | | | | 4 | | | | | | | | | | | | | | | | | | 6 | | SYSTEM | | | | | SYSTEM | | | | | | A | В | C | D | | 8 | | ST | AC | K | | | | ME | MC | ORY | ŕ | | \$ | \$ | \$ | \$ | | Α | | | | | | | | | | | | | | | | 100 | | C | | | | | | | | | | | | | | | | | | E | | | | | | | | | | | | | | | | | | OW | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | С | D | E | F | |------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|-----|----| | 0<br>2<br>4<br>6 | А | С | E | G | ľ | K | М | 0 | ۵ | s | U | w | Υ | | ST | EM | | 8<br>A<br>C | В | D | F | н | J | L | N | Р | R | Т | V | х | z | | EMC | RY | #### 7A00H~7AFFH | LOW | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | |------------------|---|---|---|---|---|---|---|---|----|----|----|----|----|---|---|---| | 0<br>2<br>4<br>6 | x | Υ | v | s | | | | D | | 10 | ST | AC | v | | | | | 8<br>A<br>C<br>E | Z | υ | w | | | | | D | 13 | | 31 | AC | ·K | | | | #### 7B00H~7BFFH | LOW | 0 1 | 2 3 4 5 | 6 7 8 9 A | BCDEF | |---------------------------------|---------------|------------------|------------------|-----------------| | 0<br>2<br>4<br>6<br>8<br>A<br>C | SYSTEM MEMORY | STRING<br>BUFFER | OUTPUT<br>BUFFER | INPUT<br>BUFFER | - A~Z (7900H~79CFH) are fixed numerical variables. - A\$~Z\$ are fixed character variables. - The arithmetic registers X, Y, V, S, Z, U and W (7A00H~7A37H) are different from fixed numerical variables. - BASIC stack includes stacks for FOR-NEXT, GOSUB, DATA, FUNCTION. - See the next page for details of the display buffer. - For system memory, refer to MEMORY MAP VII. #### MEMORY MAP V #### I/O port | | PC-1500 | CE-150 | CE-153 | CE-158 | |------------------------------|---------|--------|--------|--------| | Do not use | F000H | В000Н | 8000Н | D000H | | Do not use | F001H | В001Н | 8001H | D001H | | Do not use | F002H | В002Н | 8002H | D002H | | Do not use | F003H | в003Н | 8003H | D003H | | Divider reset | F004H | В004Н | 8004H | D004H | | U register output | F005H | В005Н | 8005H | D005H | | Serial transfer | F006H | в006Н | 8006Н | D006H | | Load divider to F register | F007H | В007Н | 8007H | D007H | | Port C input/output | F008H | B008H | 8008H | D008H | | G register input/output | F009H | В009Н | 8009Н | D009H | | MSK register input/output | F00AH | вооан | 800AH | D00AH | | IF register input/output | F00BH | воовн | 800BH | D00BH | | Specify port A I/O direction | F00CH | В00СН | 800CH | D00CH | | Specify port B I/O direction | F00DH | B00DH | 800DH | D00DH | | Port A input/output | F00EH | вооен | 800EH | D00EH | | Port B input/output | F00FH | B00FH | 800FH | D00FH | #### Memory map VI Display buffer Since there are 7 × 156 dots with 14 additional dots of symbols (DEF, I, PRO, etc.), each dot is allocated with a corresponding bit of the memory in order to control activation of dots. Address is represented by the hexadecimal notation and "H" is used to represent high state and "L" to represent low state of segment drive signals. | | 760 | )— | 76 | - | 76 | 2- | 763 | 3- | 76- | 4 — | |---|----------------------|---------------------|----------------------|---------------------|----------------------|---------------------|----------------------|---------------------|----------------------|---------------------| | / | HIGH ORDER<br>4 BITS | LOW ORDER<br>4 BITS | HIGH ORDER<br>4 BITS | LOW ORDER<br>4 BITS | HIGH ORDER<br>4 BITS | LOW ORDER<br>4 BITS | HIGH ORDER<br>4 BITS | LOW ORDER<br>4 BITS | HIGH ORDER<br>4 BITS | LOW ORDER<br>4 BITS | | 0 | S79L | S1L | S87L | S9L | S95L | S17L | S103L | S25L | S111L | S31L | | 1 | S79H | S1H | S87H | S9H | S95H | S17H | S103H | S25H | S111H | S31H | | 2 | S80L | S2L | 1 | 1 | | 1 | 1 | 1 | 1 | † | | 3 | S80H | S2H | | | | | | | | | | 4 | 81 | 3 | | | | | | | | | | 5 | 81 | 3 | | | | | | | | | | 6 | 82 | 4 | | | | | | | | | | 7 | 82 | 4 | | | | | | | | | | 8 | 83 | 5 | | | | | | | | | | 9 | 83 | 5 | | | | | | | | | | Α | 84 | 6 | | | | | | | | | | В | 84 | 6 | | | | | | | | | | С | 85 | 7 | | | | | | | S117L | S39L | | D | 85 | 7 | | | | | | | S117H | S39H | | E | S86L | S8L | S94L | S16L | S102L | S24L | S110L | S30L | | | | F | S86H | S8H | S94H | S16H | S102H | S24H | S110H | S30H | | | | ADDRESS | | HIGH ORI | DER 4 BIT | S | | LOW ORD | ER 4 BITS | | |---------|----------|----------|-----------|---------|----------|---------|-----------|-----| | 764EH | DEF | I | П | Ш | SMALL | SML | SHIFT | BUS | | 764FH | NOT USED | RUN | PRO | RESERVE | NOT USED | RAD | G | DE | | | 77 | 0- | 77 | 1- | 77. | 2- | 77. | 3- | 77 | 4- | |---|----------------------|---------------------|----------------------|---------------------|----------------------|---------------------|----------------------|----------------------|----------------------|----------------------| | | HIGH ORDER<br>4 BITS | LOW CHEER<br>4 BITS | HIGH ORDER<br>4 BITS | LOW DRDER<br>4 BITS | HIGH ORDER<br>4 BITS | LOW ORDER<br>4 Bits | HIGH ORDER<br>4 BITS | LOW ORDER<br>4. BITS | HIGH ORDER<br>4 BITS | LOW DISSES<br>4 BITS | | 0 | S118L | S40L | \$126L | S48L | S134L | S56L | S142L | S64L | S150L | S72L | | 1 | S118H | S40H | S126H | \$48H | S134H | S56H | S142H | S64H | S150H | \$72H | | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 3 | | | | | | | | | | | | 4 | | | | | | | | | | | | 5 | | | | | | | | | | | | 6 | | | | | | | | | | | | 7 | | | | | | | | | | | | 8 | | | | | | | | | | | | 9 | | | | | | | | | | | | Α | | | | | | | | | | | | В | | | | | | | | | <b>.</b> | | | C | | | | | | | | | S156L | S78L | | D | | | | | | + | | <b>.</b> | S156H | S78F | | E | S125L | S47L | S133L | \$55L | S141L | S63L | S149L | \$71L | NOT | USED | | F | S125H | S47H | S133H | S55H | S141H | S63H | S149H | S71H | NOT | USEU | ### Memory Map VII ### MEMORY SYSTEM DETAIL | | 5 | 6 | 7 | 8 | 9 | Α | В | |---|---|----------|--------------------|-----------------------|-----------------------|-----------------------|-----------------------| | 0 | | | | | FOR POINTER | PREVIOUS<br>ADORESS H | BREAK<br>TOP H | | 1 | | | WAIT Y/N | | GOSUB<br>POINTER | PREVIOUS<br>ADDRESS L | BREAK<br>TOP L | | 2 | | | WAIT CU | | | PREVIOUS<br>LINE H | ERROR<br>ADDRESS H | | 3 | | | WAIT CL | | | PREVIOUS<br>LINE L | ERROR<br>ADDRESS L | | 4 | | | CURSOR EN | | STRING BUFFER POINTER | PREVIOUS<br>TOP H | ERROR<br>LINE H | | 5 | | | CURSOR<br>POINTER | | USING F/F | PREVIOUS<br>TOP L | ERROR<br>LINE L | | 6 | | | | | USING M | SEARCH<br>ADDRESS H | ERROR<br>TOP H | | 7 | | | | | USING & | SEARCH<br>ADDRESS L | ERROR<br>TOP L | | 8 | | | 1980414940494 | | USING m | SEARCH<br>LINE H | ON ERROR<br>ADDRESS H | | 9 | | | | | VARIABLE<br>POINTER H | SEARCH<br>LINE L | ON EHROR<br>ADDRESS L | | A | | | | | VARIABLE<br>POINTER L | SEARCH<br>TOP H | ON ERROR | | В | | RMT/BEEP | | | ERN | SEARCH<br>TOP L | ON ERROR<br>LINE L | | c | | | | | CURRENT<br>LINE H | BREAK<br>ADDRESS H | ON ERROR | | D | | | BRINK<br>CHARACTOR | TRACE | CURRENT<br>LINE L | BREAK<br>ADDRESS L | ON FRROR | | E | | | CURSOR H | TRACE<br>CONDITION | CURRENT<br>TOP H | BREAK<br>LINE H | DATA<br>POINTER H | | F | | | CURSOR L | OUTPUT BUFFER POINTER | CURRENT<br>TOP L | BREAK<br>LINE L | DATA<br>PONTER L | | 9X | X | | | 7BXX | |----|--------|--------------------------|------------|-----------------------------| | | D | E | F | 0 | | 0 | | USER<br>COUNTER XH | GRAPH/TEXT | 1 | | 1 | OPN DV | USER<br>COUNTER XL | | | | 2 | | USER<br>COUNTER YH | ROTATE | RND | | 3 | | USER<br>COUNTER YL | COLOR | NUMBER | | 4 | | SCISSORING<br>COUNTER YH | CSIZE | | | 5 | | SCISSORING<br>COUNTER YL | | | | 6 | | ABSOLUTE<br>POSITION X | | | | 7 | | SCISSORING<br>COUNTER XL | | | | 8 | | SCISSORING<br>COUNTER XH | | | | 9 | | | | | | A | | LINE TYPE | | OFF COUNTER L | | В | | DOT LINE<br>COUNTER | | AUTO POWER<br>OFF COUNTER N | | c | | UP/DOWN | | AUTO POWER<br>OFF COUNTER L | | D | | X MOTOR HOLD<br>COUNTER | | | | E | | PORT C | | | | F | | Y MOTOR HOLD<br>COUNTER | FOCK | | | RMT/BEEP<br>WAIT Y/N | Remote and beep on/off pointer | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WAIT Y/N | AND THE COST CONTROL OF THE COST OS OF THE COST OF THE COST OF THE COST OF THE COST OF THE COST OS OF THE COST | | | WAIT(0), WAIT0(3), WAIT1(2) | | WAIT COUNTER H | WAIT counter | | WAIT COUNTER L | | | CURSOR ENABLE | (01H) if used. (00H) if not. | | CURSOR POINTER | Cursor pointer (0~155) | | BLINK CHARACTER | Character code to be blinked. | | BLINK CURSOR H | Blinking cursor position (address of the display buffer | | BLINK CURSOR L | | | TRACE | Trace on/off pointer | | TRACE CONDITION | Status when trace on. | | OUTPUT BUFFER POINTER | Output buffer pointer | | FOR POINTER | FOR-NEXT stack pointer | | GOSUB POINTER | GOSUB pointer | | STRING BUFFER POINTER | String buffer pointer | | USING F/F | Using format (presence of decimal point, comma, etc. | | USING M | Integer part of Using | | USING & | Using of character string | | USING m | Decimal part of Using | | VARIABLE POINTER H | Variable pointer | | VARIABLE POINTER L | | | ERL | Error number when occurred. | | CURRENT LINE H | Current line number | | CURRENT LINE L | | | CURRENT TOP H | Leading address of program of the current line | | CURRENT TOP L | | | PREVIOUS ADDRESS H | Address of immediately preceding line | | PREVIOUS ADDRESS L | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | PREVIOUS LINE H | Line number immediately preceding | | PREVIOUS LINE L | | | PREVIOUS TOP H | Leading address of program of the line immediately | | PREVIOUS TOP L | preceding | | SEARCH ADDRESS H | Address of the line found during search | | | | | Section (Section 1) For U.S. Saladiro | Line number found after search | | | | | | Leading address of the searched program block | | SEARCH TOP L | | | BREAK ADDRESS H | Address of breakpoint | | | | | | Address of breakpoint line number | | Proportion and advantage of a | Action of oreaspoint line Itimoer | | 100000000000000000000000000000000000000 | T- dd- dh- | | | Top address of the program block to which break is applied. | | TOTAL PRODUCTION OF THE PROPERTY PROPER | | | | Address where error is met. | | | Line number unter constituted | | | Line number where error is met. | | | BLINK CHARACTER BLINK CURSOR H BLINK CURSOR L TRACE TRACE CONDITION OUTPUT BUFFER POINTER FOR POINTER GOSUB POINTER STRING BUFFER POINTER USING F/F USING M USING & USING M VARIABLE POINTER H VARIABLE POINTER L ERL CURRENT LINE H CURRENT LINE H CURRENT TOP H CURRENT TOP L PREVIOUS ADDRESS H PREVIOUS LINE H PREVIOUS LINE H PREVIOUS TOP H PREVIOUS TOP H PREVIOUS TOP L SEARCH ADDRESS L SEARCH LINE H SEARCH LINE H SEARCH TOP H | | Address | Name | Function | | | | |---------|-----------------------|--------------------------------------------------------|--|--|--| | 78B6H | ERROR TOP H | Leading address of the program block in which error is | | | | | 78B7H | ERROR TOP L | met. | | | | | 78B8H | ON ERROR ADDRESS H | Address to which program jumps when an error is met | | | | | 78B9H | ON ERROR ADDRESS L | | | | | | 78BAH | ON ERROR LINE H | Line number to which program jumps when an error is | | | | | 78BBH | ON ERROR LINE L | met. | | | | | 78BCH | ON ERROR TOP H | Leading address of program block in which an error is | | | | | 78BDH | ON ERROR TOP L | met. | | | | | 78BEH | DATA POINTER H | Pointer for data statement | | | | | 78BFH | DATA POINTER L | | | | | | 79D1H | OPN DV | Peripheral device select | | | | | 79E0H | USER COUNTER XH | Counter by which X-coordinates of the pen are | | | | | 79E1H | USER COUNTER XL | indicated. | | | | | 79E2H | USER COUNTER YH | Counter by which Y-coordinates of the pen are | | | | | 79E3H | USER COUNTER YL | indicated. | | | | | 79E4H | SCISSORING COUNTER YH | Y-direction scissoring counter | | | | | 79E5H | SCISSORING COUNTER YL | The section and the section of the constitution of | | | | | 79E6H | ABSOLUTE POSITION X | X-direction absolute point counter | | | | | 78E7H | SCISSORING COUNTER XL | X-direction scissoring counter | | | | | 79E8H | SCISSORING COUNTER XH | | | | | | 79EAH | LINE TYPE | Kind of line | | | | | 79EBH | DOT LINE COUNTER | Dot line counter | | | | | 79ECH | UP/DOWN | Pen up/down position select | | | | | 79EDH | X MOTOR HOLD COUNTER | X motor hold counter | | | | | 79EEH | PORT C | Indicates current motor phase. | | | | | 79EFH | Y MOTOR HOLD COUNTER | Y motor hold counter | | | | | 79F0H | GRAPH/TEXT | Printer mode select (graph=255, text=0) | | | | | 79F2H | ROTATE | Printing direction select | | | | | 79F3H | COLOR | Color select | | | | | 79F4H | CSIZE | Printing character size select | | | | | 79FFH | LOCK | Lock/unlock select | | | | | 7B00H | RND NUMBER | Random number | | | | | 7B01H | RND NUMBER | | | | | | 7B02H | RND NUMBER | | | | | | 7B03H | RND NUMBER | | | | | | 7B04H | RND NUMBER | | | | | | 7B05H | RND NUMBER | | | | | | 7B06H | RND NUMBER | | | | | | 7B07H | RND NUMBER | | | | | | 7B0AH | AUTO P-OFF COUNTER U | Auto power off counter | | | | | 7B0BH | AUTO P-OFF COUNTER M | | | | | | 7B0CH | AUTO P-OFF COUNTER L | | | | | # 4-3. Connector signals/LSI signals Note that there may be a different kind of connector used for the 40 and 60 pin connector of the PC-1500 on account of product revision. The 64-pin connector on the back of the CE-150 is compatible with the 60-pin connector of the PC-1500. Either the LH5811 or LH5810 is used for the I/O PC. The LH5811 is an upgraded version of the LH5810. ### 4-3-1. 40-pin connector | Pin no. | Signal name | Description | |---------|-------------|------------------------------------------------------------------------| | 1 | vcc | VCC | | 2 | PV | Chip select | | 3 | PU | Chip select | | 4 | Y0 | Address designation of 0000H~3FFFH | | 5 | S4 | Address designation of 6000H~6700H | | 6 | DME0 | Chip select with WAIT condition in consideration (ME0 area assignment) | | 7 | D7 | Data bus | | 8 | D6 | Data bus | | 9 | D5 | Data bus | | 10 | D4 | Data bus | | 11 | D3 | Data bus | | 12 | D2 | Data bus | | 13 | D1 | Data bus | | 14 | D0 | Data bus | | 15 | INHIBIT | Prohibits ROM select of the PC-1500, when connected to GND | | 16 | S1 | Address designation of 4800H~4FFFH | | 17 | S2 | Address designation of 5000H~57FFH | | 18 | S3 | Address designation of 5800H~5FFFH | | 19 | Y2 | Address designation of 8000H~BFFFH | | 20 | VGG | VGG | | 21 | GND | GND | | 22 | AD15 | Address bus | | 23 | AD14 | Address bus | | 24 | AD13 | Address bus | | 25 | AD12 | Address bus | | 26 | AD11 | Address bus | | 27 | AD10 | Address bus | | 28 | AD9 | Address bus | | 29 | AD8 | Address bus | | 30 | AD7 | Address bus | | 31 | AD6 | Address bus | | 32 | AD5 | Address bus | | 33 | AD4 | Address bus | | 34 | AD3 | Address bus | | 35 | AD2 | Address bus | | 36 | AD1 | Address bus | | 37 | AD0 | Address bus | | 38 | OD | Output disable | | 39 | R/W | Memory read/write | | 40 | GND | GND | NOTE: S4 of No. 5 may be NC, depending on production month. # 4-3-2. 60-pin connector | in no. | Signal name | Description | |--------|---------------|--------------------------------------------------------------| | 1 | AD7 | Address bus | | 2 | AD6 | Address bus | | 3 | AD5 | Address bus | | 4 | AD4 | Address bus | | 5 | AD3 | Address bus | | 6 | AD2 | Address bus | | 7 | AD1 | Address bus | | 8 | AD0 | Address bus | | 9 | PB0 | Not used | | 10 | PC7 | Not used | | 11 | VCC | VCC | | 12 | VCC | VCC | | 13 | NC | NC | | 14 | NC | NC | | 15 | PV | Chip select | | 16 | PU | Chip select | | 17 | D7 | Data bus | | 18 | D6 | Data bus | | 19 | D5 | Data bus | | 20 | D4 | Data bus | | 21 | D3 | Data bus | | 22 | D2 | Data bus | | 23 | D1 | Data bus | | 24 | D0 | Data bus | | 25 | INHIBIT | Prohibits ROM select of the PC-1500, when connected to GND | | 26 | WEX | External WAIT signal | | 27 | CMTIN | Cassette data input | | 28 | W1 | WAIT condition input | | 29 | CMTOUT | Cassette data output | | 30 | INT | Interrupt request to CPU | | 31 | AD8 | Address bus | | 32 | AD9 | Address bus | | 33 | AD10 | Address bus | | 34 | AD11 | Address bus | | 35 | AD12 | Address bus | | 36 | AD13 | Address bus | | 37 | AD14 | Address bus | | 38 | AD15 | Address bus | | 39 | PB1 | Not used | | 40 | NC | NC. | | 41 | VCC | VCC | | 42 | VCC | VCC | | 43 | F-GND<br>VBAT | Frame GND | | 45 | VBAT | VBAT<br>VBAT | | 46 | VBAT | VBAT | | 47 | VBAT | VBAT | | 48 | VBAT | VBAT | | 49 | NC NC | NC VBA1 | | 50 | BFO | VCC output | | 51 | ΦOS | Clock in the same phase as the LSI internal clock | | 52 | GND | GND | | 53 | GND | GND | | 54 | GND | GND | | 55 | GND | GND | | 56 | DMEO | Chip select taking consideration of WAIT condition (ME0 area | | 50 | DIVIEU | designation) | | 57 | R/W | Memory read/write signal | | 58 | DME1 | Chip select taking consideration of WAIT condition (ME1 area | | 50 | DIVIC | designation) | | 59 | ME1 | ME1 area designation | | Jo | OD | Output disable | NOTE: PB0 of No. 9 may be NC depending on production month. PB1 of No. 39 may be NC depending on production month. # 4-3-3. LH5801 Microprocessor | Pin no. | Signal name | Description | |---------|-------------|------------------------------------------------------------| | 1 | RESET | Reset input | | 2 | NC | NC | | 3 | BRQ | Fixed to GND level | | 4 | BFI | key input signal | | 5 | VGG | VGG | | 6 | BFO | VCC output | | 7 | OPF | Not used | | 8 | BAK | Not used | | 9 | VCC | VCC (4.0~4.7V) | | 10 | VGG | VGG (4.0~4.7V) | | 11 | VM | LCD power supply | | 12 | VDIS | LCD power supply | | 13 | VA | LCD power supply | | 14 | VB | LCD power supply | | 15 | NMI | GND | | 16 | MI | Maskable interrupt input | | 17 | HIN | LCD backplate signal | | 18 | HA | LCD backplate signal | | 19 | DISP | LCD on/off control | | 20 | H7 | Not used | | 21 | H6 | Backplate control | | 22 | H5 | Backplate control | | 23 | H4 | Backplate control | | 24 | H3 | Backplate control | | 25 | H2 | Backplate control | | 26 | H1 | Backplate control | | 27 | 1-10 | Backplate control | | 28 | OD | Output disable | | 29 | ME0 | ME0 area designation | | 30 | ME1 | ME1 area designation | | 31 | D0 | Data bus | | 32 | D1 | Data bus | | 33 | D2 | Data bus | | 34 | D3 | Data bus | | 35 | D4 | Data bus | | 36 | D5 | Data bus | | 37 | D6 | Data bus | | 38 | D7 | Data bus | | 39 | AD0 | Address bus | | 40 | AD1 | Address bus | | 41 | AD2 | Address bus | | 42 | AD3 | Address bus | | 43 | AD4<br>AD5 | Address bus | | 45 | AD6 | Address bus Address bus | | 46 | AD7 | | | 47 | GND | Address bus | | 48 | AD8 | GND<br>Address bus | | 49 | VGG | | | 50 | AD9 | VGG<br>Address bus | | 51 | AD10 | Address bus | | 52 | AD10 | Address bus | | 53 | AD12 | Address bus | | 54 | AD13 | Address bus | | 55 | AD14 | Address bus | | 56 | AD15 | Address bus | | 57 | NC NC | NC | | 58 | R/W | Memory read/write | | 59 | PO | Not used | | 60 | PV | Chip select | | 61 | PU | Chip select | | 62 | ♦OS | Clock which is in the same phase as the LSI internal clock | | 63 | XL0 | 2.6MHz oscillator input | | 64 | XL1 | 2.6MHz oscillator output | | 65 | WAIT | CPU WAIT signal | | 66 | IN7 | Key input port | | 67 | IN6 | Key input port | | 68 | IN5 | Key input port | | 69 | IN4 | Key input port | | 70 | IN3 | Key input port | | 71 | IN2 | Key input port | | 72 | IN1 | Key input port | | 73 | INO | Key input port | | 74 | NC NC | NC<br>NC | | 75 | NC NC | NC NC | | 76 | NC NC | NC NC | # 4-3-4. I/O PC When the pin No. 34 (ME0) of the I/O PC is connected with ME1 of the CPU, it will be accessed as the ME1 area. # ① PC-1500 I/O PC | Pin no. | Signal name | Description | |---------|-------------|------------------------------------------------------------------------------| | 1 | PA1 | Key strobe | | 2 | PA2 | Key strobe | | 3 | PA3 | Key strobe | | 4 | PA4 | Key strobe | | 5 | PA5 | Key strobe | | 6 | PA6 | Key strobe | | 7 | PA7 | Key strobe | | 8 | GND | GND | | 9 | PB0 | Not used | | 10 | PB1 | Not used | | 11 | PB2 | Serial data input from the cassette tape | | 12 | PB3 | VCC (export model), GND (domestic model) | | 13 | PB4 | GND | | 14 | PB5 | Timer control | | 15 | P86 | Timer control | | 16 | PB7 | ON key input | | 17 | Pφ | GND | | 18 | PC0 | Timer control | | 19 | PC1 | Timer control | | 20 | PC2 | Timer control | | 21 | PC3 | Timer control | | 22 | PC4 | Timer control | | 23 | PC5 | Timer control | | 24 | PC6 | Buzzer on/off control | | 25 | PC7 | Not used | | 26 | CS0 | Chip select (AD12) | | 27 | CS1 | Chip select (AD13) | | 28 | CS2 | Chip select | | 29 | RS0 | Chip select (AD0) | | 30 | RS1 | Chip select (AD1) | | 31 | RS2 | Chip select (AD2) | | 32 | RS3 | Chip select (AD3) | | 33 | R/W | Memory read/write | | 34 | ME0 | ME0 area designation | | 35 | ME1 | ME1 area designation | | 36 | W0 | WAIT condition input | | 37 | W1 | WAIT condition input | | 38 | GND | GND | | 39 | VCC | VCC | | 40 | DME0 | Chip select taking consideration of WAIT condition (assignment of ME0 area). | | 41 | DME1 | Chip select taking consideration of WAIT condition (assignment of ME1 area). | | 42 | WAIT | WAIT to CPU | | 43 | INT | Interrupt to CPU | | 44 | RESET | I/O port reset input | | 45 | IRQ | Interrupt input | | 46 | φOS | Basic clock input | | 47 | CL1 | CMT demodulation clock input | | 48 | SD1 | VCC level | | 49 | LC | Not used | | 50 | CLO | CMT signal | | 51 | SD0 | Serial data output to cassette tape | | 52 | D0 | Data bus | | 53 | D1 | Data bus | | 54 | D2 | Data bus | | 55 | D3 | Data bus | | 56 | D4 | Data bus | | 57 | D5 | Data bus | | 58 | D6 | Data bus | | 59 | D7 | Data bus | | | 40.0 | | # ② CE-150 I/O PC | Signal name | Description | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PA1 | Remote 0 control | | PA2 | Remote 0 control | | PA3 | Remote 1 control | | PA4 | Remote 1 control | | PA5 | Manual print mode assignment | | PA6 | Not used | | PA7 | Not used | | GND | GND | | PB0 | Pen ascending signal | | PB1 | Pen descending signal | | PB2 | Color detection | | PB3 | Not used | | PB4 | Not used | | | Not used | | | Low battery | | | Paper feed key input | | | Not used | | 10,040.5 | X motor control | | 174-27-7 | X motor control | | | X motor control | | | X motor control | | | Y motor control | | | | | | Y motor control | | | Y motor control | | | Y motor control | | | AD13 input/output | | | AD12 input/output | | The second secon | I/O port address designation | | | AD0 | | | AD1 | | 1141 | AD2 | | 100000000000000000000000000000000000000 | AD3 | | | Memory read/write | | | ME0 area designation | | | GND | | 7.7.9 | GND | | - | WAIT condition output | | GND | GND | | VCC | VCC | | DME0 | Not used | | DME1 | Not used | | WAIT | WAIT condition output | | INT | Interrupt request to CPU | | RESET | LH5811 reset | | IRQ | Interrupt request from external source | | ΦOS | Internal clock having the same phase as LSI | | CL1 | GND | | SD1 | GND | | | Not used | | CLO | Not used | | SD0 | Not used | | D0 | Data bus | | | Data bus | | D2 | Data bus | | | Data bus | | | Data bus | | | Data bus | | | Data bus | | 1 385 | | | D6 | Data bus | | | PA1 PA2 PA3 PA4 PA5 PA6 PA7 GND PB0 PB1 PB2 PB3 PB4 PB5 PB6 PB7 Pφ PC0 PC1 PC2 PC3 PC4 PC5 PC6 PC7 CS0 CS1 CS2 RS0 RS1 RS2 RS3 R/W ME0 ME1 W0 W1 GND VCC DME0 DME1 WAIT INT RESET IRQ ΦOS CL1 SD1 LC CL0 SD0 D0 D1 | # ③ CE-153 I/O PC | Pin no. | Signal name | Description | |---------|-------------|----------------------------------------------| | 1 | PA1 | Key input port | | 2 | PA2 | Key input port | | 3 | PA3 | Key input port | | 4 | PA4 | Key input port | | 5 | PA5 | Key input port | | 6 | PA6 | Key input port | | 7 | PA7 | Key input port | | 8 | GND | GND | | 9 | PB0 | Key input port | | 10 | PB1 | Key input port | | 11 | PB2 | Key strobe | | 12 | PB3 | Key strobe | | 13 | PB4 | Key strobe | | 14 | PB5 | Key strobe | | 15 | PB6 | Key strobe | | 16 | PB7 | Key strobe | | 17 | Ρφ | GND | | 18 | PC0 | Key strobe | | 19 | PC1 | Key strobe | | 20 | PC2 | Key strobe | | 21 | PC3 | Key strobe | | 22 | PC4 | Key strobe | | 23 | PC5 | Key strobe | | 24 | PC6 | Key strobe | | 25 | PC7 | Key strobe | | 26 | CS0 | AD15 | | 27 | CS1 | AD14 | | 28 | CS2 | AD13 | | 29 | RS0 | AD0 | | 30 | RS1 | AD1 | | 31 | RS2 | AD2 | | 32 | RS3 | AD3 | | 33 | R/W | Memory read/write | | 34 | ME0 | ME0 area designation | | 35 | ME1 | GND | | 36 | WO | GND | | 37 | W1 | GND | | | 71111 | ATTIVITY. | | 38 | GND | GND | | 39 | VCC . | VCC (4.70±0.02V) | | 40 | DME0 | Not used | | 41 | DME1 | Not used | | 42 | WAIT | WAIT condition | | 43 | INT | Not used | | 44 | RESET | Reset | | 45 | IRQ | GND | | 46 | Φos | Internal clock having the same phase as LSI. | | 47 | CL1 | GND | | 48 | SD1 | GND | | 49 | LC | Not used | | 50 | CL0 | Not used | | 51 | SD0 | Not used | | 52 | D0 | Data bus | | 53 | D1 | Data bus | | 54 | D2 | Data bus | | 55 | D3 | Data bus | | 56 | D4 | Data bus | | 57 | D5 | Data bus | | 58 | D6 | Data bus | | 59 | D7 | Data bus | | 60 | PA0 | Key input port | # **4** CE-158 I/O PC | Pin no. | Signal name | Description | | | |---------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 1 | PA1 | RS232C I/F send request | | | | 2 | PA2 | RS232C I/F ready to receive | | | | 3 | PA3 | RS232C I/F carrier detect | | | | 4 | PA4 | RS232C I/F data set ready | | | | 5 | PA5 | Low battery | | | | 6 | PA6 | Baud rate select | | | | 7 | PA7 | Baud rate select | | | | 8 | GND | GND | | | | 9 | PB0 | Centronics parallel I/F DATA 2 | | | | 10 | PB1 | Centronics parallel I/F DATA 3 | | | | 11 | PB2 | Centronics parallel I/F DATA 4 | | | | 12 | PB3 | Centronics parallel I/F DATA 5 | | | | 13 | PB4 | Gentronics parallel I/F DATA 6 | | | | 14 | PB5 | Centronics parallel I/F DATA 7 | | | | 15 | PB6 | Centronics parallel I/F DATA 8 | | | | 16 | PB7 | Centronics parallel I/F BUSY input | | | | 17 | Ρφ | GND | | | | 18 | PC0 | Baud rate select | | | | 19 | PC1 | Baud rate select | | | | 20 | PC2 | Baud rate select | | | | 21 | PC3 | Baud rate select | | | | 22 | PC4 | Baud rate select | | | | 23 | PC5 | Centronics parallel I/F DATA 1 | | | | 24 | PC6 | Centronics parallel I/F STROBE | | | | 25 | PC7 | Centronics parallel I/F INIT | | | | 26 | CS0 | VCC (4.70±0.02V) | | | | 27 | CS1 | VCC (4.70±0.02V) | | | | 28 | CS2 | GND | | | | 29 | RS0 | AD0 | | | | 30 | RS1 | AD1 | | | | 31 | RS2 | AD2 | | | | 32 | RS3 | AD3 | | | | 33 | R/W | Memory read/write | | | | 34 | MEO | | | | | 35 | ME1 | ME0 area designation GND | | | | 36 | WO | GND | | | | 37 | W1 | GND | | | | 38 | GND | GND | | | | 39 | | TO STATE OF THE PARTY PA | | | | 40 | VCC | VCC (4.70±0.02V) Not used | | | | | DME0 | | | | | 41 | DME1<br>WAIT | Not used | | | | 43 | | Not used Interrupt request to CPU | | | | 44 | INT | Introduction of the control c | | | | 45 | RESET | LH5811 reset | | | | 46 | ΦOS | Interrupt request | | | | 47 | | Internal clock having the same phase as LSI. GND | | | | | CL1 | 1 C 1 C 1 C 1 C 1 C 1 C 1 C 1 C 1 C 1 C | | | | 48 | SD1 | GND | | | | 49 | LC | Not used | | | | 50 | CL0 | Not used | | | | 51 | SD0 | Not used | | | | 52 | D0 | Data bus | | | | 53 | D1 | Data bus | | | | 54 | D2 | Data bus | | | | 55 | D3 | Data bus | | | | 56 | D4 | Data bus | | | | 57 | D5 | Data bus | | | | 58 | D6 | Data bus | | | | 59 | D7 | Data bus RS232C I/F terminal ready | | | # 4-4. Key matrix and key code chart # Key matrix # Key code chart | OW | 0 | 1 | 2 | 3 | 4 | 5 | |----|-------|------|-------|---|---|---| | 0 | | | SPACE | 0 | | Р | | 1 | SHIFT | F1 | | 1 | Α | Q | | 2 | SML | F2 | | 2 | В | R | | 3 | | F3 | | 3 | С | S | | 4 | | F4 | | 4 | D | Т | | 5 | | F5 | | 5 | Ε | U | | 6 | | F6 | | 6 | F | V | | 7 | | | | 7 | G | W | | 8 | 4 | CL | ( | 8 | Н | X | | 9 | \$ | RCL | ) | 9 | I | Y | | Α | 1 | | * | | J | Z | | В | 1 | DEF | + | | K | | | С | • | | | | L | | | D | ENTER | | _ | = | М | | | Ε | | | *: | | Ν | | | F | OFF | MODE | 1 | | 0 | | NOTE: For ON key, refer to "KEY SCAN" of "SYSTEM SUBROUTINE". 5 # PC-1500 software # 5-1. BASIC command related PC-1500 machine language In this section we will discuss the BASIC command related PC-1500 machine language. # 5-1-1. NEW # Format (PRO mode) # NEW - expression - # NEW expression (=0) Clears program and all data areas and secures the BASIC program area following to the reserve program area. | | Top of the BASIC program | |-----------------------------------------|--------------------------| | Operation of the PC-1500 only | 40C5H | | Operation in conjuction with the CE-155 | 38C5H | See (System memory) # ② NEW expression (≠0) Effective when there is no user ROM area. Clears BASIC program and all data areas and sets the BASIC program area from the address represented in the expression, which is valid within an address range of RAM area except the reserve area. #### ③ NEW Clears BASIC program and all data areas without affecting the BASIC program area. When executed in the reserve mode, it clears the reserve area. # 5-1-2. **STATUS** #### **Format** #### Status → expression → # ① STATUS 0 Similar to MEM, the sum of unoccupied memory size and data memory size is given in terms of bytes. #### ② STATUS 1 Size of the memory used for the BASIC program is given in terms of bytes. # **③ STATUS 2** The last BASIC program address plus one address (next to FFH) is given. #### **④ STATUS 3** The smallest address where data stored is given. #### STATUS 4 When BASIC program is in execution, the line number executed immediately before. When program execution is at halt, the current line number. In otherwise condition, "0". Same for STATUS 5 thru 255. NOTE: ROM information is 8 bytes and the reserve area is 189 bytes. # 5-1-3. PEEK #### **Format** PEEK ⊤ # ¬ expression → PEEK expression Recalls the data in ME0 area whose address is represented by the expression. PEEK # expression Recalls the data in the MEI area whose address is represented by the expression. # 5-1-4. POKE #### **Format** POKE + # + expression-1 - , - expression-i - ① POKE expression-1, expression-2, expression-3, ... Starting from the ME0 area address represented by the expression-1, it begins to store successive data in order of the expression-2, expression-3, ... - POKE # expression-1, expression-2, expression3, ... Starting from the MEI area address represented by the expression-1, it begins to store successive data in order of the expression-2, expression-3, ... CAUTION: Since the I/O port controller is in the ME1 area for the PC-1500, care must be taken not to have a wrong use of this command, as it may possibly result in destruction. (EX): POKE &4700, &01, &02, &03 | Address | Data | |---------|------| | 4700H | 01H | | 4701H | 02H | | 4703H | 03H | # 5-1-5. CALL #### **Format** CALL → expression ¬ · · · variable ¬ ## (1) CALL expression Machine language program starts to execute starting from address specified by the expression. Progam returns from the machine language routine by the command. #### ② CALL expression, variable - 1) When the variable is a numerical variable (within a range of -32768 thru 32767) - 1. The value of the variable is transferred to the Xreg. - Machine language program is executed from the starting address represented by the expression. - 3. If there is a carry when returns, the value of the Xreg is transferred to the variable. - 2) When the variable is a nonnumeric variable - The leading address of the nonnumeric variable is transferred to the Xreg and the size information of the nonnumeric variable is transferred to the accumulator. - Machine language program is executed from the starting address represented by the expression. - If there is a carry when returns, the character string whose size is indicated by the accumulator is transferred to the variable from the address represented by the Xreg. NOTE: It will result in ERROR 7 for a two-nonnumeric variable whose variable has not been defined. # 5-1-6. CSAVE M #### **Format** CSAVE M - -1 1 "file name"; - expression-1, expression-2 -, expression 3 - ① CSAVE M expression-1, expression-2, expression-3 Data residing from the address represented by the expression-1 to the address represented by the expression-2 is recorded on the tape as the machine language program. When the expression-3 is given, execution will automatically take place from the address represented by the expression-3 upon loading of the program from the tape. File name will also be recorded on the tape, when there is a file name. #### ② CSAVE M-1 Tape control will be set to the REMOTE-1 side. # 5-1-7. CLOAD M # Format CLOAD M T -1 T "file name"; T expression T #### ① CLOAD M The machine language program recorded on the tape is loaded into the same memory area as when recorded. When the expression is given, program load will take place from the address represented by the expression. If there have been the expression-3 during data save, program execution will automatically take place from the address represented by the expression-3 upon completion of program load. However, automatic execution will not start if the expression is given. #### ② CLOAD M-1 Tape control will be set to the REMOTE-1 side. # 5-2. Internal code chart With the PC-1500 system, BASIC command is converted into internal code of two bytes to be processed by the PC-1500 system. Shown next is the list of commands with corresponding internal codes. | COMMAND | INTERNAL CODE | |----------|---------------| | ABS | F170H | | ACS | F174H | | AND | F150H | | AREAD | F180H | | ARUN | F181H | | ASC | F160H | | ASN | F173H | | ATN | F175H | | BEEP | F182H | | BREAK | FOB3H | | | F18AH | | CALL | | | CHAIN | F O B 2 H | | CHR\$ | F163H | | CLEAR | F187H | | CLOAD | F089H | | CLS | F088H | | COM\$ | E 8 5 8 H | | CONSOLE | F O B 1 H | | CONT | F183H | | COLOR | F0B5H | | COS | F17EH | | CSAVE | F095H | | CSIZE | E 6-8 0 H | | CURSOR | F 0 8 4 H | | DATA | F18DH | | DEG | F165H | | DEGREE | F18CH | | DEV\$ | E 8 5 7 H | | DIM | F 1 8 B H | | DMS | F166H | | DTE | E 8 8 4 H | | END | F18EH | | | F 0 5 3 H | | ERL | F 0 5 2 H | | ERN | | | ERROR | F1B4H | | EXP | F178H | | FEED | FOBOH | | FOR | F1A5H | | GCURSOR | F 0 9 3 H | | GLCURSOR | E 6 8 2 H | | GOSUB | F194H | | GOTO | F 1 9 2 H | | GPRINT | F09FH | | GRAD | F186H | | GRAPH | E 6 8 1 H | | 1 F | F196H | | INKEY\$ | F15CH | | INPUT | F091H | | INSTAT | E859H | | | | | INT | F171H | | COMMAND | INTERNAL CODE | |----------|----------------| | LCURSOR | E 6 8 3 H | | LEFT\$ | F17AH | | LEN | F164H | | LET | F198H | | LF | F0B6H | | LINE | F0B7H | | LIST | F090H | | LLIST | F0B8H | | LN | F176H | | LOCK | F1B5H | | LOG | F177H | | LPRINT | F0B9H | | MEM | F 1 5 8 H | | MERGE | F08FH | | MID\$ | F17BH | | NEW | F19BH | | NEXT | F19AH | | NOT | F16DH | | OFF | F19EH | | ON | F19CH | | OPN | F19DH | | OR | F151H | | OUTSTAT | E 8 8 0 H | | PAUSE | F1A2H | | PEEK | F16FH | | PEEK# | F16EH<br>F15DH | | POINT | | | POKE | F168H | | POKE# | FIATH | | PRINT | F 0 9 7 H | | RADIAN | FIAAH | | RANDOM | F1A8H | | READ | F1A6H | | REM | FIABH | | RESTORE | F1A7H | | RETURN | F199H | | RIGHT\$ | F172H | | RINKEY\$ | E 8 5 A H | | RLINE | FOBAH | | RMT | E7A9H | | RND | F17CH | | ROTATE | E 6 8 5 H | | RUN | FIA4H | | 17.56.11 | 1.10111 | | COMMAND | INTERNAL CODE | |----------|---------------| | SETCOM | E 8 8 2 H | | SETDEV | E886H | | SGN | F179H | | SIN | F17DH | | SORGN | E 6 8 4 H | | SPACE\$ | F 0 6 1 H | | SQR | F16BH | | STATUS | F 1 6 7 H | | STEP | FIADH | | STOP | FIACH | | STR\$ | F161H | | TAB | FOBBH | | TAN | F17FH | | TERMINAL | E883H | | TEST | FOBCH | | TEXT | E 6 8 6 H | | THEN | FIAEH | | TIME | F15BH | | TO | F1B1H | | TRANSMIT | E 8 8 5 H | | TROFF | F1B0H | | TRON | FIAFH | | UNLOCK | F1B6H | | USING | F 0 8 5 H | | VAL | F 1 6 2 H | | WAIT | F1B3H | | ZONE | FOB4H | # 5-3. Expression of variable and program # 5-3-1. Expression of decimal number Decimal number consists of eight bytes which are used to represent number within a range of $-9.99999999 \times 10^{99}$ to $+9.999999999 \times 10^{99}$ and are composed of the exponent part, mantissa sign and mantissa part. | 7A00H | | | | | | 7A07H | | |-------|-------|-------|-------|-------|-------|---------|------------------| | 0 3 H | 0 0 H | 15H | 0 0 H | 0 0 H | 0 0 H | 00H 00H | 1500 | | 0 0 H | 0 0 H | 12H | 3 4 H | 5 6 H | 0 0 H | 00H 00H | 1.23456 | | FDH | 0 0 H | 1 2 H | 3 4 H | 5 6 H | 7 8 H | 90H 00H | 0.00123456789012 | | 0 8 H | 8 0 H | 12H | 3 4 H | 0 0 H | 0 0 H | 00H 00H | -1.234×10* | # 5-3-2. Expression of binary number Binary number consists of eight bytes, but five bytes are not used. It expresses a binary number within an integer range of -32768 thru +32767. # 5-3-3. Expression of character string Character string information is composed of eight bytes (with four bytes of valid data) and it resides in the address contained in the character string information. 53H S 48H н 41H 52H R 50H Р # 5-3-4. Structure of variable name Variable name field is made of two bytes which consists of variable name composed of ASCII character, distinction of numeric and nonnumeric variable, and presence of array assignment. # 5-3-5. Structure of program Each of program lines is composed of the line number, line size, program code, and end code. # 5-3-6. Structure of reserve area # ① Leading address of the reserve area | System configuration | Leading address | |----------------------|-----------------| | PC-1500 ONLY | 4000H | | PC-1500+CE-151 | 4000H | | PC-1500+CE-155 | 3800H | | PC-1500+CE-159 | 2000H | # ② Reserve memory configuration (when only the PC-1500 is used) | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | C | D | E | F | |-------|---|----|-----|------|-----|------|-------|-------|-----|------|------|------|------|------|-----|-----| | 400 | | | | | | | | | | | | | | | | | | 401 | | | Key | sy | mb | ol o | f th | e re | ser | ve r | num | ber | 1 ( | 26 t | yte | s) | | 402 | | | Ke | y sy | mb | ol ( | of th | ie r | ese | rve | nur | nbe | r II | (26 | by | tes | | 403 | | | | | | | | | | | | | Г | | | | | 404 | Г | Ke | y s | ymt | loc | of t | he r | ese | rve | nur | mbe | r II | (2 | 6 by | tes | ) | | 4 0 5 | | | | | | | Г | S | | | | - 0 | - 7 | | - | | | 406 | П | | The | co | nte | nts | of r | ese | ve | key | s ar | e s | ore | d ir | 'n | | | 407 | | | | | | ord | er c | of re | gis | trat | on | (11 | 1 b | ytes | ) | | | 4 0 8 | | | | | | | | | | | | | | | | | | 409 | | | | | | | | | | | | | | | | | | 4 0 A | | | | | | | | | | | | | | | | | | 4 0 B | | | | | | | | | | | | | | | | | | 4 0 C | | | | | | | M | ach | ine | lan | gua | ge | | 1 | | | | 4 0 D | | | | | | | or | 8 | | | | | | | | | | 4 0 E | | | | | | | B | ASI | Ср | rog | ram | j. 1 | | | | | | 4 0 F | | | | | | | | | | | | | | | | | NOTE: When NEW [NEW] is executed in the RESERVE mode, address area from 4008H to 40C4H is filled up with "00H". # 3 Reserve key code | Key RESERVE NO. | I | II | Ш | |-----------------|-------|-------|-------| | F 1 | 0 1 H | 11H | 0 9 H | | F 2 | 0 2 H | 12H | 0 A H | | F 3 | 0 3 H | 13H | 0 B H | | F4 | 0 4 H | 1 4 H | 0 C H | | F 5 | 0 5 H | 15H | 0 D H | | F 6 | 0 6 H | 16H | 0 E H | - Reserve key contents are stored following to the key code. - Reserve programs are stored in order of registration. In the case of re-registration, the previous program is deleted and the new program is added following to it. # 4 ROM status information | ADDRESS | DESCRIPTION | |---------------------|--------------------------------------------------------------------------------------------------------| | 1st Byte in the ROM | 55H | | 2nd Byte in the ROM | High order one byte of the ROM top address | | 3rd Byte in the ROM | High order one byte of the top address of the BASIC program assuming the ROM top address to be "0000H" | | 4th Byte in the ROM | Low order one byte of the top address of the BASIC program, assuming the ROM top address to be "0000H" | | 5th Byte in the ROM | Write the following code according to the ROM size 1KB:"04H" 2KB:"08H" 4KB:"10H" 8KB:"20H" 16KB:"40H" | | 6th Byte in the ROM | Undefined | | 7th Byte in the ROM | Undefined | | 8th Byte in the ROM | To inhibit "LLIST" command, write "00H" To effect "LLIST" command, write "FFH" | Note: The ROM address is 0000H~3FFFH. # (An example of registration) # Key symbol | Reserve No. [ | P | R | Ť | 1 | N | p | G | T | 0 | G | S | 8 | 8 | ε | T | | |---------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--| | Reserve No.II | s | 1 | N | c | 0 | s | 1 | A | N | П | | | Ī | | | | | Reserve No. 🗎 | R | U | N | G | T | 0 | | | П | | | | | | | | ## Reserve contents | Registration order | | Key | Registered contents | |--------------------|----|-----|---------------------| | 1 | Ι | F 1 | PRINT | | 2 | I | F 3 | GOTO | | 3 | I | F 2 | INPUT | | 4 | I | F 4 | GOSUB | | 5 | I | F 5 | RETURN | | 6 | II | F 1 | SIN | | 7 | II | F 3 | TAN | | 8 | Ш | F 2 | GOTO@ | | 9 | Ш | F 1 | RUN@ | | 10 | II | F 2 | cos | | High order | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | C | D | E | F | |------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | 400 | | | | | | | | | 20 | 50 | 52 | 54 | 20 | 49 | 4E | 50 | | 4 0 1 | 20 | 47 | 4F | 54 | 20 | 47 | 53 | 42 | 20 | 52 | 45 | 54 | 20 | 00 | 00 | 00 | | 402 | 00 | 00 | 20 | 53 | 49 | 4E | 20 | 43 | 4F | 53 | 20 | 54 | 41 | 4E | 20 | 00 | | 403 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 20 | 52 | 55 | 4E | | 404 | 20 | 47 | 54 | 4F | 20 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | 405 | 00 | 00 | 00 | 00 | 00 | 00 | 01 | F0 | 97 | 03 | FI | 92 | 02 | F0 | 91 | 04 | | 4 0 6 | FI | 94 | 05 | F1 | 99 | 11 | FI | 70 | 13 | F1 | 7F | 0A | FI | 92 | 40 | 09 | | 4 0 7 | F1 | A4 | 40 | 12 | F1 | 7E | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | 408 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | 409 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | 4 0 A | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | 4 0 B | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | 4 0 C | 00 | 00 | 00 | 00 | 00 | | | | | | | | | | | Г | | 4 0 D | | | | | | | | | | | | | | | | | | 4 0 E | | | | | | | | | | | | | | | | | | 40F | | | | | | | | | | | | | | | | | Characters are stored in form of character code and commands in form of internal code. "00H" is for the end code of data. # 5-4. System subroutines System subroutines used by the machine language program will be introduced next. However, care must be taken for printer related entry address for it differs depending on the ROM version of the CE-150. The version number will be indicated in the address A800H. | Version 0 | Address A800H is 44H. | | |-----------|-----------------------|--| | Version 1 | Address A800H is BEH. | | # (1) Character function | Combination of character | D925H | VAL | D9D7H | |--------------------------|-------|---------------------|-------| | CHRS | D9B1H | LEN, ASC | D9DDH | | STRS | D9CFH | RIGHTS, MIDS, LEFTS | D9F3H | # ② Arithmetic operations | Substract | EFB6H | 10n | F1D4H | DEG | F531H | |-----------|-------|-----|-------|-------------|-------| | Add | EFBAH | cos | F391H | DMS | F564H | | Multiply | F01AH | TAN | F39EH | ABS | F597H | | Divide | F084H | SIN | F3A2H | SGN | F59DH | | LN | F161H | ACS | F492H | INT | F5BEH | | LOG | F165H | ATN | F496H | Power raise | F89CH | | EXP | F1CBH | ASN | F49AH | | | ## ① Compare | Numerical comparison | D0D2H | Character string comparison | D0F9H | | |----------------------|-------|-----------------------------|-------|--| |----------------------|-------|-----------------------------|-------|--| ## 4 Search | Line number search | D2EAH | Variable search | D461H | |--------------------|-------|-----------------|-------| | KEY scan (I) | E42CH | KEY scan (II) | E243H | ## ⑤ Display | Auto-power-off | E33FH | One character display | ED57H | |--------------------------------|-------|--------------------------------------------|-------| | Program display | E8CAH | "n" character display | ED3BH | | Graphic display | EDEFH | Cursor move after one<br>character display | ED4DH | | Hexadecimal (2 bytes → 1 byte) | ED95H | Cursor move after "n" character display | ED00H | # 6 Printer related | Color designation | A519H(A4F7H) | Pen up/down | AAE3H(AABDH) | |---------------------|--------------|------------------|--------------| | Print | A781H(A75BH) | Motor drive | A8DDH(A8B7H) | | Linefeed | A9F1H(A9CBH) | Motor off | A769H(A747H) | | Paper feed | AA04H(A9DEH) | Get GRAPHIC mode | ABEFH(ABC6H) | | Get TEXT mode ready | ACBBH(AC8FH) | ready | | (Figures in parentheses indicate version 0.) # ⑦ Cassette tape | Remote on | BF11H | Header input/output | BCE8H | |--------------------|-------|---------------------|--------| | Remote off | BF43H | CMT I/O control | .BBF5H | | One character save | BDCCH | Create header | BBD6H | | One character load | BDF0H | Transfer file | BD3CH | # 5-4-1. Character functions #### Combination of character string Combination of character string-1 and character string-2 #### (1) ENTRY PREPARATION · Preparation of character strings Character string information of the character string-1 is stored in the arithmetic register (7A00H~7A07H). Character string information of the character string-2 is stored in the arithmetic register (7A10H~7A17H). 10H is stored in the string buffer pointer (7894H). ## **② ENTRY ADDRESS** D925H Subroutine is called in the following format: SJP (Address where PSH Xreg is written) DB DATA (Error return address) PSH Xreg PSH Yreg | Write in other addresses. JMP D925 #### (1) EXIT STATE · When no error Returns to the address next to the data. Resultant character string information will then be stored in the arithmetic register X (7A00H~7A07H) and the combined character strings will be stored in the string buffer (7B10H~). · When error After storing the error code in the UH register, it returns to the data stored address plus one. NOTE: For details of character string information, refer to the paragraph discussing the structure of variable and program. ### ■ CHRS #### (1) ENTRY PREPARATION Preparation of numeric value An integer of 0 thru 255 is stored in the arithmetic register (7A00H~7A07H) in decimal or binary figure. 10H is stored in the string buffer pointer (7894H). # **② ENTRY ADDRESS** D9B1H #### ③ EXIT STATE When no error UH = 00H | Address | Contents | |---------|------------| | 7A04H | C1H | | 7A05H | 7BH | | 7A06H | 10H | | 7A07H | 00H or 01H | | 7B10H | ASCII code | When ASCII code is 00H, the contents of 7A07H become 00H or 01H when other than 00H. When error UH ≠ 00H (Error code is stored in UH) #### ■ STRS #### 1) ENTRY PREPARATION - Number to be converted is stored in the arithmetic register (7A00H~7A07H) in decimal or binary figure. - 10H is stored in the string buffer pointer (7894H). ## **② ENTRY ADDRESS** D9CFH #### (3) EXIT STATE · When no error UH = 00H | Address | Data | |---------|-----------------------------------------------------------| | 7A04H | DOH | | 7A05H | Leading address of character string (high order one byte) | | 7A06H | Leading address of character string (low order one byte) | | 7A07H | Size of character string | For an actual character string, the string buffer (7B10H~7B5FH) can be used. · When error $UH \neq 00H$ (Error code will be stored in UH.) # ■ VAL #### 1 ENTRY PREPARATION Character string information to be converted is stored in the arithmetic register X (7A00H~7A07H) in character string format. #### **② ENTRY ADDRESS** D9D7H # **③ EXIT STATE** · When no error UH = 00H Result is stored in arithmetic register X (7A00H~7A07H) in decimal figure. · When error $UH \neq 00H$ (Error code will be stored in UH.) # ■ ASC, LEN #### (I) ENTRY PREPARATION Character string information to be converted is stored in the arithmetic register X (7A00H~7A07H). | Address | Data | |---------|-----------------------------------------------------------| | 7A04H | DOH | | 7A05H | Leading address of character string (high order one byte) | | 7A06H | Leading address of character string (low order one byte) | | 7A07H | Size of character string | Setup of function | Function | YL | |----------|-----| | ASC | 60H | | LEN | 64H | #### **② ENTRY ADDRESS** D9DDH #### (3) EXIT STATE When no error UH = 00H Result is stored in arithmetic reister X (7A00H ~ 7A07H) in decimal figure. When error UH≠ 00H (UH=error code) ■ RIGHTS (Character string, numeric value-1) LEFT\$ (Character string, numeric value-1) MID\$ (Character string, numeric value-2, numeric value-1) # **(1) ENTRY PREPARATION** Setup of function | Function | YL | |----------|-----| | RIGHTS | 02H | | LEFTS | 7AH | | MIDS | 7BH | - Existence of availability for 8 bytes in the BASIC stack (7A38H~7AFFH) is checked. - In the case of RIGHT\$, LEFT\$ (Data of 7890H) < (data of 7891H) 8</p> - In the case of MID\$ (Data of 7890H) < (data of 7891H) = 16</p> Since re-write of 7890H and 7891H is not permitted, it must be avoided to call this subroutine, unless the above condition is satisfied. ## • Change of the data pointer (7892H) | Function | Data | |----------|----------------------| | RIGHT\$ | (data of 7890H) + 8 | | LEFTS | | | MIDS | (data of 7890H) + 16 | #### Preparation of character string | Address | Data | | |---------------------|-----------------------------------------------------------|--| | (Data of 7890H) + 4 | D0H | | | (Data of 7890H) + 5 | Leading address of character string (high order one byte) | | | (Data of 7890H) + 6 | Leading address of character string (low order one byte) | | | (Data of 7890H) + 7 | Size of character string | | NOTE: High order byte of address is 7AH. For actual character string, the string, the string buffer (7B10H~7B5FH) can be used. # · Preparation of numerical data Numeric-1 is stored in 7A00H~7A07H in decimal or binary figure. (In the case of MID\$, the numeric-2 is stored from the address of "data of 7890H" plus eight to the address "data of 7890H" plus fifteen.) Stored in the above address in a decimal or binary format. # ② ENTRY ADDRESS D9F3H #### **③ EXIT STATE** When no error UH = 00H | Address | Data | |---------|-----------------------------------------------------------| | 7A04H | DOH | | 7A05H | Leading address of character string (high order one byte) | | 7A06H | Leading address of character string (low order one byte) | | 7A07H | Size of character string | For an actual character string, the string buffer (7B10H~7B5FH) can be used. #### · When error $UH \neq 00H$ (UH is substituted with error code.) NOTE: Stack of FOR Represented by the pointer (7890H) Stack of FOR Stack of GOSUB Represented by the pointer (7891H) # 5-4-2. Arithmetic subroutines # (I) ENTRY PREPARATION Preparation of numeric value Numeric value should be prepared in the arithmetic register X (7A00H~7A07H) and the arithmetic register Y (7A10H~7A17H). (In the case of a single variable, only the arithmetic register needs to be prepared. # **② ENTRY ADDRESS** | | Opera | ation | Address | |-------------------------|--------------------------------------|----------------------------|---------| | ı, | Add | $X + Y \rightarrow X$ | EFBAH | | Two-variable function | Subtract | $X-Y \rightarrow X$ | EFB6H | | able | Multiphy | X ★ Y → X | F01 AH | | func | Divide | X / Y → X | F084H | | 5 | Power raise | $X \wedge Y \rightarrow X$ | F89CH | | | | SQR X→ X | F0E9H | | | Square root | LN X → X | F161H | | | | LOG X → X | F165H | | | | EXP X→X | F1CBH | | | Logarithm | 10∧X → X | F1D4H | | m | | SIN X → X | F3A2H | | 000 | Trignometric function | COS X→ X | F391H | | -VBD | | TAN X→ X | F39EH | | 510 | 5 | ASN X→X | F49AH | | Single-vanable function | Inverse<br>trignometric<br>function | ACS X→X | F492H | | ä | | ATN X→ X | F496H | | | Degree to minute | DEG X→X | F531H | | | and<br>second conversion | DMS X→X | F564H | | | Absolute value | ABS → X | F597H | | | Sign | SGN X→ X | F59DH | | | Conversion into an<br>integer number | INT X→X | F5BEH | ## (3) EXIT STATE • Result will be stored in the arithmetic register X (7A00H~7A07H). # 5-4-3. Comparison # ■ Comparison of numeric (Numeric 1) ○ (numeric 2) O Indicates the operand. ## (1) ENTRY PREPARATION Setup of operand | Operand | Accumulator data | |---------|------------------| | <> | 00Н | | < | 01H | | > | 02H | | = | 04H | | <= | 05H | | >= | 06H | • The numeric is stored in the arithmetic register in a format of decimal figure. | Numeric 1 | Arithmetic register X (7A00H~7A07H) | |-----------|-------------------------------------| | Numeric 2 | Arithmetic register X (7A10H~7107H) | # **② ENTRY ADDRESS** D0D2H #### (3) EXIT STATE When the operand is established The flag Z is reset to "0" and the arithmetic register turns to "1". | 7A00H | | | | | | | 7A07H | |-------|-----|-----|-----|-----|-----|-----|-------| | 00H | 00H | 10H | 00H | 00H | 00H | 00H | ООН | · When the operand is not established The flag Z is set to "1" and the arithmetic register turns to "0". | 7A00H | | | | | | | 7A07H | | |-------|-----|-----|-----|-----|-----|-----|-------|--| | 00H | #### ■ Comparison of character string (Character string-1) (character string-2) Indicates the operand. # **① ENTRY PREPARATION** Designation of the operand | Operand | Accumulator data | |---------|------------------| | <> | 00Н | | < | 01H | | > | 02H | | - | 04H | Preparation of character string | Contents | Address | Character string-1 | Character<br>string-2 | |-----------------------|--------------|--------------------|-----------------------| | D0H | | 7A04H | 7A14H | | Leading address of | (high order) | 7A05H | 7A15H | | the character string | (low order) | 7A06H | 7A16H | | Size of the character | string | 7A07H | 7A17H | For the address where the character string is stored, the string buffer (7B10H~7B5FH) can be used. 10H is stored in the string buffer pointer (7894H). #### **② ENTRY ADDRESS** D0F9H # **③ EXIT STATE** • When the condition for the operand is established (Z=0) | 7A00H | | | | | | | | |-------|-----|-----|-----|-----|-----|-----|-----| | 00H | 00H | 10H | 00H | 00H | 00H | 00H | 00H | • When the condition for the operand is not established (Z=1) | 7A00H | | | | | | | | | | |-------|-----|-----|-----|-----|-----|-----|-----|--|--| | 00H | | # 5-4-4. Search # ■ Variable address search #### (I) ENTRY PREPARATION · Designation of variable name The variable name is stored in the Ureg. Whether array is one dimension or two dimension is stored in parameter F/F (788CH). one dimension: 01H two dimension: 02H Subscript is stored in the arithmetic register X (7A00H~7A07H). When one dimension array: the first subscript When two dimension array: the second subscript Subscript is stored in the arithmetic register Y (7A10H~7A17H). When one dimension array: No need When two dimension array: the first subscript #### ② ENTRY ADDRESS D461H · Subroutine must be called in the following format: SJP D461H DB FAH DB DATA .....(Decides the address to return when an error is met.) # ③ EXIT STATE · When no error The leading address of the variable is stored in the Ureg, and the variable name and the data size is stored in the arithmetic register X. Then, it returns to the address that follows DB DATA. | | 7A05H | 7A06H | 7A07H | | |-----|----------|-----------|---------------|---------------------| | - 3 | UH | UL | 10001000 | Numeric variable | | | UH | UL | 0XXXXXXX | Nonnumeric variable | | | Leading | g address | Size secure | d | | | of varia | | for the varia | ible | · When error Returns to the address that data plus one is added to the "data written address" after storing the error code is stored in UH. ### Key scan (I) - (1) ENTRY PREPARATION - None - ② ENTRY ADDRESS E42CH - **③ EXIT STATE** - The key code of the key that depressed at that time is stored in the accumulator. If there is no key depression, "00H" will be stored in the accumulator. - Key scan (II) - ① ENTRY PREPARATION - None - ② ENTRY ADDRESS E243H - **③ EXIT STATE** - The key code of newly depressed key is stored in the accumulator. Although it does not return until a next key is depressed, it may end in auto-power-off unless a key is depressed within seven minutes. (However, the previous state resumes with depression of the ON key. When the ON key is pushed, PB7 of the PC-1500 IF register (#F00BH) will be set. NOTE: So long as PB7 of the address #F00BH is set, "0EH" will be stored in the accumulator. PB7 of the address #F00BH will be reset when "ANI #F00BH, FDH" is executed. # Search of program line ## 1 ENTRY PREPARATION Line number is stored in the Ureg (0001H ≤ Ureg ≤ FFFFH). ## ② ENTRY ADDRESS #### D2EAH Subroutine is called in the following format: SJP D2EAH DB DATA #### **③ EXIT STATE** When the specified line is found Returns to the address that follows DB DATA after storing the data in SEARCH (78A6H~78ABH). | | Service and the th | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 78A6H | Leading address of the line | | 78A7H | Leading address of the line | | 78A8H | Line number | | 78A9H | Line number | | 78AAH | Leading address of the line plus 3 | | 78ABH | Leading address of the line plus 3 | | | | When the specified line is not found Returns to the "data written address" plus one after storing the error code in UH. | Carry | Condition | |-------|-------------------------------------------------------------------------| | 0 | No specified line found, and search is made to the last of the program. | | 1 | Found the line larger than the specified line. | # 5-4-5. Display #### One character display ## ENTRY PREPARATION - Display start position is stored in the cursor pointer (7875H). Cursor will be effective within a range of 00H to 98H. - Code of display character is stored in the accumulator. ## **② ENTRY ADDRESS** ED57H #### **③ EXIT STATE** - No change takes place in the cursor pointer. - Change will be met in carry depending on the cursor called. | Cursor | Carry | |---------|-------| | 00H~95H | 0 | | 96H~9BH | 1 | One character will be displayed on LCD. # ■ Moving cursor after displaying one character #### (1) ENTRY PREPARATION - Display start position is stored in the cursor pointer (7875H). Cursor will be effective within a range of 00H to 98H. - · Code of display character is stored in the accumulator. # **② ENTRY ADDRESS** ED4DH 3 Change will be met in the cursor pointer. | Cursor position when called | Cursor position after return | |-----------------------------|------------------------------| | 00H~95H | Previous cursor position +6 | | 96H~9BH | 00Н | One character will be displayed on LCD. ## Auto-power-off ## **(1) ENTRY PREPARATION** None #### **② ENTRY ADDRESS** E33FH # **③ EXIT STATE** - When power is turned on once after auto-power-off, no printer initialization takes place. - When power is turned on by means of the N key once after auto-power-off, it needs to push any key, except SHFT, SML, and DEF key, as subroutine is in execution. Note: An example of manual operation # Example of manual operation | Key operation | Display | |-----------------------------------------|---------------------| | CALL & E33F | CALL & E33F | | (ENTER) | (OFF state) | | (ON) | BUSY<br>CALL & E33F | | Any key except [SHFT], [SML], and [DEF] | > | #### "n" character display ## ① ENTRY PREPARATION - Display start position is stored in the cursor pointer (7875H). - Size of the character string is stored in the accumulator (01H≤ACC≤1AH). - Leading address of the character string is stored in the Ureg (0000H ≤ Ureg ≤ FFFFH). #### ② ENTRY ADDRESS ED00H #### **③ EXIT STATE** Change will be met in carry. | Carry | Cursor position | |-------|-------------------------------------------------------------------------------------------------------------| | 0 | Next to the rightmost position of the character string on display. | | 1 | Indicates the last character on the display, in case display should end at 26th digit or exceed 26th digit. | NOTE: When display exceeds 156 dots, the contents after this dot position will be ignored. #### Output of "n" characters from the top of LCD "n" characters will be displayed unconditionally from the left side of LCD. #### 1 ENTRY PREPARATION - The leading address of the character string is stored in the Ureg (0000H≤Ureg≤FFFFH). - Size of the character string is stored in XL (01H ≤ Xreg ≤ 1AH). #### ② ENTRY ADDRESS ED3BH #### ③ EXIT STATE · Change will be met in carry. | Carry | Contents | | | | |-------|-------------------------------------------|--|--|--| | 0 | Character string within 25 characters. | | | | | 1 | Character string more than 26 characters. | | | | #### ■ Hexadecimal (2 byte - 1 byte) ASCII code of two bytes is assumed to be a hexidecimal figure and is changed into numeric of one byte. #### (1) ENTRY PREPARATION Leading address of the ASCII code is stored in the Xreg. # **② ENTRY ADDRESS** ED95H # **③ EXIT STATE** - In Xreg is stored the value of previous Xreg added with 02H. - The one byte of the derived data is stored in the accumulator. # Graphic display ## **(1) ENTRY PREPARATION** · Output pattern is stored in the accumulator. #### **② ENTRY ADDRESS** **EDEFH** ## **③ EXIT STATE** - · Contents of Xreg, Ureg, and accumulator become irrelevant. - · No change takes place in the cursor position. #### (Reference) #### Program display # **(1) ENTRY PREPARATION** A. In the case of numeric Data is stored in the arithmetic register (7A00H~7A07H). B. In the case of character string or program Data is stored in the input buffer (7BB0H~7BFFH). Cursor position is stored in Yreg. (In the case of program, 7BH is stored in YH.) C. Parameter F/F (7880H) is set. | Data of 7880H | Display contents | | |---------------|-------------------------------------------------------------------------------|--| | 40H | Character string is displayed according to Yreg. | | | 00H | Character string is displayed from the top, regardless of Yreg contents. | | | 20H | Numerical value of the arithmetic register X is displayed. | | | 10H | Line number, space, and program are displayed from the top | | | 14H | Line number, colon, and program are displayed from the top. | | | 50H | Line number and space are displayed in a middle of program according to Yreg. | | | 54H | Line number and colon are displayed in a middle of program according to Yreg. | | # **② ENTRY ADDRESS** E8CAH #### (3) EXIT STATE Displayed on LCD according to direction. NOTES: 1. In the case of an internal code, the cursor must show the code position on the lower side of 2 bytes. - Numeric is displayed in right justified manner and character string in left justified manner. - 3. Numeric has no concern with USING. - 4. Only 26 characters will be handled for a character string exceeding 26 characters. - 5. 0DH is required at the end of character string for the input buffer. # 5-4-6. Printer # ■Color designation. #### (I) ENTRY PREPARATION The specified color code (0~3) is stored in the UL. #### ② ENTRY ADDRESS A519H (A4F7H for the version 0.) #### ③ EXIT STATE Return with the motor on. (Motor off routine must be called after EXIT.) | (EX) | LDI | UL, color code | |------|-----|----------------| | | SJP | A519H | | | SJP | A769H | | | RTN | | #### ■ Motor drive #### (1) ENTRY PREPARATION Set the address pointer in the Xreg to indicate the value of relative movement, then store the value of relative movement after that address pointer. | Address shown by Xreg | ΔXH: High order 8 bits of the relative movement value towards the X direction. | | | |-------------------------|-----------------------------------------------------------------------------------|--|--| | Address shown by Xreg+1 | AYH: High order 8 bits of the relative movement value<br>towards the Y direction. | | | | Address shown by Xreg+2 | ΔXL: Low order 8 bits of the relative movement value towards the X direction. | | | | Address shown by Xreg+2 | ΔYL: Low order 8 bits of the relative movement value<br>towards the Y direction. | | | #### ② ENTRY ADDRESS A8DDH (A8B7H for the version 0.) ## **③ EXIT STATE** • The motor is on. (Motor off routine must be called after EXIT.) NOTE: Negative movement must be indicated by a complement. Relative movement must be within a range of -32768 thru 32767. #### ■ Motor off # (1) ENTRY PREPARATION None # **② ENTRY ADDRESS** A769H (A747H for the version 0.) #### **③ EXIT STATE** Motor off # ■ Pen up/down ## **(1) ENTRY PREPARATION** Either 00H or FFH is stored in the PEN UP/DOWN F/F (79E9H). | UP | 00H | |------|-----| | DOWN | FFH | #### ② ENTRY ADDRESS AAE3H (AABDH for the version 0.) #### **③ EXIT STATE** Pen ascends or descends then solenoid turn inactive. # ■ GRAPHIC mode preapration ## (1) ENTRY PREPARATION None ## **② ENTRY ADDRESS** ABEFH (ABC6H for the version 0.) #### ③ EXIT STATE | Line (79EAH) | 00H | |----------------------------|-----| | Rotate (79F2H) | 00H | | User counter (79E0H~79E3H) | 00H | #### NOTES: - 1. Because G/T (79F0H) is not changed, it needs to store FFH in G/T (79F0H) after return. - 2. CSIZE does not change. - 3. Scissoring counter does not change. #### ■ TEXT mode preparation # **(1) ENTRY PREPARATION** None ## ② ENTRY ADDRESS ACBBH (ACBFH for the version 0.) #### ③ EXIT STATE | Line (79EAH) | 00H | |----------------|-----| | G/T (79F0H) | 00H | | Rotate (79F2H) | 00H | #### NOTES: - When the scissoring counter YH and YL (79E4H~79E5H) exceeds 0200H, it makes 79E4H turned to 01H and 79E5H to FFH. When (79E4H~79E5H) is below 01FFH, it causes no change in 79E4H and 79E5H. - 2. CSIZE does not change. #### Paper feed ## (1) ENTRY PREPARATION Paper feed count is stored in the address represented by the Xreg. (Negative number is indicated by a complement.) # **② ENTRY ADDRESS** AA04H (A9DEH for the version 0.) #### ③ EXIT STATE • The motor stays on. (Motor off routine must be called after EXIT.) NOTE: Paper feed count may change after setting the CSIZE. #### Linefeed # (1) ENTRY PREPARATION - Line kind (79EAH) must be reset to 0. - Address area that can be destructed should be stored in Xreg. (X-10 ~ X+1 will be destructed.) ## ② ENTRY ADDRESS A9F1H (A9CBH for the version 0.) #### (3) EXIT STATE • The motor stays on. (Motor off routine must be called after EXIT.) #### NOTES: - 1. When the contents of Xreg is 7A22H, data in 7A18H thru 7A23H will be destructed. - 2. Paper feed count changes after CSIZE. #### Print #### (1) ENTRY PREPARATION - 00H is stored in LINE TYPE (79EAH). - Print code storing address must be stored in the Xreg. (When 7A20H is stored in Xreg, it affects the data in 7A08H thru 7A37H. So, care must be exerted not to destruct address area of the Xreg represented address minus ten and plus one. - Print code is stored in the address represented by the Xreg. ### ② ENTRY ADDRESS A781H (A75BH for the version 0.) #### ③ EXIT STATE - · Stays on. - The value of 6×CSIZE will be added to the contents of CURSOR (79E6H). (Motor off routine must be called after EXIT.) # 5-4-7. Cassette tape #### ■ REMOTE ON #### (1) ENTRY PREPARATION • Sets the PARAMETER F/F (7879H). | Contents of 7879H | Remote | CMT input port | |-------------------|--------|----------------| | 0XX0XXX | 0 | Close | | 0XX1XXXX | 1 | (CMT output) | | 1XX0XXXX | 0 | Open | | 1XX1XXXX | 1 | (CMT input) | #### ② ENTRY ADDRESS BF11H ## **③ EXIT STATE** REMOTE 0 or 1 turns active according to the contents of the PARAMETER F/F (7879H). NOTE: This system subroutine drives the relay in the CE-150, regardless of the REMOTE switch position. #### **■ REMOTE OFF** #### (I) ENTRY PREPARATION RMT/BEEP (786BH) must be set to control REMOTE 1. (Preparation is not required in the case of REMOTE 0. | Contents of 786BH | Remote | |-------------------|--------| | OXXXXXX | OFF | | 1XXXXXXX | ON | # **② ENTRY ADDRESS** BF43H ## ③ EXIT STATE - · REMOTE 0 is off. - REMOTE 1 will be in accordance with RMT/BEEP (786BH). NOTE: This system subroutine drives the relay in the CE-150, regardless of the REMOTE switch position. #### Save of one character ## (1) ENTRY PREPARATION · Data is stored in the accumulator. # **② ENTRY ADDRESS** **BDCCH** # ③ EXIT STATE · None. NOTE: This system call must be executed after saving of the synchronizing header. #### ■ Load of one character - (1) ENTRY PREPARATION - None - ② ENTRY ADDRESS **BDF0H** #### (1) EXIT STATE - Data has been sent in the accumulator. - Change takes place in carry. | Carry | Condition | | |-------|--------------------------------|--| | 0 | End of data read. | | | 1 | Depression of the [BREAK] key. | | #### Creation of header #### (1) ENTRY PREPARATION · File mode is set in the accumulator. | File mode | Contents | |-----------|------------------| | 00H | Machine language | | 01H | BASIC program | | 02H | Reserve | | 04H | Data | Use another code to avoid confusion, as the file mode for other than PC-1500 is used. • File name is stored in 7B69H~7B78H of the output buffer. #### (2) ENTRY ADDRESS BBD6H #### (3) EXIT STATE • Header is established in 7B60H~7B87H of the output buffer. | Address | Contents | |-------------|----------------------| | 7B60H~7B67H | Synchronizing header | | 7B68H | File mode | | 7B69H~7B78H | File name | | 7B79H~7B87H | All 00H | #### ■ Header input/output #### (I) ENTRY PREPARATION Parameter F/F (7879H) is set. | Contents of 7879H | In/Out | Remote | | |-------------------|--------|--------|--| | 0XX0XXX | 0.4 | 0 side | | | 0XX1XXXX | Out | 1 side | | | 1XX0XXXX | 10 | 0 side | | | 1XX1XXXX | In | 1 side | | RMT/BEEP (786BH) is set. | Contents of 786BH | BEEP | |-------------------|------| | XXXXXXX0 | OFF | | XXXXXXX1 | ON | · Header is created in the case of output. #### **② ENTRY ADDRESS** BCE8H #### ③ EXIT STATE · Carry changes. | Carry | Condition | |-------|--------------------| | 0 | Broken in a middle | | 1 | Input is complete. | · In the case of input The read data is stored in the output buffer of 7B91H~7BAFH. · In the case of output Stop bit modulation signal stays on. NOTES: 1. BEEP will be in accordance with 786BH. - 2. Paper feed operation stays prohibited for the CE-150. - In the case of input, the file name coincident of the header and file mode is displayed on the LCD. In case the file name is specified, it is searched until found. #### File transfer #### **(1) ENTRY PREPARATION** 1) Parameter F/F (7879H) is set. | 7879H | Contents | | |----------|-----------------------------|--| | 00XXXXXX | In the case of load | | | 01XXXXXX | In the case of verification | | | OXXXXXXX | In the case of save | | - 2) Leading address of input/output data is stored in the Xreg. - 3) Byte count of the data minus one is stored in the Ureg. #### **② ENTRY ADDRESS** BD3CH #### **③ EXIT STATE** In the case of save (Carry changes) | Carry | Condition Broken in a middle. | | |-------|--------------------------------|--| | 1 | | | | 0 | Input/output is complete | | #### ■ Termination of CMT I/O control #### (1) ENTRY PREPARATION Parameter F/F (7879H) is set. | Contents of 7879H | Data input/output | | |-------------------|-------------------|--| | 1XXXXXXX | Input | | | 0XXXXXXX | Output | | #### **② ENTRY ADDRESS** BBF5H #### **③ EXIT STATE** - · Serial port is reset. - PAPER FEED key of the CE-150 becomes operative. - · Motor drive turns off. - · In the case of load Change is met in carry, H, and V. | Carry | Н | ٧ | State | |-------|---|---|---------------------------------------| | 0 | - | - | Load and verification are complete. | | 1 | 1 | 2 | In break state. | | 1 | 0 | 1 | Error occurrence during verification. | | 1 | 0 | 0 | Occurrence of check sum error. | NOTE: The last transfer "address plus one" is stored in the Xreg. ### 5-4-8. Caution for system subroutine call #### 1. Printer related system call Although the error code is put on the display when an error such as low battery occurred during execution of printer related system subroutine, it is not possible to check the error line using the [f] key. 6 # Machine language programming examples \*Machine language program discussed is assumed to start from the address 40C5H. ## 6-1. Binary to hexadecimal conversion The binary number stored in the Xreg is converted into hexadecimal equivalent and stored in the fixed nonnumeric variable Y\$. Binary number within a range of -32769 < a < 32768 is applicable. | DDRESS | MACHINE LANGUAGE | | MNEMONIC | |--------|------------------|------------|------------| | 40C5 | 68 77 | | LDI UH 77H | | 7 | 6A E0 | | LDI UL E0H | | 9 | 84 | | LDA XH | | Α | BE 40 E0 | | SJP ① | | D | 61 | | SIN U | | E | 84 | | LDA XH | | F | BE 40 E1 | | SJP ② | | D2 | 61 | TWAY | SIN U | | 3 | 04 | 1/0/ | LDA XL | | 4 | BE 40 E0 | | SJP ① | | 7 | 61 | | SIN U | | 8 | 04 | | LDA XL | | 9 | BE 40 E1 | 9 11 11 11 | SJP (2) | | С | 61 | | SIN U | | D | 69 00 | | ANI U, OOH | | F | 9A | | RTN | | EO | F1 | ① | AEX | | 1 | B9 OF | (2) | ANI A, OFH | | 3 | B7 OA | | CPI A, OAH | | 5 | 83 03 | | BCS ③ | | 7 | B3 30 | | ADI A, 30H | | 9 | 9A | | RTN | | A | B3 36 | (3) | ADI A, 30H | | С | 9A | | RTN | # 6-2. Display inversion The current display contents are inverted. | ADDRESS | MACHINE LANGUAGE | MNEMONIC | |---------|------------------|-------------| | 40C5 | 68 78 | LDI UH, 78H | | 7 | 6A 4D | LDI UL 4DH | | 9 | FD 62 | DEC UH | | В | 25 | LDA U | | С | BD FF | EAI FFH | | E | 2E | STA U | | F | 88 06 | LOP 06H | | D1 | 6C 77 | CPI UH, 77H | | 3 | 93 OE | BCS 0EH | | 5 | 9A | RTN | # 6-3. Single display dot left shift The current display contents are shifted to the left by one dot position. | DDRESS | MACHINE LANGUAGE | MNEMONIC | | |--------|------------------|----------|-------------| | 40C5 | FD 88 | | PSH X | | 7 | FD 98 | | PSH Y | | 9 | FD A8 | | PSH U | | В | A5 76 00 | | LDA 7600H | | E | F1 | | AEX | | F | B9 OF | | ANI A, OFH | | D1 | 0A | | STA XL | | 2 | A5 76 01 | | LDA 7601H | | 5 | F1 | | AEX | | 6 | B9 OF | | ANI A, OFH | | 8 | 08 | | STA XH | | 9 | 68 78 | | LDI UH, 78H | | В | FD 62 | 1 | DEC UH | | D | 6A 4D | TWAY. | LDI UL, 4DH | | F | 66 | (2) | DEC U | | EO | 65 | | LIN U | | 1 | 1A | | STA YL | | 2 | 25 | | LDA U | | 3 | 18 | | STA YH | | 4 | 84 | | LDA XH | | 5 | 63 | | SDE U | | 6 | 04 | | LDA XL | | 7 | 2E | | STA U | | 8 | FD 18 | | LDX Y | | Α | 88 OD | | LOP (2) | | С | 6C 77 | | CPI UH, 77H | | E | 93 15 | | BCS ① | | FO | 04 | | LDA XL | | 1 | F1 | | AEX | | 2 | AE 77 4E | | STA 774EH | | 5 | 84 | | LDA XH | | 6 | F1 | | AEX | | 7 | AE 77 4F | | STA 774FH | | Α | FD 2A | | POP U | | С | FD 1A | | POP Y | | E | FD OA | | POP X | | 4100 | F9 | | REC | | 1 | 9A | | RTN | # 6-4. Single display dot right shift The current display contents are shifted to the right by one dot position. | DDRESS | MACHINE LANGUAGE | MNEMONIC | |--------|------------------|-------------| | 40C5 | FD 88 | PSH X | | 7 | FD 98 | PSH Y | | 9 | FD A8 | PSH U | | В | A5 77 4C | LDA 774CH | | E | F1 | AEX | | F | B9 F0 | ANI A, FOH | | D1 | OA | STA XL | | 2 | A5 77 4D | LDA 774DH | | 5 | F1 | AEX | | 6 | B9 F0 | ANI A FOH | | 8 | 08 | STA XH | | 9 | 68 75 | LDI UH, 75H | | В | 6A FF | LDI UL, FFH | | D | 64 | INC U | | E | 65 | LIN U | | F | 1A | STA YL | | EO | 25 | LDA U | | 1 | 18 | STA YH | | 2 | 84 | LDA XH | | 3 | 63 | SDE U | | 4 | 04 | LDA XL | | 5 | 61 | SIN U | | 6 | FD 18 | LDX Y | | 8 | 6E 4D | CPI UL, 4DH | | A | 91 OF | BCR,-OFH | | С | 6C 77 | CPI UH, 77H | | E | 91 15 | BCR, - 15H | | FO | 64 | INC U | | 1 | 04 | LDA XL | | 2 | F1 | AEX | | 3 | 61 | SIN U | | 4 | 84 | LDA XH | | 5 | F1 | AEX | | 6 | 2E | STA U | | 7 | FD 2A | POP U | | 9 | FD 1A | POP Y | | В | FD OA | POP X | | D | F9 | REC | | E | 9A | RTN | # 6-5. Conversion of USING format expressed numerical data into character string #### (I) ENTRY PREPARATION Numeric data is stored in the fixed numeric variable A in decimal figure and the format is specified by means of the USING statement. (Format is within 16 characters and no error is detected during conversion.) - ② ENTRY ADDRESS 40C5H - **③ EXIT STATE** - Character string is stored in the fixed nonnumeric variable A\$. However, A\$ can be anything when in error. #### (4) PROGRAM | ADDRESS | MACHINE LANGUAGE | MNEMONIC | |---------|------------------|--------------| | 40C5 | 48 79 | LDI XH, 79H | | 7 | 4A 00 | LDI, OOH | | 9 | 58 7A | LDI YH, 7AH | | В | BE F7 3F | SJP F73FH | | E | B5 01 | LDI A, O1H | | DO | CD 96 | VMJ 96H | | 2 | DF | DEC A | | 3 | 2A | STA UL | | 4 | 58 78 | LDI YH | | 6 | 5A CO | LDI YL | | 8 | F5 | TIN | | 9 | 88 03 | LOP 03H | | В | 14 | LDA YL | | С | B9 OF | ANI A, OFH | | E | 8B 02 | BZS. +02H | | EO | 59 00 | ANI (Y), 00H | | 2 | 9A | RTN | # 6-6. Power off that does not activate the printer upon power on With the following program, the printer will not be activated when power is turned on after power was turned off, the same manner as in the case of OFF to ON. | ADDRESS | MACHINE LANGUAGE | MNEMONIC | | |---------|------------------|----------------|--| | 40C5 | AA 78 4F | LDI S, 784FH | | | 8 | BE CF CC | SJP CFCCH | | | В | BE DO 2B | SJP D02BH | | | E | B5 3E | LDI A, 3EH | | | D0 | 1E | STA Y | | | 1 | E9 78 8A EF | ANI 788AH, EFH | | | 5 | E9 76 4E FE | ANI 764EH, FEH | | | 9 | B5 00 | LDI A, OOH | | | В | AE 78 80 | STA 7880H | | | E | AE 78 9C | STA 789CH | | | E1 | AE 78 9D | STA 789DH | | | 4 | BE E8 CA | SJP E8CAH | | | 7 | 48 CA | LDI XH, CAH | | | 9 | 4A 92 | LDI XL, 92H | | | В | FD 88 | PSH X | | | D | BA E3 3F | JMP E33FH | | # Determining printing character size and direction - Specifying printing character size Print character size (1~9) must be stored in the character size memory (79F4H). - Specifying printing direction Print direction (0~3) must be stored in the print direction memory (79F2H). ## 2. Restoration of array and two-character variable - Array variable and two-character variable that cleared by means of RUN operation or CLEAR command can be restored by operating the variable pointer (7899H, 789AH). Number of bytes dominated by the array variable and two-character variable should be deducted from the last address of the free area, then store it in the variable pointer. - · How to store Assume now "x" is the number that the byte count of array and two-character variable deducted from the last address of the free area. $$a = x / 256$$ $$b = x - 256 * a$$ Where, a: High order two digits when x is displayed in hexadecimal figure. b: Low order two digits when x is displayed in hexadecimal figure. Whereas, store a in the variable pointer 7899H and b in 789AH. · Last address of the free area | System configuration | Address | | |----------------------|---------|--| | PC-1500 only | 4800H | | | PC-1500 + CE-151 | 5800H | | | PC-1500 + CE-155 | 6000H | | | PC-1500 + CE-159 | 4800H | | Number of bytes used for the array and two-character variable Numeric array variable: 7 bytes + 8 bytes ★ size of array Nonnumeric array variable: 7 bytes + character length ★ size of array (Character size is normally 16 characters.) Numeric two-character variable: 7 bytes + 8 bytes Character two-character variable: 7 bytes + 16 bytes ### 3. Knowing the use of CE-150 Because the system program ROM of the CE-150 resides in the CE-150, FFH will be read when a ME0 address range of A000H thru BFFFH is accessed with the CE-150 not connected to the PC-1500. If connected, the contents of A000H will fetch C0H. NOTE: PV must be reset. #### 4. CMT format CMT FORMAT-1 INFORMATION FILE LEADER OBJECT FILE DATA : 1026ms -8.01 sec - 2981ms OTHER: 260ms BLANK 10 11 12 13 14 15 16 17 00 00 00 00 00 00 00 00 00 BLANK HEADER MODE FILE NAME NULL DADRS **JADRS** SIZE 16 (8 BYTE) 32 (16BYTE) 18 (9 BYTE) CSUM RMT ON MACHINE : TRANSFER ADDRESS AFTER LOADING DATA MACHINE : 00 PROGRAM: PROGRAM: 01 RESERVE : 0000 RESERVE: 02 DATA DATA : 04 MACHINE : PROGRAM: DATA(BYTE)-1 RESERVE : DATA 0000 OBJECT FILE STARTING ADDRESS IN CLOAD M TEXT BLANK MACHINE PROGRAM FILE END RESERVE REMAINED CSUM 160(80BYTE) CSUM CSUM CSUM 160(80BYTE) DATA 1st DATA UNIT DATA CSUM -252ms ---DATA STATUS 3rd~ BLANK DATA FILE BLANK BLANK 2nd DATA UNIT BLANK DATA UNIT <−1026ms → -1026ms -> - 262ms -FILE END DATA UNIT DATA FILE VARIABLES [A, B...] VARIABLE DATA 8 DIM( ★ , ★ ) STRING DATA 16 STRINGS [A\$, B\$...] 00 13 00 00 10 00 23 DIM( 🖈 ) A: DATA SIZE(BYTE)+3 @(X) 208 @(\*) B: FIRST ELEMENT DATA @\$(X) 416 C: SECOND ELEMENT UNIT @\$(X) B C DIMENSIONING VARIABLES D: VARIABLES: 88 $[B+1]\times[C+1]\times8$ DIMENSIONING STRINGS : LENGTH OF STRING VARIABLES[A(\*)...] DIMENSIONING STRINGS DIMENSIONING [B+1]×[C+1]×[THE LENGTH OF STRING WITHIN THE ARRAY] STRINGS[A\$(\*)...] # 5. Circuit diagram Circuitry subject to change without notice. Do not sell this PDF !!! LH-5811 ( See key code chart ) TC40H000F Dent ourespe 154 4(PBL) ■ FCT ■ GND X 4 ■ VBAT X 4 ■ VCC X 4 ■ F GND X 2 155 5 - 3 CE-151 5 - 4 CE-153 5 - 5 CE-155 #### MEMORY MAP when the CE-161 is used. (FOR PC-1500) #### MEMORY MAP when the CE-161 is used. (FOR PC-1500A) 5 - 7 CE- 159 5-8 #### MEMORY MAP when the CE-161 is used. (FOR PC-1500) #### MEMORY MAP when the CE-161 is used. (FOR PC-1500A) ### **ADDENDUM** # Differences between the PC-1500A and the PC-1500 Take notice of these differences when you use the machine language for the PC-1500A. | Page | PC-1500 | PC-1500A | | | |------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 89 | Chip select decoder and it is used to select chip by means of S0∼4, S6, S7, 2Y2 and 2Y3. | Chip select decoder and it is used to select chip by means of S0∼7, 2Y2 and 2Y3 | | | | | ① System RAM | ① System RAM | | | | | Because the 4-bit×1K bytes TC5514 is used in a pair, the data bus is divided into two of D0~D3 and D4~D7 and the select signal S7 is | | | | | | commonly shared so as to be compatible with the 8-bit RAM. | | | | | | Address is within 7800H to 7BFFH of the ME0 area which is used for the system memory area and for the fixed variable area. | Address is within 7800H to 7FFFH of the ME0 area which is used for the system memory area, machine language area (7C01H~7FFFH) and for the fixed variable area. | | | | 90 | ® User RAM | ® User RAM | | | | | It is the user RAM for which 8-bit× 2KB HM6116 is used. Address selected by S0 is within 4000H to 47FFH. | It is the user RAM for which 8-bit×<br>2KB HM6116 is used. Address<br>selected by S0~S2 is within 4000H to<br>57FFH. | | | | | 4-2-2. Block diagram | 4-2-2. Block diagram for the PC-<br>1500A | | | | | | Refer to 4-2-2 diagram for the PC-1500A. | | | | 91 | 4-2-3. Chip select circuit | 4-2-3. Chip select circuit for the PC-<br>1500A | | | | | | Refer to 4-2-3 circuit for the PC-1500A. | | | ## 4-2-2. Block diagram for the PC-1500A ### 4-2-3. Chip select circuit for the PC-1500A | Page | PC-1500 | PC-1500A | | | |------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 92 | ● S0~S7 is selected by the decoder IC (TC40H138F) when the gate signal input ME0 (G1) is high, Y1 (G2A) low, and G2B is low (normally low). S1 With high, low so as to (YI) select the optional user RAM area | ● S0~S7 is selected by the decoder IC (TC40H138F) when the gate signal input ME0 (G1) is high, Y1 (G2A) low, and G2B is low (normally low). S1 With high, low so as to (Y1) select the user RAM area | | | | | S2 With low, the S2 output (Y2) goes low so as to select the optional user RAM area | S2 With low, the S2 output (Y2) goes low so as to select the user RAM area | | | | | $\overline{(Y3)}$ With low, the S3 output $\overline{(Y3)}$ goes low so as to select the user RAM area | S3 With low , the S3 output (Y3) goes low so as to select the optional user RAM area | | | | | S4 With high, the S4 output (Y4) goes low so as to select the user RAM area | S4 With high, the S4 output (Y4) goes low so as to select the optional user RAM area | | | | | S5 Do not use | S5Optional user RAM area (\overline{\bar{Y5}}) (Address assignment of 6800H~6FFFH) | | | | | $\frac{S7}{(Y7)}$ so as to select the system $\frac{S7}{(Y7)}$ RAM (TC5514) | S7so as to select the system (Y7) RAM (HM6116) | | | | 93 | Chip select signal | Chip select signal for the PC-1500A<br>Refer to following chart for the PC-<br>1500A. | | | ## Chip select signal for the PC-1500A | | | | 0000Н | 1000 | | |-------------|-------------------|-------|----------------|-------------------------------------------------------------------------------------|--| | Y0<br>(1Y0) | | | | OPTIONAL USER MEMORY | | | | | | 3FFFH | | | | | S0<br>(Y0) | | 4000H<br>47FFH | | | | | S1 | | 4800H | | | | | ( <del>Y</del> 1) | | 4FFFH | STANDARD USER MEMORY | | | | \$2 | | 5000H | | | | | ( <del>Y2</del> ) | | 57FFH | | | | | S3 | | 5800H | | | | | ( <del>Y3</del> ) | | 5FFFH | | | | | S4 | | 6000H | OPTIONAL USER MEMORY | | | Y1 | (Y4) | | 67FFH | OF HONAL USER MEMORY | | | (1Y1) | S5 | | 6800H | | | | 31332 | (Y5) | | 6FFFH | | | | | | | 7000H | INHIBITED | | | | S6 | | 75FFH | | | | | (Y6) | V2 | 7600H | D/AN | | | | (10) | (2Y2) | 76FFH | | | | | | V3 | 7700H | STANDARD USER AND | | | | | (2Y2) | 77FFH | SYSTEM MEMORY | | | | S7 | | 7800H | | | | | (Y7) | | 7FFFH | MACHINE LANGUAGE AREA<br>(7C01H~7FFFH) | | | Y2<br>(1Y2) | | | 8000H | CE-150<br>SYSTEM PROGRAM,I/O PORT<br>CE-153<br>I/O PORT<br>CE-158<br>SYSTEM PROGRAM | | | | | | <b>BFFFH</b> | | | | Y3<br>(1Y3) | | | С000Н | PC-1500A<br>SYSTEM PROGRAM<br>I/O PORT<br>CE-158<br>I/O PORT<br>UART | | | | | | FFFFH | | | NOTE: S0~S7, V2, and V3 are applicable only for ME0 area. | Page | PC-1500 | memory area 4000H thru 57FFH and 7600H thru 7FFFH are used for | | | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--|--| | 94 | 4-2-4. PC-1500 system memory map ① With the PC-1500, ME0 memory area 4000H thru 47FFH and 7600H thru 7BFFH are used for the user memory and C000H thru FFFFH for the system program | | | | | 95 | MEMORY MAP I | MEMORY MAP I<br>Refer to following MAP I for the PC-<br>1500A. | | | | 96 | MEMORY MAP II | MEMORY MAP II<br>Refer to following MAP II for the PC-<br>1500A. | | | ### MEMORY MAP I for the PC-1500A ### MEMORY MAP II for the PC-1500A MEMORY MAP when the CE-155 is used. | Page | PC-1500<br>4-3-1. 40-pin connector | | | PC-1500A<br>4-3-1. 40-pin connector | | | |------|------------------------------------|-------------|-------------------------------------|------------------------------------------------------------------------------------------------|-------------|------------------------------------| | 102 | | | | | | | | | 10000 | Signal name | Description | Pin no. | Signal name | Description | | | 5 | S4 | Address designation of 0000H~ 3FFFH | 5 | NC | NC | | | 16 | S1 | Address designation of 4800H~4FFFH | 16 | S3 | Address designation of 5800H~5FFFH | | | 17 | S2 | Address designation of 5000H~57FFH | 17 | \$4 | Address designation of 6000H~67FFH | | | 18 | S3 | Address designation of 5800H~5FFFH | 18 | \$5 | Address designation of 6800H~6FFFH | | | | | | The ab | ove portion | should be changed | | 154 | 5-1. PC-1500 Circuit diagram | | | 5-1. PC-1500A Circuit Diagram For the PC-1500A, refer to the circuit diagram on the next page. | | |