# Chapter 4 Other Information

#### Chapter 4 Other Information

#### **§**l Display

#### 1.1. Display Settings

MultiFonts CP/M for the QX-10 supports both green and color display monitors. Since different hardware is used in each of these, it is also necessary to set the display controller in different modes. When the system uses a green monitor in the non-MFBASIC normal mode, BIOS sets the display controller in the mixed character/graphics mode and the entire screen is set in the character display area. When the system uses a green monitor in the non-MFBASIC MF mode or MFBASIC mode, BIOS sets the display controller in the mixed character/graphics mode and the entire screen is set in the graphic display area.

In the case of a color monitor, the display controller is set in the graphic mode for all modes of operation (non-MFBASIC normal and MF modes, and MFBASIC mode).

The table below summarizes the I/O port numbers and data output to set the display controller in the different display modes. The mode settings are made with the scroll command.

| Mode                | Green                                                    | monitor                              | Color monitor                                                  |
|---------------------|----------------------------------------------------------|--------------------------------------|----------------------------------------------------------------|
| I/O port            | Non-MFBASIC Non-MFBASIC MF normal mode mode/MFBASIC mode |                                      | Non-MFBASIC normal<br>mode/non-MFBASIC MF<br>mode/MFBASIC mode |
| Command<br>039H     | 070н                                                     | 070н                                 | 070н                                                           |
| Parameter 1<br>038H | 0 (Lower byte of display address)                        | 0 (Lower byte of<br>display address) | 0 (Lower byte of<br>display address)                           |
| Parameter 2<br>038H | 0 (Upper byte of display address)                        | 0 (Upper byte of display address)    | 0 (Upper byte of<br>display address)                           |
| Parameter 3<br>038H | 0 or 0F0H                                                | ОГОН                                 | ОГОН                                                           |
| Parameter 4<br>038H | 019н ог 03Fн                                             | 07FH                                 | 03Fн                                                           |

Parameters 1 and 2 specify the starting address for display; i.e., the VRAM address which is displayed in the upper left corner of the screen. When parameters 1 and 2 are incremented by 1 (this is done by a 16-bit logical operation) and the commands and parameters (parameters 1 to 4) are written to the I/O ports again, results differ according to mode as follows. For a green monitor in the non-MFBASIC normal mode, the character in the upper left corner is erased and all other characters are moved back one position. A new character then moves into the bottom right corner of the screen. For a green monitor in the non-MFBASIC MF mode or MFBASIC mode or a color monitor in any mode, the 16-dot area at the upper left corner of the screen is erased and all other portions of the screen are moved back a corresponding amount. New data then moves into the 16-dot area at the bottom right corner of the

screen.

Thus, the scroll command both determines the screen mode and scrolls data.

All characters are displayed as bit images when a green monitor is used in the mixed character/graphics mode and the graphic section is specified or when a color monitor is used. See the description of the CONOUT routine in Chapter 1 for details.

A green monitor is provided with the QX-10 as standard equipment; however, a color monitor can also be used when the optional color monitor interface board is installed. Since BIOS also provides support for color monitors, no changes need be made in MultiFonts CP/M. Differentiation between the green and color monitors and specification of the display colors for the color monitor is as follows.

<Differentiation between green and color monitors>

When a green monitor is connected, the value present at I/O port 02CH is 0FEH, and when a color monitor is connected, the value present is 0FDH.

<Display color specification for color monitors>

Any of eight different colors--black (no color), blue, red, green, purple, light blue, yellow, and white--can be displayed. However, colors other than blue, red, and green are displayed by combining two or more of these three basic colors.

Purple - Displayed using blue and red

Light blue - Displayed using blue and green

Yellow - Displayed using red and green

White - Displayed using blue, red, and green

The colors blue, red, and green are specified by setting one bit of the corresponding I/O port to "1". (Results are not assured if more than one bit is set to "1".)

I/O port 02DH <-- 01B (01H) - Blue

I/O port 02DH <-- 010B (02H) - Green

I/O port 02DH <-- 0100B (04H) - Red

Once a color has been specified, that specification remains effective until the next specification is made. The color specification is invalid when a green monitor is used. when the screen is not zoomed.

#### 1.2 Zoom Function

The  $\mu PD7220$  is used as the display controller in the QX-10. This controller is equipped with a zoom function. The zoom function makes it possible to magnify characters for display. However, this change in size is not reflected in hard copies taken of the display; when a hard copy is made, characters appear the same as

Zooming is done by outputting commands to I/O ports as shown below.

```
IN
        A, (038H)
MIND
        6
XOR
        4
                     ;7220 BUFFER EMPTY?
JR
                      ; NO.
        NZ, $-6
                      ; ZOOM COMMAND.
LD
        A. 046H
OUT
        (039H),A
LD
        A,010H
                     ; ZOOM PARAMETER.
        (038H),A
OUT
LD
        A. 1
DUT
        (03AH),A
```

Here, I/O port 039H is the  $\mu PD7220$  command port and 038H is the parameter and status port. The zoom command is 046H; after this command has been output, it is followed by outputting the magnification to the parameter port. The magnification must also be output to port 03AH.

The zoom magnification can be set to any value from 1 to 16. The value which is output to I/O port 038H is equal to (ratio - 1) x 16, and that which is output to port 03AH is equal to (ratio - 1).

The command sequence for magnifying characters by 10 is as follows.

```
.
LD A,046H
OUT (039H),A ;COMMAND.
LD A,090H
OUT (038H),A ;PARAMETER 1 x 10
LD A,09H
OUT (03AH),A ;PARAMETER 2 x 10
```

The upper left corner of the display is used as the origin for zooming. Thus, characters are enlarged from the top left corner toward the bottom right. The reason for using the upper left corner of the display as the origin is that processing becomes quite complicated if the origin is placed at the center; i.e., it becomes necessary to change the display address for the upper left corner each time the zoom function is used. This could be done using the scroll command.

The scroll command and its parameters are as follows.

| K                   |                                   |                                     |                                                                |  |  |
|---------------------|-----------------------------------|-------------------------------------|----------------------------------------------------------------|--|--|
| Mode                | Green                             | Green monitor                       |                                                                |  |  |
| I/O port            | Non-MFBASIC<br>normal mode        | Non-MFBASIC MF<br>mode/MFBASIC mode | Non-MFBASIC normal<br>mode/non-MFBASIC MF<br>mode/MFBASIC mode |  |  |
| Command<br>039H     | 070н                              | 070н                                | 070н                                                           |  |  |
| Parameter l<br>038H | 0 (Lower byte of display address) | 0 (Lower byte of display address)   | 0 (Lower byte of display address)                              |  |  |
| Parameter 2<br>038H | 0 (Upper byte of display address) | 0 (Upper byte of display address)   | 0 (Upper byte of<br>display address)                           |  |  |
| Parameter 3<br>038H | ОГОН                              | ОГОН                                | ОГОН                                                           |  |  |
| Parameter 4<br>038H | 03FH                              | 07 <b>гн</b>                        | 03FH                                                           |  |  |

See the discussion of the CONOUT routine in Chapter 1 concerning display addresses and display modes.

Although the display address can be changed independently of the zoom function, BIOS would have no way of knowing that a change had been made. Therefore, subsequent character display might not be performed properly the next time the CONOUT routine is called. Thus, if the display address is changed, it must be restored (or the screen must be cleared) before calling CONOUT. The display address is saved as two bytes in SPOS (address OFE70H) in the BIOS common data area, and can be restored by outputting that value to an I/O port with the scroll command.

BIOS support is not provided when the zoom function is used, and cannot be utilized again until the original character size is restored. This is done by setting a magnification ratio of 1.

Magnification of characters for display by the zoom function is done entirely by hardware, and no software considerations are necessary. The effect is the same as if the display were viewed through a magnifying glass. Although portions of the image extending beyond the edge of the screen are not visible, all data in VRAM can be brought into view by executing the scroll command to move the display address up, down, left, or right. Again, results are not assured if CONOUT is called for display.

However, the CONOUT routine can be used to output an escape sequence to clear the screen. In this case, it is the user's responsibility to restore the zoom magnification to the original ratio.

#### §2 Memory Banks

#### 2.1 Using the User Banks

User bank 1 can be used as a program area or data area as long as MFBASIC is not started. User bank 2 can be used in the same manner. When one of the user banks is to be used as program area, the program must be loaded into the corresponding bank. This is done as follows.

- (1) Read in one sector of the subroutine program by calling BDOS from a program in the main bank.
- (2) Call BIOS routine LDIRX to transfer the data read to user bank 1 or 2.
- (3) Repeat steps 1 and 2 until the entire subroutine has been loaded.
- (4) Start processing with the main program after subroutine program loading has been completed.
- (5) Use the CALLX routine of BIOS to call the subroutine in the user bank. (CALLX makes it possible to execute subroutines in other banks.)

These procedures are shown as a flowchart below.





FCB for BDOS calls





As shown above, the FCB (file control block) is composed of 36 bytes. The FCB is referenced by BDOS when a file is accessed. Specification of a file control block is mandatory whenever the user accesses a program or data file on a flexible disk.

An example of the FCB specification for opening a subroutine program file is shown below.

Byte 0: Drive number

- 0 Disk currently logged in
- 1 Drive A
- 2 Drive B
- 3 Drive C
- 4 Drive D

Bytes 1 - 11: Filename

Example: SUB1.COM



Only upper-case characters can be specified for the file name.

Bytes 12, 14, and 32: Set to 0.

Any data may be specified for bytes which are shaded.

When a file is opened by making a BDOS call, prepare an FCB such as that shown above before making the call.

Normally the FCB is located in the main bank area starting at address 05CH. However, it can also be prepared in a user program area.

#### 2.2 Switching Banks

User programs are normally loaded into the main bank area from 0100F to 0DFFFH for execution. However, if memory banks are switched during program execution, program control is switched to the selected memory bank. Therefore, at the user's option it is possible to continue program execution in the selected bank. (See 2.1 "Using the User Banks" for procedures for loading programs or data into banks other than the main bank.) The sequence for switching memory banks is as follows.

- (1) Save the current bank number.
- (2) Set the new bank number in the BIOS common data area.
- (3) Output the new bank number to the applicable I/O port.

If the above sequence is loaded into part of resident memory, there will be no problem with execution of the next instruction even if banks are switched. Therefore, every effort should be made to avoid switching banks from other than resident memory, and BIOS entries LDIRX, JUMPX, or CALLX should be used for continuing execution.

An example of coding for continuation of a program in another bank is shown below.

| MEMBANK | EQU | ØFEFØH      | CURRENT BANK NO.      |
|---------|-----|-------------|-----------------------|
| CBANK   | EQU | 030H        | ;I/O FORT.            |
| NBANK   | EQU | 018H        | ;I/O PORT.            |
|         | ĎΙ  |             | ;DISABLE INTERRUPT.   |
|         | IN  | A, (CBANK)  | KEEP CURRENT BANK NO. |
|         | LD. | (SVBANK),A  | <b>5</b>              |
|         | LD  | A,040H      | ;SELECT USER BANK.    |
|         | LD  | (MEMBANK),A | ;SET NEW BANK NO.     |
|         | OUT | (NBANK),A   | ; CHANGE.             |
|         | ΕI  |             | ; ENABLE INTERRUPT.   |
|         |     |             |                       |
| SVBANK: | DS  | 1           | ;BANK NO. SAVE AREA.  |

In the example above, MEMBANK is the BIOS control data byte in the BIOS common data area which is used for saving the current bank number. Since BIOS uses this information for switching banks, the new bank number must be set in MEMBANK. The bank number is set as a bit pattern (see below) in which only one of the bits is set to "l". Note that operation is not assured if more than one bit of this bit pattern is "l". Also note that access to all memory other than the resident area (addresses 0E000H to 0FFFFH) will be cut off if all bits of this pattern are set to "0".

| Bank                     | Bit pattern |
|--------------------------|-------------|
| Main bank                | 010H        |
| System bank (BIOS)       | 020Н        |
| User bank 1              | 040H        |
| User bank 2 (option RAM) | 080н        |

#### §3 Keyboard Control

The keyboard is interfaced with the system via an NEC  $\mu$ PD7201. Data transfer between the keyboard and the main system is bidirectional, and is performed at 1200 bps. The signals used for transfer of data are as follows.

| Pin No. | Signal  |
|---------|---------|
| 1       | RxD     |
| 2       | Clock   |
| 3       | +12 VDC |
| 4       | TxD     |
| 5       | GND     |
| 6, 7, 8 | NC/GND  |

Data sent to the main system from the keyboard includes (1) the matrix codes of keys pressed, and (2) the LED status codes. The control and status codes for the LEDs are as shown in the table below.

LED control/status codes

| Key       | Control | code    | Status | code |
|-----------|---------|---------|--------|------|
|           | On      | Off     | On     | Off  |
| CAPS LOCK | 41H     | 40H     | ClH    | СОН  |
| INSert    | 45 H    | 44H     | С5Н    | С4Н  |
| SF4       | 49H     | 48H     | С9Н    | С8Н  |
| SF3       | SF3 4BH |         | СВН    | САН  |
| SF2       | 4 DH    | 4 CH    | CDH    | ССН  |
| SFl       | 4FH     | 4EH CFH |        | СЕН  |

Only matrix codes are generated when the keys are pressed; these matrix codes are converted into the corresponding internal character codes by the system software. The momentary shift keys (GRPH, left SHIFT, right SHIFT, and CTRL) generate both make and break codes. The keyboard matrix scanning codes generated are as shown in the following table.

### KEYBOARD SCAN CODES (ASCII)

|   | 0             | 1   | 2  | 3            | 4      | 5      | 6       | 7   | 8                    | 9 | Α | В | С                    | D . | Е | F |
|---|---------------|-----|----|--------------|--------|--------|---------|-----|----------------------|---|---|---|----------------------|-----|---|---|
| 0 |               |     |    |              |        |        |         |     |                      |   |   |   | CAPS<br>LOCKS<br>OFF |     |   |   |
| 1 | F4            | LF  |    | CAPS<br>LOCK |        | Q      | 2       | F3  |                      |   | · |   | CAPS<br>LOCK<br>ON   |     |   |   |
| 2 | F5            | A5  | Α4 | (SPACE)      |        | W      | #<br>3  | F2  |                      |   |   |   |                      |     |   |   |
| 3 | F6            |     |    | Z            | A      | E      | \$<br>4 | F1  |                      |   |   |   |                      |     |   |   |
| 4 | F7            | 000 |    | Х            | S      | R      | %<br>5  |     | SHIFT<br>(R)<br>BRK  |   |   |   | INS<br>OFF           |     |   |   |
| 5 | F8            |     | 3  | С            | D      | Т      | &<br>6  | ESC | SHIFT<br>(R)<br>MAKE |   |   |   | INS<br>ON            |     |   |   |
| 6 | F9            |     | 2  | v            | F      | Y      | ,<br>7  | :/  | SHIFT<br>(L)<br>BRK  |   |   |   | -                    |     |   |   |
| 7 | F10           | 0   | 1  | В            | G      | U      | (<br>8  | ТАВ | SHIFT<br>(L)<br>MAKE |   | 1 |   |                      |     |   |   |
| 8 | Al            | +   | _  | N            | Н      | I      | )<br>9  |     |                      |   |   |   | MF4<br>OFF           |     |   |   |
| 9 | BREAK         | 6   | 9  | М            | J      | 0      | 0       |     |                      |   |   | - | MF4<br>ON            |     |   |   |
| A | PAUSE         | 5   | 8  | <,           | K      | P      | =       |     | CTRL<br>BRK          |   |   |   | MF3<br>OFF           |     |   |   |
| В | S CAN<br>DUMP | 4   | 7  | >            | L      | @      | ~       |     | CTRL<br>MAKE         |   |   |   | MF3<br>ON            |     |   |   |
| С | HELP          |     | =  |              | +<br>; | {<br>[ |         |     | GRPH<br>BRK          |   |   |   | MF2<br>OFF           |     |   |   |
| D | A2            |     | *  |              | *      | }<br>] | BS      |     | GRPH<br>MAKE         |   |   |   | MF2<br>ON            |     |   |   |
| E | A3            |     | /  |              |        | INS    | НОМЕ    |     |                      |   |   |   | MF1<br>OFF           |     |   |   |
| F | SF1           |     | ,  |              | ? /    | DEL    | CLS     |     |                      |   |   |   | MF1<br>ON            |     |   |   |

**†** 

Shift Key

1

LED

Data sent to the keyboard from the main system controls the keyboard as follows.

(1) Auto-repeat start time setting

The auto-repeat start time (the time from the moment a key is first pressed until the auto-repeat function starts operating) can be set in 25 ms increments within the range from 300 ms to 1075 ms.

(2) Auto-repeat interval setting

The auto-repeat interval (the interval at which input is accepted from a key after the repeat function starts operating) can be set to within the range from 30 ms to 185 ms in 5 ms increments.

(3) Auto-repeat control

The repeat function can be enabled or disabled. When disabled, only one character is input each time a key is pressed, no matter how long that key is held down.

(4) Keyboard LED control

LEDs built into certain keytops can be turned on or off by specifying the corresponding LED number.

(5) LED status read

The current status of all LEDs (on or off) can be checked.

(6) SW status read

The current status of the keyboard switches (SHIFT, CTRL, and GRPH) can be checked.

(7) Keyboard enable/disable

Input from the keyboard buffer can be either enabled or disabled.

(8) Reset

The keyboard controller can be reset. The status upon reset is as follows.

- o The keyboard buffer (built into the keyboard) is cleared.
- o The repeat function is enabled.
- o The repeat starting time is set to 500 ms.
- o The repeat interval is set to 50 ms.
- o All LEDs are turned off.

The reset function also executes a keyboard diagnostic program which turns on the LEDs in sequence, then turns all LEDs on and back off again; and which scans all keys, outputting OH it no key is pressed and OFFH if any key is pressed.

Control commands for the eight functions described above

are summarized in the table below.

| Command                  |   | Bit pattern |     |          |     |                |     |                              | Example     |
|--------------------------|---|-------------|-----|----------|-----|----------------|-----|------------------------------|-------------|
|                          |   | 6           | 5   | 4        | 3   | 2              | 1   | 0                            | Вхатрте     |
| Repeat starting time set | 0 | 0           | 0   | *1       |     | nı             |     |                              | 00H ~ 01FH  |
| Repeat interval set      | 0 | 0           | 1   | *2       |     | n <sub>2</sub> |     |                              | 020н∿03ғн   |
| Repeat control           | 1 | 0           | 1   | X        | X   | х              | Х   | *3<br>ON/OFF                 | OAOH, OAlH  |
| LED ON/OFF               | 0 | 1           | 0   | х        | *4  | LED            | No. | *5<br>ON/OFF                 | 040H ∼ 04FH |
| LED status read          | 0 | 1           | 1   | l<br>I X | X   | Х              | X   | Х                            | 07FH        |
| SW status read           | 1 | 0           | . 0 | X        | X   | Х              | ! X | Х                            | 080н        |
| Keyboard enable          | 1 | 1           | ' 0 | X        | X   | Х              | Х   | *6<br>ON/OFF                 | OCOH, OC1H  |
| Reset                    | 1 | 1           | 1   | X        | ı X | Х              | х   | *7 <sub>Di-</sub><br>agnosis | OFEH        |

Either 0 or 1 may be specified for bits marked with an "x".

#### Notes:

- \*1,\*2 nl and n2 specify the repeat starting time and the repeat interval. The repeat starting time is equal to 300 ms + nl x 25 ms, and the repeat interval is equal to 30 ms + n2 x 5 ms.
- \*3 Bit 0 controls the repeat function. The repeat function is inhibited if 0 is set in bit 0, and is enabled if 1 is set in bit 0.
- \*4 With the LED status read command, bits 3, 2, and 1 designate the LED to be turned on or off as follows.

LED No.=0 - CAPS LOCK LED

LED No.=2 - INS LED

LED No.=4 - MF4 LED

LED No.=5 - MF3 LED

LED No.=6 - MF2 LED

LED No.=7 - MF1 LED

- \*5 This bit determines whether the specified LED is turned on or off. When bit 0 is 0, the LED is turned off; when it is 1, the LED is turned on.
- \*6 Input from the keyboard is inhibited if bit 0 is 0 (although data currently being sent is output); input is enabled if this bit is set to 1.
- \*7 Specifies execution of the diagnostic program. The diagnostic program is executed when bit 0 is set to 0, and is not executed when it is set to 1.

All of these keyboard control commands are output to I/O port 010H.

#### Example: Sequence to light the MF3 LED

```
.
LD A,01000111B; MF3 LED ON.
OUT (010H),A;
```

Normally, the results of the LED status read command or the SW status read command cannot be read by the BIOS CONIN routine. Therefore, the user must read in the value as follows.

(1) Call the BIOS CONST routine to confirm that there is no data in the keyboard buffer. If there is data and it can be ignored, initialize the keyboard data pointer as follows.

```
EQU
KBUF
                 ØFE2EH
                               KEYBOARD BUFFER ADDR.
INPTR
         EQU
                 ØFE21H
                               ; KEY PUT POINTER.
KEYPTR
         EQU
                 ØFE23H
                               ;KEY GET POINTER.
         DI
                               ; DISABLE INT.
         LD
                 HL, KBUF
                               ; INITIALIZE KEY DATA.
         LD
                  (INPTR),HL
                               ; POINTER.
                  (KEYPTR), HL ;
         L.D
         EI
```

- (2) Output the applicable command (LED or SW status read).
- (3) Call the CONST routine to wait until data is input.
- (4) Read in 8 bytes of data from KBUF (address OFE2EH) in the BIOS common data area for each command executed, then reinitialize the keyboard buffer.

The following is an example of a program which does steps 1 to 4 above.

```
KBUF
          EQU
                 ØFE2EH
INTETR
          EQU
                 ØFE21H
KEYPTR
          EQU
                 ØFE23H
CONST
         EQU
                 0F606H
          CALL
                 CONST
                               ; CHECK INPUT STATUS.
          OR
         CALL
                 NZ, KRINIT
                              ; IF READY
         LD
                 A,060H
                              ; READ LED STATUS.
          OUT
                 (010H),A
         LD
                 HL.KBUF
                              KEY BUFFER HEAD ADDR.
                 B.8
         LD
                               ;8 TIMES.
LOOP:
         PUSH
                 BC
         PUSH
                 HL
         CALL
                 CONST
                              ; CHECK STATUS.
         POP
                 HL
```

```
POP
                  BC
          OR
                  Α
          JR
                  Z, LOOP
                                ; NO DATA.
          LD
                  A, (HL)
                                : A=LED DATA.
          INC
                  HL
          DJNZ
                  LOOP
          CALL
                  KBINIT
                                ; INITIALIZE POINTER.
KBINIT:
          DI
                                ; SUBROUTINE.
          LD
                  HL, KBUF
          LD
                  (INTPTR), HL ; INITIALIZE KEY DATA.
                  (KEYPTR), HL ; POINTER.
          LD
          ΕI
          RET
```

Eight bytes of data are returned as the result of the LED status read command. These values are composed of bit patterns such as the one shown below.



Example: The value 011001011B indicates that the MF3 key LED is lit.

Eight bytes are also returned as the result of the SW data read command. These are composed of bit patterns such as the following.



1: Unassigned

2: Right shift key

3: Left shift key

4: Unassigned

5: CTRL key

6: GRPH key

7: Unassigned

Example: The value 010000111B indicates that the left shift key is currently being pressed.

The repeat starting time, repeat interval, and repeat control can also be set by setting data in KBSTRT (address 0FE4DH), KBINTVL (address 0FE4EH), and KBREPT (address 0FE4CH) in the BIOS common data area. However, the values set are different in the case of repeat control; set 0FFH to enable the repeat function and 0H to disable it.

#### §4 Light Pen

Depending on the display mode with which it is used, light pen sensitivity may be quite low. This is particularly true when used with other than a green monitor in the non-MFBASIC normal mode. The reason for this is as follows.

Light pen detection by the  $\mu PD7220$  is performed by reading data twice and ignoring it if the results of the two reads do not match. For modes other than the non-MFBASIC normal mode (or other than a green monitor), there are 400 character addresses in the vertical direction; i.e., data addresses differ in 1-dot units. Therefore, if the light pen slips even slightly when it is pressed against the screen, the address (and particularly the vertical address) is likely to change. This means that the light pen must be held at a constant angle to the screen and kept from slipping in any direction. Further, sensitivity is particularly low with red when a color monitor is used.

This problem does not occur when the light pen is used with a green monitor in the non-MFBASIC normal mode.

The address detected by the light pen is posted by reading it in from an I/O port; however, the address read is not the same as the actual address of the screen area against which the light pen was pressed. BIOS corrects for this difference as follows.

|                                                       | Gree                       | en monitor                          | Color monitor                                                  |
|-------------------------------------------------------|----------------------------|-------------------------------------|----------------------------------------------------------------|
| Display mode                                          | Non-MFBASIC<br>Normal mode | Non-MFBASIC MF<br>mode/MFBASIC mode | Non-MFBASIC normal<br>mode/Non-MFBASIC MF<br>mode/MFBASIC mode |
| Correction value<br>(2 bytes)                         | -5 (OFFFBH)                | -2 (OFFFEH)                         | -3 (OFFFDH)                                                    |
| BIOS common data area containing the correction value | MLPBIAS<br>(OFEF6H)        | GLPBIAS<br>(OFE9BH)                 | CLPBIAS<br>(OFEF4H)                                            |

As indicated above, different 2-byte correction values are stored in the BIOS common data area for each mode. If the address read differs from the actual one by too much, these values can be changed using the DDT transient command. See the discussion of CONOUT in Chapter 1 for procedures for using DDT to change data in the BIOS common data area.

#### §5 RS-232C Interface

Including the optional RS-232C cards, the QX-10 supports a total of 5 RS-232C interface channels. Except with respect to maximum transfer speed, processing for both the standard and optional interfaces is performed in exactly the same manner. Further, data can be received on all five channels simultaneously as long as the following conditions are satisfied.

- (a) The transfer speed must not be more than 300 bps.
- (b) SI/SO control must not be used.
- (c) XON/XOFF control may be specified; however, in this case the interfaces cannot be used for transfer of binary data.
- (d) Every effort should be made to minimize I/O access and bank switching during processing of receive data. It is particularly important to avoid access to flexible disk drives or output of data to the screen.

BIOS routines provided for using the RS-232C interfaces include RSOPEN, RSCLOSE, RSINST, RSOUTST, RSIN, RSOUT, and RSIOX. However, except for RSIOX, these routines can only be used for control of the main board interface. Therefore, the RSIOX routine must be called for control of the optional RS-232C interfaces. Further, the receive buffer is fixed to the 512-byte area starting at address ODAOOH of the system bank for all routines other than RSIOX. This means that the RSIOX routine cannot be used together with other RS-232C control routines.

The standard RS-232C interface can be assigned to any logical device name (LST:, PUN:, RDR:, or CON:) by specifying the appropriate setting in the I/O byte. Assignment of the RS-232C interface to a logical device does not open the interface; the interface is opened only when data is input or output. The RS-232C interface is opened by resetting it (the  $\mu$ PD7201). Therefore, the standard RS-232C interface cannot be used by a user program or MFBASIC when it has been specified in the I/O byte. In this case, use one of the optional RS-232C interfaces for standard system I/O.

When connecting an HX-20 to the QX-10 via their RS-232C interfaces, data sent from the HX-20 to the QX-10 will be shifted by one bit (resulting in an error) if the RS-232C interface on the QX-10 side is opened before that on the HX-20 side. The reason for this is that when the HX-20's RS-232C interface is opened, noise is output during initialization of the interface when its power is turned on. The QX-10 interprets this noise as a start bit, so that subsequent data received is shifted by one bit. Therefore, be sure to open the RS-232C interface of the HX-20 prior to that of the QX-10.

All RS-232C interfaces are set to the asynchronous mode by BIOS. When any of the interfaces is to be used in the synchronous mode, jumper settings must be changed and RS-232C control must be provided.

The jumper settings for the respective modes are as follows.

Main board RS-232C interface

| Mode<br>Jumper | Asynchronous <b>&lt;</b> | ⇒Synchronous |
|----------------|--------------------------|--------------|
|                | Al                       | В1           |
| J2             | A2                       | В2           |

Changing these settings for synchronous communication causes the external clock to be used in the case of the main board RS-232C interface.

Jumper settings for the optional RS-232C interface cards are as follows.

| Mode   | <b>+</b>     | Synchronous            |                        |  |  |  |
|--------|--------------|------------------------|------------------------|--|--|--|
| Jumper | Asynchronous | External<br>Send Clock | Internal<br>Send Clock |  |  |  |
| J6     | В            | A                      | В                      |  |  |  |
| J7     | Α            | В                      | В                      |  |  |  |

When the interfaces are set to the synchronous mode, the external clock is used as the receive clock.

Settings of the various registers for synchronous communication are described below.

#### PIN CONFIGURATION



#### PIN DESCRIPTION

#### μPD**720**1

| ***   | P                              | IN                                                          | PHOODIDMICAN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|--------------------------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NO.   | SYMBOL                         | NAME                                                        | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12-19 | D <sub>0</sub> -D <sub>7</sub> | System Data Bus<br>(bidirectional,<br>3-state)              | The system data bus transfers data and commands between the processor and the ${\tt IPD7201.}\  \   D_0$ is the least significant bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 25    | B/Ā                            | Channel A or B Select<br>(input, High selects<br>Channel B) | This input defines which channel is accessed during a data transfer between the processor and the µPD7201.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 24    | c/D                            | Control or Data Select<br>(input, High selects<br>Control)  | This input defines the type of information transfer performed between the processor and the $\mu PD7201$ . A High at this input during a processor write to or read from the $\mu PD7201$ causes the information on the data bus to be interpreted as a command for the channel selected by $B/A$ . A low at $C/D$ means that the information on the data bus is data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 23    | CS                             | Chip Select (input, active Low)                             | A low level at this input enables the $\mu PD7201$ to accept command or data inputs from the processor during a write cycle, or to transmit (data to the processor during a read cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1     | CLK                            | System Clock (input)                                        | The µPD7201 uses standard TTL clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 22    | RD                             | Read (input active Low)                                     | If $\overline{RD}$ is active, a memory or I/O read operation is in progress. $\overline{RD}$ is used with $C/\overline{D}$ . $B/\overline{A}$ and $\overline{CS}$ to transfer data from the $\mu PD7201$ to the processor or the memory.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 21    | WR                             | Write (input, active Low)                                   | The $\overline{WR}$ signal is used to control the transfer of either command or data from the processor or the memory to the µPD7201.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2     | RESET                          | Reset (input, active Low)                                   | A low RESET disables both receivers and transmitters, forces TxDA and TxDB marking, forces the modem controls high and disables all interrupts. The control registers must be rewritten after the µPD7201 is reset and before data is transmitted or received. RESET must be active for a minimum of one complete CLK cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 10,38 | RTSA, RTSB                     | Request to Send (outputs, active Low)                       | When the RTS bit is set, the RTS output goes Low. When the RTS bit is reset in the Asynchronous mode, the output goes High after the transmitter is empty. In Synchronous modes, the RTS pin strictly follows the state of the RTS bit. Both pins can be used as general-purpose outputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10,33 | SYNCA, SYNCB                   | Synchronization (inputs/outpus, active Low)                 | These pins can act either as inputs of outputs. In the Asynchronous Receive mode, they are inputs similar to CTS and DCD. In this mode, the transitions on these lines affect the state of the Sync/Hunt status bits in Read Register O. In the External Sync mode, these lines also act as inputs. When external synchronization is achieved. SYNC must be driven Low on the second rising edge of RXC after that rising edge of RXC on which the last bit of the sync character was received. In other words, after the sync pattern is detected, the external logic must wait for two full Receive Clock cycles to activate the SYNC input. Once SYNC is forced Low, it is wise to keep it Low until the processor informs the external sync logic that synchronization has been lost or a new message is about to start. Character assembly begins on the rising edge of RXC that immediatley precedes the falling edge of SYNC in the External Sync mode. |
|       |                                |                                                             | In the Internal Synchronization mode (monosync and Bisync), these pins act as outputs that are active during the part of the receive clock (RxC) cycle in which sync characters are recognized. The sync condition is not latched, so these outputs are active each time a sync pattern is recognized, regardless of character boundaries.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 26,31 |                                |                                                             | These outputs follow the state programmed into the DTR bit. They can also be programmed as general-purpose outputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

# PIN DESCRIPTION (CONT.)

μPD7201

|                | PIN                              |                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|----------------------------------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NO.            | SYMBOL                           | NAME                                                   | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 27             | INTA                             | Interrupt<br>Acknowledge (input,<br>active Low)        | This signal is generated by the processor and is sent to all peripheral devices. It serves to acknowledge the interrupt and to allow the highest priority interrupting device to put an 8-bit vector on the bus. INT and INTA are compatible with the fully nested option of the uPD8259A-5.                                                                                                                                                               |
| 29             | PRI                              | Priority In (input, active Low)                        | These signals are daisy chained through the peripheral device controllers. The signal on these lines is intact until a device with a pending interrupt request is found on the chain. After that device, this signal holds off lower priority device interrupts. A higher                                                                                                                                                                                  |
| 30             | PRO                              | Priority Out (output, active Low)                      | priority device can interrupt the processing of an interrupt from a lower priority device, provided the processor has interrupts enabled.                                                                                                                                                                                                                                                                                                                  |
|                |                                  |                                                        | PRI is used with PRO to form a priority daisy chain when there is more than one interrupt-driven device. A low on this line indicates that no other device of higher priority is being serviced by a processor interrupt service routine.                                                                                                                                                                                                                  |
|                |                                  |                                                        | PRO is Low only if PRI is Low and the processor is not servicing an interrupt from the µPD7201. Thus, this signal blocks lower priority devices from interrupting while a higher priority device is being serviced by its processor interrupt service routine.                                                                                                                                                                                             |
| 11,29<br>30,32 | DRQTxA, DRQTxB<br>DRQRxA, DRQRxB | DMA Request<br>(outputs, active High)                  | These signals are generated by the receiver or transmitter of Channel A and Channel B. These signals can be connected to most DMA Controllers directly and are used for handshaking during DMA transfer.                                                                                                                                                                                                                                                   |
| 26             | IAH                              | DMA Acknowledge<br>(input, active Low)                 | Typically, the HLDA signal driven from the processor is input to the HAI terminal of the highest priority µPD7201, and the HAO output of that µPD7201 is daisy chained to the HAI input of the lower priority                                                                                                                                                                                                                                              |
| 31             | HAO                              | DMA Acknowledge<br>(output, active Low)                | μPD7201 and propagated downstream. HAI and HAO signals provide aknowledgement for the highest priority outstanding DMA request.                                                                                                                                                                                                                                                                                                                            |
| 28             | INT                              | Interrupt Request (output, open collector, active Low) | When the $\mu PD7201$ is requesting an interrupt, it pulls $\overline{\mbox{INT}}$ low.                                                                                                                                                                                                                                                                                                                                                                    |
| 11,32          | WAITA, WAITB                     | (Outputs, open drain)                                  | Wait lines for both channels that synchronize the processor to the $\nu PD7201$ data rate. The reset state is open drain.                                                                                                                                                                                                                                                                                                                                  |
| 6,39           | CTSA, CTSB                       | Clear to Send<br>(inputs, active Low)                  | When programmed as Auto Enables, a Low on these inputs enables the respective transmitter. If not programmed as Auto Enables, these inputs may be programmed as general-purpose inputs. Both inputs are Schmitt-trigger buffered to accommodate slow-risetime inputs. The µPD7201 detects pulses on these inputs and interrupts the processor on both logic level transitions. The Schmitt-trigger inputs do not guarantee a specified noise-level margin. |
| 3,5            | DCDA, DCDB                       | Data Carrier Detect<br>(inputs, active Low)            | These signals are similar to the CTS inputs, except they can be used as receiver enables.                                                                                                                                                                                                                                                                                                                                                                  |
| 9,34           | RxDA, RxDB                       | Receive Data (inputs, active High)                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8,37           | TxDA, TxDB                       | Transmit Data (outputs, active High)                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4.35           | RxCA, RxCB                       | Receiver Clocks<br>(inputs)                            | The Receiver Clocks may be 1, 16, 32, or 64 times the data rate in asynchronous modes. Receive data is sampled on the rising edge of RxC.                                                                                                                                                                                                                                                                                                                  |
| 7,36           | TxCA, TxCB                       | Transmitter Clocks<br>(inputs)                         | In asynchronous modes, the Transmitter Clocks may be 1, 16, 32, or 64 times the data rate. The multiplier for the transmitter and the receiver must be the same. Both TxC and RxC inputs are Schmitt-trigger buffered for relaxed rise- and fall-time requirements (no noise margin is specified). TxD changes on the falling edge of TxC. Note that TxC and RxC in Channel B are on a common pin, RxCB/TxCB.                                              |

#### **BLOCK DIAGRAM**



#### INTERRUPT STRUCTURE



| WRO | 7        | 6        | 5         | 4           | 3           | 2        | 1.         | 0     |
|-----|----------|----------|-----------|-------------|-------------|----------|------------|-------|
|     | CRC1     | CRC0     | CMD2      | CMD1        | CMD0        | PTR2     | PTRl       | PTRO  |
|     | 00 Null  |          | 000 Null  |             |             | (000 WRO | ,RRO)      |       |
|     | 01 Reset | Rx CRC   | 001 Send  | Abort (SDL  | C)          | 001 WR1  | ,RR1       |       |
|     | Chec     | ker      | 010 Reset | E/S INT     |             | 010 WR2  | ,RR2 (CH.B | only) |
|     | 10 Reset | Tx CRC   | 011 Chann | el Reset    |             | 011 WR3  |            |       |
|     | Gene     | rator    | 100 Enabl | e INT on N  | ext Rx CHAR | 100 WR4  |            |       |
|     | 11 Resét | Tx       | 101 Reset | Tx INT/DM   | A Pending   | 101 WR5  |            |       |
|     | Unde     | rrun/EOM | 110 Error | Reset       |             | 110 WR6  |            |       |
|     | Bit      |          | lll End c | of INT (CH. | A only)     | 111 WR7  |            |       |

| R1 | 7         | 6 | 5       | 4         | 3             | 2               | 1          | 0         |
|----|-----------|---|---------|-----------|---------------|-----------------|------------|-----------|
|    | Wait      | 0 | Wait on | Rx INT    | Rx INT        | Status          | Tx INT/DMA | E/S INT   |
|    | Enable    |   | Rx/Tx   | Mode 1    | Mode 0        | Affects         | Enable     | Enable    |
|    |           |   | :       |           |               | Vector          |            |           |
|    | 0 Disable | 0 | 0 Tx    | 00 INT/DN | MA Disable    | 0 Fixed         | 0 Disable  | 0 Disable |
|    | l Enable  |   | l Rx    | 01 INT or | n First CHAR. | Vector          | l Eable    | l Enable  |
|    |           |   |         |           | n All CHAR.   | l Modi-<br>fied |            |           |
|    |           | 1 |         | . (=      |               | Vector          |            |           |
|    |           |   |         | 11 INT or | n All CHAR.   |                 |            |           |
|    |           |   |         | (Parit    | ty included)  |                 |            |           |

| WR2A | 7              | 6   | 5        | 4        | 3          | 2 *       | 1         | 0       |
|------|----------------|-----|----------|----------|------------|-----------|-----------|---------|
|      | RTSB/SYNC3     | . 0 | Vector   | INT      | INT        | Priority  | INT/DMA   | INT/DMA |
|      | Select Mode    |     | Mode     | Model    | Mode 0     | Select    | Model     | Mode 0  |
|      | 0 RTSB 0 0 Nor |     | 0 Non-   | 00 35-3  | l Vectored | 0 TxA-RxB | 00 Both C | CH. INT |
|      | 1 SYNC3        |     | Vectored | 01 35-2  | 2 Vectored | l RxB-TxA | 01 CH.A:D | MA      |
|      | 1 Vectored     |     | 10 36    | Vectored |            | CH.B:I    | NT        |         |
|      |                |     |          |          |            | 10 Both C | CH.DMA    |         |

<sup>\* 0:</sup> RxA TxA RxB TxB E/SA E/SB 1: RxA RxB TxA TxB E/SA E/SB

High ----- Low

| WR2B | . 7            | 6  | 5              | 4  | 3              | 2              | 1              | 0                |
|------|----------------|----|----------------|----|----------------|----------------|----------------|------------------|
|      | V <sub>7</sub> | ٧4 | V <sub>5</sub> | V4 | V <sub>3</sub> | V <sub>2</sub> | V <sub>1</sub> | . V <sub>0</sub> |

| WR3   | 7              | 6     | 5         | 4               | 3.        | 2      | 1         | 0         |
|-------|----------------|-------|-----------|-----------------|-----------|--------|-----------|-----------|
|       | Rx Rx          |       | Auto      | Enter           | Rx        | Adrs   | CYNC CHAR | Rx        |
| į     | Bits/          | Bits/ | Enable    | Hunt            | CRC       | Search | Load      | Enable    |
|       | CHAR1          | CHAR0 |           | Phase           | Enable    | Mode   | Inhibit   |           |
| Async | 00 5Bits/CHAR. |       | 0 Disable | 0               | 0         | 0      | 0         | 0 Disable |
|       | 01 7Bits/CHAR. |       | l Enable  | ·               | U         | U      | 0         | l Enable  |
| Sync  | 10 6Bits/CHAR. |       |           | 0 Nop           | 0 Disable |        | 0 Nop     | 1 Midple  |
| _     | ll 8Bits/CHAR. |       |           | l Re-<br>enable | l Enable  |        | l Inhibit |           |

| WR4      | 7         | 6        | 5         | 4      | 3                                    | 2                       | 1        | 0         |
|----------|-----------|----------|-----------|--------|--------------------------------------|-------------------------|----------|-----------|
|          | Clock     | Clock    | SYNC      | SYNC   | Stop                                 | Stop                    | Parity   | Parity    |
|          | Rate 1    | Rate 0   | Mode 1    | Mode 0 | Bits 1                               | Bits 0                  | Even/Odd | Enable    |
|          | 00 xl Cl  | ock Mode |           |        | 01 1 stop                            | bit/CHAR                | 0 Odd    | 0 Disable |
| Async    | 01 x16 C1 | ock Mode |           | 00     | 10 1 <sup>1</sup> / <sub>2</sub> sto | 10 1 1/2 stop bits/CHAR |          | l Enable  |
| 2        | 10 x32 Cl | ock Mode |           |        | 11 2 stop                            | bits/CHAR               |          |           |
|          | 11 x64 C1 | ock Mode |           |        |                                      |                         |          |           |
|          |           |          | 00 8 bit  | SYNC   | 00 SYNC M                            | ode                     |          |           |
| Sync     |           | 00       | 01 16 bit | SYNC   |                                      |                         |          |           |
| <u> </u> | - v .     |          | 11 EXT SY | NC     |                                      |                         |          |           |

| WR5   | 7       | 6         | 5             | 4         | 3         | 2         | 1          | 0         |
|-------|---------|-----------|---------------|-----------|-----------|-----------|------------|-----------|
|       | DTR     | Tx Bits/  | Tx Bits/      | Send      | Тx        | CRC-16/   | RTS        | Tx CRC    |
|       |         | CHAR 1    | CHAR 0        | Break     | Enable    | CCITT     |            | Enable    |
|       | 0 DTR=1 | 00 5 or L | ess Bits/CHAR | 0 Marking | 0 Disable | 0         | 0 RTS=1    | 0         |
| Async | 1 DTR=0 | 01 7 Bits | /CHAR.        | 1 Spacing | l Enable  |           | (all sent) |           |
|       |         | 10 6 Bits | /CHAR.        |           |           |           | 1 RTS=0    |           |
| Sync  |         | ll 8 Bits | /CHAR.        |           |           | 0 CCITT-0 | 0 RTS=1    | 0 Disable |
|       |         |           |               |           |           | 1 CRC-16  | 1 RTS=0    | l Enable  |

|          |     |                      |     | V    | IR7  |    |   |     |               |      |     | W     | R6   |     |   |   |
|----------|-----|----------------------|-----|------|------|----|---|-----|---------------|------|-----|-------|------|-----|---|---|
|          | 7   | 6                    | 5   | 4    | 3    | 2  | 1 | 0   | 7             | 6    | 5   | 4     | 3    | 2   | 1 | 0 |
| - 100    |     |                      | SYN | C Bi | t 15 | ∿8 |   |     |               | *    | SYN | C Bi  | t 7º | v 0 |   |   |
| Async    | not | t used               |     |      |      |    |   |     | not used      |      |     |       |      |     |   |   |
| Monosync | Rx  | x SYNC CHAR.         |     |      |      |    |   |     | Tx STNC CHAR. |      |     |       |      |     |   |   |
| Bisync   | SYN | YNC CHAR. Bit 15 ∿ 8 |     |      |      |    |   | SYN | С СН.         | AR.  | Bit | 7 ∿ 0 |      |     |   |   |
| EXT sync | not | not used             |     |      |      |    |   |     | Тх            | SYNC | CHA | R.    |      |     |   |   |

| RR0      | 7        | 6         | 5       | 4        | 3       | 2         | 1        | 0         |
|----------|----------|-----------|---------|----------|---------|-----------|----------|-----------|
|          | Break/   | Tx Under- | CTS     | SYNC/    | DCD     | Tx Buffer | INT      | Rx CHAR.  |
|          | Abort    | run/EOM   |         | Hunt     |         | Empty     | Pending  | Available |
|          | l Break  | Unknown   | 1 CTS=0 | 1 SYNC=0 | 1 DCD=0 | l Tx Buff | l INT    | 1 Rx CHAR |
| Async    | Detected |           | 0 CTS=1 | 0 SYNC=1 | 0 DCD=1 | Empty     | Pending  | Available |
| 1        | 0 Normal |           |         |          |         | 0 Tx Buff | 0 No INT | 0 Rx Buff |
|          | L        |           |         |          |         | Full      | Pending  | Empty     |
| EXT sync |          | 1 Tx      |         |          |         | 1 Tx Buff | (CH.A    |           |
|          | 0        | Underrun  |         |          |         | Empty     | only)    |           |
| Monosync |          | /EOM      | 1       | l Hunt   |         | 0 Tx Buff |          |           |
| Bisync   |          | 0 Not Tx  |         | Phase    |         | Full      |          |           |
|          |          | Underrun  |         | 0 Exit   |         | (With or  |          |           |
|          |          |           |         | Hunt     |         | without   |          |           |
|          |          |           |         | Phase    |         | CRC)      | ı        |           |
|          |          | L         | l       |          |         |           | L        |           |

| RR1   | 7               | 6                        | 5                      | 4                 | 3                 | 2                 | 1                 | 0                   |
|-------|-----------------|--------------------------|------------------------|-------------------|-------------------|-------------------|-------------------|---------------------|
|       | End of<br>Frame | CRC/<br>Framing<br>Error | Rx<br>Overrun<br>Error | Parity<br>Error   | Residue<br>Code 2 | Residue<br>Code l | Residue<br>Code O | All Sent            |
| Async |                 | l Framing<br>Error       | l Rx<br>Overrun        | l Parity<br>Error | Unknown           |                   |                   | l All Sent<br>O Not |
|       | 0               | 0 No Error               | Error<br>0 No Error    | 0 No Error        |                   |                   |                   | All Sent            |
| Sync  |                 | Error<br>0 No Error      |                        |                   |                   |                   |                   | 1                   |

| RR2                   | 7              | 6              | - 5            | 4              | 3         | 2              | 1              | 0              |
|-----------------------|----------------|----------------|----------------|----------------|-----------|----------------|----------------|----------------|
| WR1 D2=0              | V <sub>7</sub> | V <sub>6</sub> | V <sub>5</sub> | V <sub>4</sub> | V 3       | V <sub>2</sub> | V <sub>1</sub> | V <sub>0</sub> |
| WR1 D <sub>2</sub> =1 |                |                |                | 1 CH. A        | 00 Tx Buf | fer Empty      |                |                |
|                       |                |                |                | 0 СН. В        | 01 Extern | al/Status      |                |                |
|                       |                |                |                |                |           | Change         |                |                |
| WR2A D                | V7             | V <sub>6</sub> | V <sub>5</sub> |                | 10 Receiv | e Character    | V <sub>1</sub> | V <sub>0</sub> |
| D =00,01              |                |                |                |                |           | Available      |                |                |
|                       |                |                |                |                | ll Specia | 1 Rx           |                |                |
|                       |                |                |                |                |           | Condition      |                |                |

#### Note:

Register WR0 can be set directly, but other registers (WR1 to WR7) are set by setting the register number in WR0 and then setting the data. Further, RR0 can be read directly from the I/O port, but PR1 can only be read after its register number has been written into WR0.

## §6 Flexible Disks

# 6.1 Flexible disk layout

|           | tor<br>0 1      | 6              | 32             | 48 60 6                               |
|-----------|-----------------|----------------|----------------|---------------------------------------|
| ack<br>00 | Boot Loader     | ССР            | вроз           | · · · · · · · · · · · · · · · · · · · |
| .01       | OS (main bank)  |                |                |                                       |
| 02        |                 | I<br>BIOS ( sy | stem bank )    |                                       |
| 03        |                 |                |                |                                       |
| 04        | Directory & FCB | File block 1   | File block 2   | File block 3                          |
| 05        | File block 4    | File block 5   | File block 6   | File block 7                          |
|           |                 |                |                |                                       |
|           |                 |                |                |                                       |
| 38        | File block 136  | File block 137 | File block 138 | File block 139                        |
| 39        |                 | Unuse          | ed area        |                                       |

| Track | Sector | Page # | Memory address<br>when loaded<br>in QX-10 | CP/M Module name |
|-------|--------|--------|-------------------------------------------|------------------|
|       | _      |        |                                           | _                |
| 00    | 00,01  |        | 0F000Н                                    | Boot Loader      |
|       | 02,03  |        | 0F100H                                    |                  |
|       | 04,05  |        | 0F200H                                    |                  |
| ļ     | 06,07  |        | 0F300H                                    |                  |
|       | 08,09  | -      | 0F400H                                    |                  |
|       | 10,11  |        | 0F500н                                    |                  |
|       | 12,13  |        | 0F600н                                    |                  |
|       | 14,15  |        | 0F700H                                    |                  |
| 00    | 16,17  | 00     | 0Е000Н                                    | CCP              |
|       | 18,19  | 01     | 0Е100Н                                    |                  |
|       | 20,21  | 02     | 0Е200Н                                    |                  |
|       | 22,23  | 03     | 0Е300Н                                    |                  |
|       | 24,25  | 04     | 0Е400Н                                    |                  |
|       | 26,27  | 05     | 0Е500Н                                    |                  |
|       | 28,29  | 06     | 0Е600Н                                    |                  |
|       | 30,31  | 07     | 0Е700Н                                    |                  |
| 00    | 32,33  | 08     | 0Е800Н                                    | BDOS             |
|       | 34,35  | 09     | 0Е900Н                                    | ·                |
|       | 36,37  |        | ОЕАООН                                    |                  |
|       | 38,39  | 11     | 0ЕВ00Н                                    |                  |
|       | 40,41  | 12     | ОЕСООН                                    |                  |
|       | 42,43  | 13     | OEDOOH                                    |                  |
|       | 44,45  |        | OEEOOH                                    | ·                |
|       | 46,47  | 15     | ОЕГООН                                    |                  |
|       | 48,49  | 16     | 0F000н                                    |                  |
|       | 50,51  | 17     | 0F100H                                    |                  |
|       | 52,53  | 18     | 0F200H                                    |                  |
|       | 54,55  | , 19   | 0F300H                                    |                  |
|       | 56,57  | 20     | OF400H                                    |                  |
|       | 58,59  | 21     | 0F500H                                    |                  |

|    | r              |    |        |                    |
|----|----------------|----|--------|--------------------|
| 00 | 60,61          | 22 | 0F600н | BIOS (main bank)   |
|    | 62,63          | 23 | 0F700H |                    |
| 01 | 00,01          | 24 | 0F800н |                    |
|    | 02,03          | 25 | 0F900Н |                    |
|    | 04,05          | 26 | OFA00H |                    |
|    | 06,07          | 27 | 0FB00H |                    |
|    | 08,09          | 28 | 0FС00Н |                    |
|    | 10,11          | 29 | OFDOOH |                    |
|    | 12,13          | 30 | OFEOOH |                    |
|    | 14,15          | 31 | OFFOOH |                    |
| 01 | 16,17          | 32 | ОН     | BIOS (system bank) |
|    | 18,19          | 33 | 100н   |                    |
|    | 20,21          | 34 | 200н   |                    |
|    | 22,23          | 35 | 300н   |                    |
|    | 24,25          | 36 | 400н   |                    |
|    | 26,27          | 37 | 500н   |                    |
|    | 28,29          | 38 | 600н   |                    |
|    | 30,31          | 39 | 700H   |                    |
|    | 32,33          | 40 | 800н   |                    |
|    | 34,35          | 41 | 900н   |                    |
|    | 36,37          | 42 | 0А00н  |                    |
|    | 38,39          | 43 | 0в00н  |                    |
|    | 40,41          | 44 | 0С00н  |                    |
|    | 42,43          | 45 | 0D00н  |                    |
|    | 44,45          | 46 | 0Е00н  | ·                  |
|    | 46,47          | 47 | 0F00н  |                    |
|    | 48,49          | 48 | 1000н  |                    |
|    | 50,51          | 49 | 1100н  |                    |
|    | 52 <b>,</b> 53 | 50 | 1200н  |                    |
|    | 54,55          | 51 | 1300н  |                    |
|    | 56 <b>,</b> 57 | 52 | 1400н  |                    |

| 01       | 58 <b>,</b> 59 | 53 | 1500н | BIOS (system bank) |
|----------|----------------|----|-------|--------------------|
|          | 60,61          | 54 | 1600н |                    |
|          | 62 <b>,</b> 63 | 55 | 1700н |                    |
| 02       | 00,01          | 56 | 1800н |                    |
|          | 02,03          | 57 | 1900н | ·<br>·             |
|          | 04,05          | 58 | 1A00H |                    |
|          | 06,07          | 59 | 1в00н |                    |
|          | 08,09          | 60 | 1C00H |                    |
|          | 10,11          | 61 | 1D00H |                    |
|          | 12,13          | 62 | 1E00H |                    |
|          | 14,15          | 63 | 1F00H |                    |
|          | 16,17          | 64 | 2000н |                    |
|          | 18,19          | 65 | 2100н |                    |
|          | 20,21          | 66 | 2200н |                    |
|          | 22,23          | 67 | 2300н |                    |
|          | 24,25          | 68 | 2400н |                    |
|          | 26,27          | 69 | 2500н |                    |
|          | 28,29          | 70 | 2600н |                    |
|          | 30,31          | 71 | 2700н |                    |
|          | 32,33          | 72 | 2800н |                    |
|          | 34,35          | 73 | 2900н |                    |
|          | 36,37          | 74 | 2АООН |                    |
|          | 38,39          | 75 | 2в00н |                    |
|          | 40,41          | 76 | 2СООН |                    |
|          | 42,43          | 77 | 2D00Н |                    |
|          | 44,45          | 78 | 2ЕООН |                    |
|          | 46,47          | 79 | 2F00Н |                    |
|          | 48,49          | 80 | 3000н |                    |
| }        | 50,51          | 81 | 3100н |                    |
|          | 52,53          | 82 | 3200н |                    |
|          | 54,55          | 83 | 3300н |                    |
|          | 56,57          | 84 | 3400Н |                    |
| <u> </u> | <u> </u>       |    | 1     | <u> </u>           |

| T           | <del></del> |     |                | <b>*</b>           |
|-------------|-------------|-----|----------------|--------------------|
| 02          | 58,59       | 85  | 3500н          | BIOS (system bank) |
|             | 60,61       | 86  | 3600н          |                    |
|             | 62,63       | 87  | 3700н          |                    |
| 03          | 00,01       | 88  | 3800н          | ·                  |
|             | 02,03       | 89  | 3900н          |                    |
|             | 04,05       | 90  | нооає          |                    |
|             | 06,07       | 91  | 3в00н          |                    |
|             | 08,09       | 92  | 3С00н          |                    |
|             | 10,11       | 93  | 3D00Н          |                    |
|             | 12,13       | 94  | 3ЕООН          |                    |
|             | 14,15       | 95  | 3F00н          |                    |
|             | 16,17       | 96  | 4000н          |                    |
|             | 18,19       | 97  | 4100н          |                    |
|             | 20,21       | 98  | 4200н          |                    |
|             | 22,23       | 99  | 4300н          |                    |
|             | 24,25       | 100 | 4400н          |                    |
|             | 26,27       | 101 | 4500н          |                    |
|             | 28,29       | 102 | 4600н          |                    |
|             | 30,31       | 103 | 4700н          |                    |
|             | 32,33       | 104 | 4800н          |                    |
|             | 34,35       | 105 | 4900н          | ·                  |
|             | 36,37       | 106 | 4А00н          |                    |
|             | 38,39       | 107 | 4B00H          |                    |
|             | 40,41       | 108 | 4 <b>C</b> 00H |                    |
|             | 42,43       | 109 | 4D00H          |                    |
|             | 44,45       | 110 | 4E00H          |                    |
|             | 46,47       | 111 | 4F00H          |                    |
|             | 48,49       | 112 | 5000н          | 9                  |
|             | 50,51       | 113 | 5100н          |                    |
|             | 52,53       | 114 | 5200Н          |                    |
|             | 54,55       | 115 | 5300н          |                    |
|             | 56,57       | 116 | 5400н          |                    |
| <del></del> | <del></del> |     |                | ·                  |

| 03 | 58,59<br>60,61<br>62,63 | 117<br>118<br>119 | 5500н<br>5600н<br>5700н |                   |
|----|-------------------------|-------------------|-------------------------|-------------------|
| 04 | 00 - 15                 |                   |                         | (Directory & FCB) |
| 04 | 16<br>\$ 63             |                   |                         | (Data track)      |

#### 6.2 File directory structure

The file directory of the QX-10 MultiFonts CP/M disk is included in sectors 0 through 15 of track 4. This directory contains the names and locations of all files on the disk and their file attributes (R/O, system, etc.).

Disk locations from sector 16 of track 4 through sector 63 of track 38 are used as user data area. This area is divided into 139 2K-byte blocks, and files are managed based on the numbers of these blocks.

Up to 64 files can be cataloged in the file directory, which is divided into 64 32-byte blocks. Each directory block manages up to 32K bytes of a file. When the size of a file exceeds 32K bytes, additional directory blocks must be used together with the cataloged file name. When the entire user area of a disk is used for a single file, 9 directory blocks are required to manage that file.

The structure of each directory block is shown below.

| us | file | type | ex | xxx   | rc | file block |    |
|----|------|------|----|-------|----|------------|----|
| 00 | 01   | 09   | 12 | 13 14 | 15 | 16         | 31 |

us: Indicates whether or not the directory block is valid.

0: Valid

0E5H: Invalid

file: File name

type: File type

ex: Indicates the block size in 16K-byte (128 sector)

units. A number from 0 to 17.

xxx: Not used.

rc: Indicates the file size in sector units. A number from

0 to 128.

file block: Contains block numbers in which the file is

written.

When the MSB of the first byte of the file type is referred to as tl and MSB of the second byte as t2,

tl = 0 R/W file

= 1 R/O file

t2 = 0 DIR file

= 1 System file

#### Examples:

00 50 49 50 20 20 20 20 20 43 4F 4D 00 00 00 3A 36 37 38 39 00 00 00 00 00 00 00 00 00 00 00 00 The file name is PIP.COM and its size is 58 sectors.

00 2E 4B 41 4E 4A 49 20 20 D3 59 53 01 00 00 80 1A 1B 1C 1D 1E 1F 20 21 22 23 24 25 26 27 28 29

00 2E 4B 41 4E 4A 49 20 20 D3 59 53 03 00 00 40 2A 2B 2C 2D 2E 2F 30 31 32 33 34 35 00 00 00 00

The file name is .KANJI.SYS, and the file has the R/O attribute and a size of 448 sectors (128×3+64).

E5 54 45 53 54 20 20 20 20 41 53 4D 00 00 00 80 01 02 03 04 05 06 07 08 00 00 00 00 00 00 00 00

The indicated file (TEST.ASM, which has a length of 128 sectors) has been erased.

00 45 50 53 4F 4E 20 20 20 44 41 54 01 00 00 80 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F 10 The file name is EPSON.DAT and the size of the file is 2224 sectors (128×17+48).

00 45 50 53 4F 4E 20 20 20 44 41 54 11 00 00 30 81 82 83 84 85 86 87 88 89 8A 8B 00 00 00 00 00

#### 6.3 Disk error checks

If an attempt is made to access a flexible disk drive when that drive is not ready (e.g., when the drive door is open or a specified expansion drive is not connected), BIOS issues the "FDD TIME OUT" message. If the BREAK key is pressed at this time, control returns to CCP; if any other key is pressed, the access attempt is continued. To avoid this kind of situation, set OFFH in BASIC (address OFED4H) in the BIOS common data area. This causes the drive status to be stored in FDSTAT (address OFED3H), after which control returns to the program attempting access.



Error processing can then be performed within the user program after checking the contents of FDSTAT.

#### §7 Set-up for Auto-Start

Auto-start is the automatic loading of a specified command line for immediate execution into the CCP command buffer when a cold start is made. The contents of this command line are normally specified using the AUTOST transient command. However, it is also possible to specify the contents of the command line for auto-start execution after a warm or cold boot without using the AUTOST command. The auto-start command line can also be changed under certain program conditions. In such cases, the auto-start specification is changed using a program such as that shown below. The same procedure or the AUTOST command can be used again if it is necessary to restore the former contents of the auto-start command line.

```
BOOT
         EQU
                0
                             ; REBOOT TO SYSTEM
WBOOT
         EQU
                1
                             ; ADDRESS OF WARM BOOT
BDOS
         EQU
                5
                             ; BDOS ENTRY POINT
BREAK
         EQU
                03H
LF
         EQU
                OAH
                             ; LINEFEED
CR
         EQU
                9DH
                            ; CARRIAGE RETURN
CI
         EQU
                6
                            CONSOLE INPUT
CO
         EQU
                0
                            CONSOLE OUTPUT
SELDSK
         EQU
                24
                            ;SELECT DISK
SELTRK
         EQU
                27
                            SELECT TRACK
         EQU
                            SELECT SECTOR
SELSEC
                30
SETDMA
         EQU
                33
                             SET DMA ADDRESS
WRITE
         EQU
                39
                            ; WRITE DISK FUNCTION
SECTOR:
         DB
                ØEH.
DMAA:
         DS
                2
                            DMA ADDRESS
#
WRTDSK:
                B, 2
                             ; WRITE DATA TO 1 TRACK ØE, ØF SECTOR
         LD
         LD
                A, ØEH
         LD
                (SECTOR), A
         LD
                HL, DATA
         LD
                (DMAA), HL
WRT10:
         PUSH
                BC
         XOR
                Α
                             SELECT DISK
         CALL
                SEL
         LD
                BC.1
         CALL
                TRK
                            ;SELECT TRACK
         LD
                A, (SECTOR)
         CALL
                SEC
                             ; SELECT SECTOR
         LD
                BC, (DMAA)
                DMA
                             SET DMA ADDRESS
         CALL
                             ; NON-BLOCKING WRITE TO DISK
         CALL
                WRITE
         CF
                0
         POP
                BC
         JR
                NZ, WRTERR
                             ; IF ERROR
         LD
                HL, SECTOR
         INC
                (HL)
```

```
LD
                  HL, (DMAA)
                  DE,80H
          LD
          ADD
                  HL, DE
          LD
                  (DMAA), HL
          DJNZ
                  WRT10
WRTERR:
                                ; ERROR OCCURRED
SEL:
          LD
                  C,A
                                SELECT DISK
          LD
                  DE, SELDSK
          JR
                  EXBIOS
TRK:
          LD)
                  DE, SELTRK
                                ;SELECT TRACK
          JR
                  EXBIOS
SEC:
          LD
                  C, A
          L.D
                  DE, SELSEC
                                ; SELECT SECTOR
          JR
                  EXBIOS
DMA:
          LD
                  DE, SETDMA
                                SET DMA ADDRESS
          JR
                  EXBIOS
WRITE:
          LD
                  C, 1
                                ; NON-BLOCKING WRITE TO DISK
                  DE, WRITE
          LD
          JR
                  EXBIOS
EXBIOS:
          LD
                  IX, (WBOOT)
                                ;ENTRY BIOS
          ADD
                  IX, DE
          JP
                  (IX)
                  DATAEND-$-1-1; DATA LENGTH < 256
DATA:
          DB
          DB
                  'SAMPLE PARAM=1,2,3',0
DATAEND
          EQU
```

Here, data to be written into the command line area must be in the following format.



The number of characters in the data area is indicated by "Length" and the data set in "Data area" is the command which is to be input following the entry prompt (A>). All letters specified in the data area must be upper-case letters, and OH must be set at the end of the string as an end mark. This end mark is not included in the character count; therefore, the maximum number of characters which can be specified is 127 and the total length of the data area (including the end mark) is 128 bytes.

§8 UL/DL Programs and Conversion Utilities

#### 8.1 UL and DL programs

Programs developed on the QX-20 can be converted for execution on the QX-10. (This applies to any program files which operate under CP/M.) This is done using EPSON's UL (UpLoad) and DL (DownLoad) utility programs.

UL and DL programs for the QX-20 (DL, Vers. 4.0 and UL, Vers. 4.0) are distributed on double density, double sided, 96TPI flexible diskettes, and those for the QX-10 (DL, Vers. 0.2 and UL, Vers. 0.1) are distributed on double density, double sided, 48 TPI flexible diskettes.

#### Notes:

- Note that the CP/M operating system is not included on the file transfer program diskettes; therefore, be sure to boot up the QX-20 and QX-10 using your CP/M system diskettes before attempting to execute the UL or DL programs.
- 2. The QX-20 should be connected to the QX-10 via their RS-232C interfaces as shown in the figure below.



Operating procedures for the DL and UL programs are as follows.

- (1) Connect the QX-20 to the QX-10 as described above.
- (2) Boot up the CP/M operating system on the DL side (the QX-10).
- (3) Boot up the CP/M operating system on the UL side (the QX-20).
- (4) Insert the diskette containing the DL file transfer program in drive A of the QX-10.
- (5) Insert the diskette containing the UL file transfer program in drive A of the QX-20.

(6) Execute the DL program from the keyboard of the QX-10. The syntax for execution of the DL program is as follows.

If the <drive> specification is omitted, the file is downloaded to the active drive. If the <newfilename> specification is omitted, the file is downloaded under the name assigned to the file on the UL side.

File downloaded to active drive under name assigned on UL side.

>DL\_B:

File downloaded to drive B under name assigned on the UL side.

>DL\_\*.ASM File downloaded to active drive with file type changed to ".ASM".

#### Notes:

- 1. Execution of the DL program can be aborted by pressing the BREAK key.
- 2. If the file name under which the downloaded file is to be saved is the same as that of another file on the disk, the message "Overwrite (Y/N)?" is displayed; press the "Y" key if the current file is to be overwritten.)
- (7) Execute the UL program from the keyboard of the QX-20. The syntax for execution of the UL program is as follows.

If the <drive> specification is omitted, the file is uploaded from the active drive.

Examples: >UL\_A.MAC File A.MAC is uploaded.

>DL\_?.COM All .COM files are uploaded.

>DL\_B:\*.\* All files on the diskette in drive B: are uploaded.

#### Note:

Execution of the DL program can be aborted by pressing the BREAK key.

#### 8.2 BPTRNQX conversion utility

When a QX-20 MFBASIC program file is transferred to the QX-10 using the UL/DL commands or the SAVE/LOAD commands of BASIC, its syntax and parameters can be converted for use on the QX-10 by means of the BPTRNQX conversion utility. Program statements are converted according to the following rules.

1) CIRCLE (x,y), r, a, s, e,  $f \longrightarrow CIRCLE (x,y)$ , r, c, s', e', aHere r, c=0 when f is PRESET; otherwise, c is omitted. The value used for s' is  $s \times 6.283185$ , and that used for e' is  $e \times 6.283185$ .

- 2) PUT@  $(x1,y1)-(x2,y2),A,f \longrightarrow PUT@ (x1,y1),A,f$
- 3) CSRLIN --> (CSRLIN 1)

Procedures for using the BPTRNQX program are described below.

- a) After transferring the MFBASIC program file as described in 8.1 above, start up EPSON MFBASIC on the QX-10, then LOAD and RUN program file "BPTRNQX.BAS".
- b) The following message is then displayed.

You can translate program file of QX-20 into one of QX-10 by this program And you ?

YES--Y NO--N

Pressing the N key in response to this message terminates the program without doing anything; pressing the Y key causes the following message to be displayed to prompt for insertion of a flexible disk.

Please set floppy OK--Y

Insert a flexible disk in the appropriate drive and press the Y key; the message shown below is then displayed.

Floppy set completed!

c) The program then prompts for entry of the name of the file to be converted as shown below. Enter the complete file name, including the drive name. (The file must have been saved in ASCII format; otherwise, the error message "\*\*\*\*\* ERROR \*\*\*\*\*(NOT ASCII SAVE)" is displayed and conversion program execution ends.)

Example:

Please input sequential file name of QX-20 (ex. B:QX20.BAS)

d) After a proper name has been entered, the program prompts for entry of the name to be assigned to the QX-10 program file generated as follows.

Please input one of QX-10 (ex. A:QX10.BAS)

- If the same name is entered as in response to the prompt shown in (C) above, the prompt is displayed again.
- e) After a proper name has been entered, the following message is displayed to request confirmation that conversion is to be performed; press the Y key to make the conversion or the N key to return to the point described in (c) above.

OK--Y NO--N

f) The following message is displayed while the file is being

converted.

Running QX-20 B:QX20.BAS ----> QX-10 A:QX10.BAS

#### Note:

If the length of a converted line exceeds 255 characters, the following message is displayed and excess characters are discarded.

\*\*\*\*\* ERROR \*\*\*\*\* (LINE xx IS TOO LONG)

g) After conversion has been completed, the following message is displayed to ask whether there are any other program files to be converted.

Translate was completed Continue ?
YES--Y NO--N

Press the Y key if another program is to be converted; otherwise, press the N key.

#### \$9 CP/M program library installation

Many application programs are available for operation under CP/M, and you will probably wish to install many of these on the QX-10 for execution. However, there is no fixed installation procedure which will work in all cases. Some considerations are described below.

One of the most commonly utilized functions is that of cursor movement. The internal codes generated when the cursor control keys ( † , † , → , or ← ) are pressed are stored in XCHUP (address 0FE58H, default 01EH), XCHDOWN (address 0FE59H, default 01FH), XCHRIGT (address 0FE5AH, default 01CH), and XCHLEFT (address 0FE5BH, default 01DH).

Further, the current horizontal position of the cursor (1 to 80) is stored in HPOS (address 0FE75H) of the BIOS common data area and the current vertical position (1 to 25 in the non-MFBASIC normal mode and 1 to 20 in the non-MFBASIC MF mode or MFBASIC mode) is stored in VPOS (address 0FE76H).

See the list of escape sequences in the Appendix for the console escape sequences.

Any type of printer can be connected; set the print size to match that of the printer used.

Screen sizes which can be specified are 80 columns x 25 lines for the non-MFBASIC normal mode, and 80 columns x 20 lines for the non-MFBASIC MF mode and MFBASIC mode. The user must switch between these three modes by changing the contents of MBFLG (address 0FE50H) and MFLG (address 0FE82H) in the BIOS common data area.

Set the data according to the program or source program to be installed. For details, see the individual installation manual.

|         | MFLG=0                     | MFLG=1                 |
|---------|----------------------------|------------------------|
| MBFLG=0 | Non-MFBASIC<br>Normal mode | Non-MFBASIC<br>MF mode |
| MBFLG=1 | MFBASI                     | C mode                 |