| RCSL No: | 99 0 00825       |
|----------|------------------|
| Edition: | 1985.01.10       |
| Author:  | Knud Erik Hansen |

Title:

RC759 CPU board Reference Manual

RCSL Nr. 46-F 0087



# **Keywords:**

RC 759, CPU board, reference

# Abstract:

This paper contains the information necessary to program the RC759.

# (56 printed pages)

Copyright © 1984, A/S Regnecentralen af 1979 RC Computer A/S Printed by A/S Regnecentralen af 1979, Copenhagen

Users of this manual are cautioned that the specifications contained herein are subject to change by RC at any time without prior notice. RC is not responsible for typographical or arithmetic errors which may appear in this manual and shall not be responsible for any damages caused by reliance on any of the materials presented.

| TAB | LE OF CONTENTS                                                                                                                                                                                                             | PAGE                                                                                                      |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| 1.  | CPU<br>1.1 Memory<br>1.2 Direct Memory Access<br>1.3 I/O<br>1.4 Interrupt                                                                                                                                                  | • 4<br>• 6<br>• 6                                                                                         |
| 2.  | CRT CONTROL<br>2.1 Generel<br>2.2 Functional Description<br>2.2.1 82730 Coprocessor<br>2.2.2 Pixel Memory<br>2.2.3 Palet<br>2.2.4 CRT Timing<br>2.2.5 Graphic Mode<br>2.2.6 Display Kind Indication<br>2.2.7 CRT Interrupt | <ul> <li>8</li> <li>10</li> <li>10</li> <li>13</li> <li>14</li> <li>18</li> <li>19</li> <li>19</li> </ul> |
| 3.  | KEYBOARD                                                                                                                                                                                                                   | . 20                                                                                                      |
| 4.  | NON VOLATILE MEMORY                                                                                                                                                                                                        | . 21                                                                                                      |
| 5.  | REAL TIME CLOCK                                                                                                                                                                                                            | • 22                                                                                                      |
| 6.  | SOUND DEVICE                                                                                                                                                                                                               | . 30                                                                                                      |
| 7.  | iSBX CONNECTOR                                                                                                                                                                                                             | . 34                                                                                                      |
| 8.  | CASSETTE INTERFACE                                                                                                                                                                                                         | . 35<br>. 36                                                                                              |
| 9.  | <pre>Floppy/Printer Connector</pre>                                                                                                                                                                                        | . 39<br>. 39<br>. 40<br>. 41<br>. 41<br>. 41<br>. 41                                                      |
| 10. | LOCAL PRINTER CONTROLLER                                                                                                                                                                                                   | • 43                                                                                                      |
| 11. | PPI 8255<br>11.1 Port A (IOBASE + 70)<br>11.2 PORT B (IOBASE + 72)<br>11.3 PORT C (IOBASE + 74)<br>11.4 Control word (IOBASE + 76)                                                                                         | • 44<br>• 45<br>• 45                                                                                      |
| 12. | ADDRESSES                                                                                                                                                                                                                  | . 47                                                                                                      |

·. · i

)

Э

Э

1

).

| Α. | INDIC | CES    | • • • | • • • • • • | •• | • • • • | • • • | • • • | • • • | <br>• • • | ••• | • • • | • • • | • • • | •   | • • •  | • • • • | 49 |
|----|-------|--------|-------|-------------|----|---------|-------|-------|-------|-----------|-----|-------|-------|-------|-----|--------|---------|----|
|    |       |        |       |             |    |         |       |       |       |           |     |       |       |       |     |        |         |    |
|    | A.1   | Survey | of    | Figure      | s  |         | • • • |       |       | <br>      |     |       |       | • • • | • • | • • •. |         | 49 |

PAGE



 $\mathbf{O}$  $\mathbf{)}$ • 

# PREFACE

Additional related information can be found in the following publications:

- IAPX186 Data Sheet
- INTEL Microprocessor and Peripheral Handbook (8255, 8259)
- 82730 CRT Controller Architectural Overview
- INTEL82730 Data Sheet
- Western Digital FD1897 Data Sheet

## 1. CPU

The system is based on an Intel 80186 single chip CPU. This CPU is described in detail in the Intel Reference Manual. 1.

This section describes how the pheriperals and memory are connected to the CPU.

80186 can handle up to 1M bytes of memory. The RC759 CPU board is euipped with 256 Kbytes of general memory, 32 K bytes of memory dedicated to the CRT controller, but accessed by the CPU as normal memory, and finally up to 64 Kbytes of ROM (Read only memory) for autoload and Comal 80.

The following peripherals are standard.

- CRT control
- local parallel printer interface
- Keyboard input
- Non Volatile Memory
- Real Time Clock
- Sound device
- iSBX connector
- cassette tape
- connector to micronet interface
- connector to adapter for external floppy/printer switch unit

The interconnections of these are shown on the blockdiagram fig. 1.



Fig. 1. Piccoline Block Diagram

A14809

# 1.1 Memory

The memory consists of at least the following parts:

1. 256 K bytes of general memory

2. 32 k bytes of Pixel memory used by the CRT

3. 64 K bytes of Read Only Memory

128 K of address space is left for memory extension. The address space is divided into the areas shown on fig. 2.

The CPU runs at 6MHz, which gives rise to a maximum of 2 memory accesses every microsecond. The memory chips used are fast enough to avoid the insertion of wait states. Only access to the CRT-memory may delay the CPU slightly, because of the heavy load the CRT imposes on this memory. 1.1



Fig. 2. Memory Address Layout

The memory is of dynamic RAM type, and needs periodical refresh cycles. When the CRT controller is initialized, the line sync pulses are used to generate refresh requests. But while the CRT controller is uninitialized, the CPU must maintain refresh of the memory. This can be done by letting one of the DMA channels repeatingly move a block of 256 words (512 bytes) to the same locations.

#### 1.2 Direct Memory Access

The 80186 has two integrated DMA channels which are connected to the iSBX connector and to the I/O expansion for external Floppy/printer box.

DMA channel 0 is connected to iSBX connector. DMA channel 1 is connected to I/O expansion connector. Refer to section 11.0 for details about control of the DMA channels.

# **1.3** I/0

The peripherals are addressed via the seven PCS signals generated by the CPU. PCS0 controls eight chipselect signals on the CPU-board: PCS00 to PCS07 selected by means of the address bits A4 to A6.

As the pheripherals are connected to the least significant eight bits of the databus, the devices can only be accessed with even addresses. This gives each PCSx 64 addresses, and each PCS0x 8 addresses.

The PCS signals are allocated either I/O space or memory address space by programming a word in the controlblock (see the iAPX186 manuals).

## 1.4 Interrupt

The peripherals able to interrupt the CPU are connected to this via a 8259A (Programmable Interrupt Controller). This is programmable via the port controlled by PCS0,0. 1.4

1.2

The IR inputs are connected as follows:

| IR0 | : | I/O expansion (Floppy)  |
|-----|---|-------------------------|
| IRl |   | Keyboard                |
| IR2 | : | I/O expansion (Printer) |
| IR3 | : | Real Time Clock         |
| IR4 | : | CRT                     |
| IR5 | : | NET                     |
| IR6 | : | Parallel printer        |
| IR7 | : | not used                |

8259 is connected to the INTO and INTAO terminal of the CPU in cascade mode.

Programming of the 8259 A takes place via the following addresses:

Initialization command word: I/O base + 0 Operation command word: I/O base + 2

For programming the internal CPU interrupt controller, see the iAPX186 reference manual: Bit 5 (c) in the INTO control registers should be set to 1. Bit 5 (C) in the INT1 control registers should be set to 0.

INT1 and INT3 on the 80186 CPU is connected to the iSBX connector.

## 2. CRT CONTROL

#### 2.1 Generel

The CRT controller is build around an Intel 82730 coprocessor, which fetches characters in memory for display controlled by a channel program.

The characters are stored in a rowbuffer to avoid 10 redundant refetches of the characters in mainmemory. Then the character codes combined with a scanlinenumber generated by the 730 is used to address the character generator/Pixel memory.

The CRT controller should maintain a frame-frequency of about 50 Hz, (option 60 Hz), each frame containing 275 videolines with 560 pixels each.

The controller will perform equally well as a memory mapped pixel graphic display, and a conventional alphanumeric display. 2.



# Fig. 3. Blockdiagram of the CRT system

The least significant 10 bits of the character code combined with the scanline address directly address the pixel memory to output a 16 bit 'word' of which at least 7 bit and at most all 16 bit are used as a dot pattern, shifted out of the shifter to be used as dot colour selector. In alpha mode, the bits select one of two colours, and in graphics either one out of two or four colours from a palet of 16 colours. If four colours are choosen in graphics mode, the dot frequency (horizontal resolution) is only 6 MHz (280 dots).

# 2.2 Functional Description

# 2.2.1 82730 Coprocessor



Fig. 4. 82730 Block Diagram

Figure 4 shows a block diagram of the 82730. The chip is divided into two main sections. The Memory Interface Unit (MIU) and the Display Generator (DG). The MIU provides the communication between the 82730 and system processor and memory, while the DG acts on the display data and carries out the display operation.

Communication between the 82730 and the CPU takes place through messages placed in communication blocks in shared memory. The processor issues channel commands by preparing these message blocks and directing 82730's attention to them by activating the а hardware channel attention signal (CA). The MIU fetches and executes these commands. When the display process is activated, the 82730 repeatedly fetches display data and embedded datastream commands from memory utilizing its built-in DMA capability, executes any datastream commands as encountered on the fly, and loads the row buffers with the display data. After executing these commands, the 82730 clears a busy flag in memory, to inform the host CPU that it

10

2.2

2.2.1

### is ready for the next command.

The MIU is divided into two sections. The Bus Interface Unit (BIU) and the Micro Controller Unit (MCU). The BIU process the electrical interface to the system bus, and the timing signals required for the MCU operations, making these operations transparent to the MCU. The 82730 can be programmed during initialization to provide 8 or 16 bit data, and 16 or 32 bit addressing.

The MCU contains the microinstruction store and the associated circuitry required for the execution of all channel and datastream commands. It uses the BIU in carrying out its memory access tasks such as loading the row buffers with display data.

The interaction between the MCU and the DG takes place through shared internal storage. The MCU fetches data from memory and writes it in the internal storage, while the DG reads from the internal storage and carries out the display operation. The MCU and DG operate asynchronously with respect to each other. Synchronization is accomplished through communication via internal flags and display timing The internal shared signals generated by the DG. storage consists of Row Buffers which store the display data and internal registers which store display parametes. There are two row buffers each capable of storing up to 200 characters. The data in one row buffer is used by the DG to display one complete character row on the screen, while the MCU is loading the second row buffer with display data fetched from memory. At the end of the row being displayed, the buffers are swapped and the MCU and DG resume their respective tasks.

The Display Characteristics Registers contain all the information used to control every aspect of display characteristics from screen size to blink rates. A major portion of this register sets is the three Content Addressable Memory (CAM) arrays that allow very flexible timing control for row and screen characteristics. The user has the power to set the parameter for the entire screen by invoking a single high level command.

By separating the Video Interface clocks from the Bus Interface clock, the 82730 provides the designer the ability to independently maximize the performance of

#### the CPU and Video sections of the system.

The Video interface consists of two independent clocks: the Reference Clock (RCLK) and the Character Clock (CCLK). While the RCLK controls the raster timing and defines the screen layout, the CCLK independently shifts character and attribute information out of the 82730, which allows proportional spacing to be achieved.

It is this combination of hardware features and high level command interface that makes the 82730 the first VLSI Text Coprocessor which simplifies hardware design and software development.

The characters output from the DG have the following formats in alphanumeric mode:

| 15 | 14          | 10 | 9         | 0       |
|----|-------------|----|-----------|---------|
| 0  | Palette sel |    | Character | address |

or in graphic mode:

| 15 | 14 | 13 10       | 9        | 0            |
|----|----|-------------|----------|--------------|
| 0  | L  | Palette sel | Pixel bl | ock address. |

If bit 15 is 1, the character is a command to the 82730 and it is not output by the DG. The remaining 15 bits are used in the illustrated way, depending on the graphic/nongraphic mode. In both cases, bits 0 to 9 are concatened to the video linenumber output by the DG and used as an address into the Character generator/Pixel memory.

In nongraphic mode, bits 10 to 14 are used to select a foreground/background - colourpair from the palette.

In graphic mode, bits 10 to 13 are used to select a colour quartet from the palett. In graphic mode bit 14 selects low resolution if 1.

In low resolution two dots are combined to one four state pixel being capable to have any of the four colours selected with bits 10 to 13. In high resolution, each dot being a two state pixel can have one of the two first colours in the guartet.

#### 2.2.2 Pixel Memory

The Pixel memory has the task to supply the dot shifter with information. The address into the Pixel memory consists of 10 bits output from the refresh memory plus 4 bits scan linenumber from the 82730.

Pixel memory address:

| 14 | 13 | 12 | 11   | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2     | ]   | 0 |
|----|----|----|------|------|---|---|---|---|---|---|-----|-------|-----|---|
|    |    |    | char | acte | r |   |   |   |   |   | sca | an li | ine |   |

bit 0 is not used, as 16 bit words are addressed.

Pixel memory address = 2% (video line number + 16% character).

The output word contains 16 bit and is used in three different ways controlled by the attribut.

A. character line:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----|
| đ  | đ  | đ  | đ  | đ  | đ  | đ | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | _1 |

first displayed

One line of a 7 dots wide character is shown. The bits d are the dots of the character in the same order as on the screen (left to right). The zero in bit 8 succeeded by all ones are lenght designators. The character cannot be narrower than 7 and not wider than 15 dots.

B. High resolution graphic line:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| đ  | đ  | đ  | đ  | đ  | đ  | đ | đ | đ | đ | đ | đ | đ | đ | d | đ |

first displayed.

2.2.2

The bits d are all displayed in the indicated sequence. As in the nongraphic mode each d select one of two colours.

C. Low resolution graphic line:

| 15 14                         | 13             | 12             | 11 | 10             | 9  | 8              | 7 | 6              | 5              | 4              | 3  | 2              | 1  | 0              |
|-------------------------------|----------------|----------------|----|----------------|----|----------------|---|----------------|----------------|----------------|----|----------------|----|----------------|
| c <sub>1</sub> c <sub>0</sub> | C <sub>1</sub> | C <sub>0</sub> | Cl | c <sub>0</sub> | C1 | c <sub>0</sub> | ۲ | C <sub>O</sub> | C <sub>1</sub> | c <sub>0</sub> | C1 | c <sub>0</sub> | Cl | C <sub>0</sub> |

first displayed

The nipples (Cl, CO) are displayed in the indicated sequence.

Each pixel occupies the space of two dots on the screen but can select one out of four colours (intensities) from the palette.

The Pixel memory has a size of 16K x 16bit or 32 K bytes and is accessible from the cpu as normal memory in the area D8000 to DFFFF Hex.

In graphic mode accesses to the Pixel memory may cause the CPU to go through a number of wait states before the memory becomes idle, because of the heavy load, the CRT imposes on it.

When nongraphic mode is selected, and narrower characters than 15 dots are displayed, the pixel memory will be busy serving the CRT all other time but during the retraces. This would give very long latencytimes and hence waiting times for the CPU with normal programmed access to the pixel memory, so in this mode it is recommended to access the pixel memory via DMA or with the 82730 stopped.

#### 2.2.3 Palet

The output of the dot shifter is used to select one of two or four colours or intensities from a Palet. The Palet has room for 32 4 bit nibbles. The nibbles has the following meaning:

| 3 | 2 | 1 | 0 |
|---|---|---|---|
| I | R | G | В |

2.2.3

if I is set the Intensity is increased. (It has no meaning with the normal 50HZ monitor. This signal is only valid with the optional 60 HZ monitor).

if R is set the Red beam is turned on. if G is set the Green beam is turned on. if B is set the Blue beam is turned on.

this gives the following effects:

value of the

| <u>colc</u> | our nipple | colour        | intensity (B&W) |
|-------------|------------|---------------|-----------------|
|             | IRGB       |               | ·               |
| 0           | 0000       | Black         | zero            |
| ٦           | 0001       | Blue          | 7               |
| 2           | 0010       | Green         |                 |
| 3           | 0011       | Cyan          | not defined     |
| 4           | 01 00      | Red           |                 |
| 5           | 0101       | Magenta       |                 |
| 6           | 0110       | Brown         | ¥               |
| 7           | 1110       | Ligh gray     | normal          |
| 8           | 1000       | Dark gray     | low             |
| 9           | 1001       | Light blue    | <b>4</b> .      |
| 10          | 1010       | Light green   |                 |
| וו          | ווסו       | Light cyan    | not defined     |
| 12          | 1100       | Light red     |                 |
| 13          | 1101       | Light magenta |                 |
| 14          | 01110      | Yellow        | ¥.              |
| 15          | 1111       | White         | high            |

The palet is written with a white instruction to the area IO Base + 180 to 1BF Hex.

The illustration shows which colour pairs are accessed on which addresses.

The number inside the boxes refer to the identity of the palette cells.

| Address    |      | bit | 7654 | 3210 |
|------------|------|-----|------|------|
| I/O base + | 180  |     | 1    | 0    |
|            | 182  |     | 3    | 2    |
|            | 184  |     | 5    | 4    |
|            | 186  |     | 7    | 6    |
|            | 188  |     | 9    | 8    |
|            | 18A  |     | 11   | 10   |
|            | 18C  |     | 13   | 12   |
|            | 18E  |     | 15   | 14   |
|            | 190  |     | 17   | 16   |
|            |      |     |      |      |
|            | 1B4  |     | 53   | 52   |
|            | 1B6  |     | 55   | 54   |
|            | 1 B8 |     | 57   | 56   |
|            | 1 BA |     | 29   | 58   |
|            | 1 BC |     | 61   | 60   |
|            | 1 BE |     | 63   | 62   |
|            |      |     |      |      |

IRGBIRGB

When accessed by the crt controller, the palet is organized in the following ways:

alphanumeric attribute

|      | the second s |
|------|----------------------------------------------------------------------------------------------------------------|
| ١    | 0                                                                                                              |
| 3    | 2                                                                                                              |
| 5    | 4                                                                                                              |
| 7    | 6                                                                                                              |
| 9    | 8                                                                                                              |
| 11   | 10                                                                                                             |
| 13   | 12                                                                                                             |
| 15   | 14                                                                                                             |
|      |                                                                                                                |
| 51   | 50                                                                                                             |
| 53   | 5Ż                                                                                                             |
| 55   | 54                                                                                                             |
| 57   | 56                                                                                                             |
| 59   | 58                                                                                                             |
| 61   | 60                                                                                                             |
| 63   | 62                                                                                                             |
| IRGB | IRGB                                                                                                           |

d=1 d=0

# Low resolution graphics:

attribute IRGBIRGBIRGBIRGB  $(c_1, c_0) = 11$ 

Classical attributes as blinking, non displayed, inverse or intensified may be implemented by loading proper colour values into the different palet cells.

E.g. nondisplayed is obtained by having a palette selector selecting a set of palet cells containing some colour in foreground and background (for D=1 and D=0), and a blinking attribute is maintained by changing the foreground five or six times per second.

## 2.2.4 CRT Timing

The 82730 takes care of the CRT timing i.e. the Vertical and Horizontal sync pulses and the visible picture field. These timing pulses are generated from a 1,25 MHz clock called RCLK (see Intel 82730 manual). Various constant must be programmed into the 82730 at initialization time. These constants indicate duration of a videoline, position and with a sync pulse, start and stop at visible field in terms of RCLK counts.

For a 720 dot per videoline-screen, the visible part of the video line should have a duration of 45 RCLK's.

Mode PARAMETERS to 82730 for a 50Hz, 15.625 KHz monochrome monitor, with 25 x 80 characters and a dotmatrix of 7 x 11.

| HSYNCSTP | =   | 8   |
|----------|-----|-----|
| HBRDSTRT | =   | 24  |
| HFLDSTRT | =   | 25  |
| HFLDSTP  | =   | 105 |
| HBRDSTP  | Ξ   | 106 |
| LINELEN  | =   | 114 |
| VSYNCSTP | =   | 3   |
| VFLDSTRT | =   | 27  |
| VFLDSTP  | =   | 309 |
| FRAMELEN | - = | 312 |

2.2.4

## 2.2.5 Graphic Mode

If bit 6 in the output register C of the 8255 PPI is set to 1 graphic mode is selected. For access of 8255 PPI see chapter 11.

## 2.2.6 Display Kind Indication

Bit 6 and 5 in port B of the PPI (see chapter 11) are used to indicate which kind of display is connected to the system.

Bit 5 = 0 indicates a colour display is attached. Bit 5 = 1 indicates a monochrome display. Bit 5 = 0 indicates a linefrequency of 15,625 KHz Bit 6 = 1 indicates a linefrequency of 22 KHz

## 2.2.7 CRT Interrupt

The 82730 may be programmed to generate interrupt on several conditions. Interrupts from 82730 are connected to the Int 4 input of the 8259.

2.2.7

2.2.5

2.2.6

# 3. **KEYBO**ARD

The keyboard is connected to the system via a special serial port on address IO base + 20 Hex. When a character is received, an interrupt is generated (IRI activated), and no further characters will arrive before the character is read. 3.

The powersupply to the keyboard is controlled by means of bit 7 in the C register of the PPI (see chapter 11).

If bit 7 is set to 1, the KB power is on. If bit 7 is set to 0, the KB power is off.

Within 0,5 - 1,0 sec. after power-up, the keyboard must be read in order to initialize the keyboard-receiver circuit.

Approximately 2 sec. after power-up, the keyboard will transmit a self-test- complete code, or 1 to 3 errorcodes. The next transmittet character, will be the character, identifying the version of the keyboard (Nationality code).

## 4. NON VOLATILE MEMORY

The "NVM" is made up by a 256 by 4 bit CMOS RAM with battery backup.

4.

The NVM is divided into 4 blocks of 64 words by 4 bits each. One of the four blocks is selected by means of bit 4 and 5 in port C of the PPI (se chapter 11).

Inside the selected block, the 64 words are accessible on the even addresses from I/O base+ 80 to I/O base + FE.

The four bits is connected to bits 0 to 3 of the I/O bus.

When accessing the NVM, 3 wait-states must be used, i.e. 3 wait-states must be programmed into the CPU.

# 5. REAL TIME CLOCK

The Real Time Clock is a CMOS LSI chip with battery backup, which allows the clock to continue the counting when the system is powered down.

The Real Time Clock (RTC) is a very "slow" device, so a special read and write procedure is to be performed.

In the following description of the procedure, A is indicating the internal addresses and the registers and latches containing the time information.

# Read the RTC

| ADD.     | OPERAT | TION | DATA BUS                  |                    |
|----------|--------|------|---------------------------|--------------------|
| I/O BASE | WRITE  | READ | BIT NO.                   |                    |
| +        |        |      | 76543210                  | COMMENTS           |
| 5C H     | х      |      | 100A 4A 3A 2A 1A 0        | Put on the         |
|          |        |      |                           | address of the     |
|          |        |      |                           | desired register   |
|          |        |      |                           | or latch           |
| 5C H     | X      |      | 101A 4A 3A 2A 1A 0        | Create an inter-   |
|          |        |      |                           | nal read-pulse     |
|          | WAIT   | FOR  | lµS (2 internal CPU Cycle | s)                 |
| 5C H     |        | x    | RTC DATA                  | Read data from RTC |
| 5C H     | X      |      | 100A 4A 3A 2A 1A 0        | Remove the inter-  |
|          |        |      |                           | nal read-pulse     |

5.

# Write to the RTC

| ADD.     | OPERATION    | DATA BUS                              |                   |
|----------|--------------|---------------------------------------|-------------------|
| I/O BASI | E WRITE READ | BIT NO.                               |                   |
| +        |              | 76543210                              | COMMENTS          |
| 5 CH     | x            | 000A'4A'3A'2A'1A'0                    | Put on the        |
|          |              |                                       | address of the    |
|          |              |                                       | desired register  |
|          |              |                                       | or latch          |
| 5 CH     | x            | RTC DATA                              | Read data to RIC  |
| 5 CH     | x            | 010 A'4A'3A'2A'1A'0                   | Create an inter-  |
|          | ·            | ·                                     | nal write-pulse   |
|          | WAIT FOR 1   | µS (2 internal CPU Cycle              | s)                |
| 5 CH     | x            | 000A'4A'3A'2A'1A'0                    | Remove the inter- |
|          |              | · · · · · · · · · · · · · · · · · · · | nal write-pulse   |
|          |              |                                       |                   |

The following table is showing the content of the internal registers and latches.

| In | teri | nal | Ado | dr. |       |                    | READ  |
|----|------|-----|-----|-----|-------|--------------------|-------|
| Bi | t na | 5.  |     |     |       | Function           | WRITE |
| A4 | A3   | A2  | A1  | AO  | (HEX) |                    |       |
| 0  | 0    | 0   | 0   | 0   | (00)  | C Seconds * 0.0001 |       |
| 0  | 1    | 0   | 0   | 0   | (08)  | L                  |       |
| 0  | 0    | 0   | 0   | 1   | (01)  | C Seconds * 0.01   |       |
| 0  | 1    | 0   | 0   | 1   | (09)  | L                  |       |
| 0  | 0    | 0   | 1   | 0   | (02)  | C Seconds          |       |
| 0  | 1    | 0   | 1   | 0   | (OA)  | L                  |       |
| 0  | 0    | 0   | 1   | 1   | (03)  | C Minutes          |       |
| 0  | 1    | 0   | 1   | 1   | (0B   | L                  | R/W   |
| 0  | 0    | 1   | 0   | 0   | (04)  | C Hours            |       |
| 0  | 1    | 1   | 0   | 0   | (0C)  | L                  |       |
| 0  | 0    | 1   | 0   | 1   | (05)  | C Day of week      |       |
| 0  | 1    | 1   | 0   | 1   | (OD)  | L                  |       |
| 0  | 0    | 1   | 1   | 0   | (06)  | C Day of month     |       |
| 0  | 1    | 1   | 1   | 0   | (OE)  | L                  | ·     |
| 0  | 0    | 1   | 1   | 1   | (07)  | C Months           |       |
| 0  | ٦    | ٦   | 1   | 1   | (OF)  | L                  |       |
| 1  | 0    | 0   | 0   | 0   | (10)  | Interrupt Status   | R     |
| 1  | 0    | 0   | 0   | ٦   | (11)  | Interrupt Control  | W     |
| 1  | 0    | 0   | 1   | 0   | (12)  | C reset            | W     |
| 1  | 0    | 0   | 1   | 1   | (13)  | L reset            | Ŵ     |
| 1  | 0    | 1   | .0  | 0   | (14)  | Status bit         | R     |
| 1  | 0    | 1   | 0   | 1   | (15)  | "GO" command       | W     |
| 1  | 0    | 1   | 1   | 0   | (16)  | Standby Interrupt  | W     |
| 1  | 1    | 1   | 1   | 1   | (1F)  | Test mode          |       |

The following table is showing the content of the internal registers and latches.

L = latch C = counter.

The clock contains a counter chain counting from the crystal frequency of 32768 Hz down to one/year.

Moreover the clock contains a latch of same length and format as the counter. Both the latch and the counter may be read and loaded at any time. The counter and latch are constantly compared giving an interrupt (it enabled) when they are equal. This means that you may receive an interrupt on a certain millisecond this year.

Both counter and latch are divided into sections corresponding to normal decimal notation:

|   | <u></u> | 1 |   |   |   | 1 |   |   |   |   |   | 1 |   |   |   |  |
|---|---------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|
| ٦ | 9       | 3 | 9 | 0 | 7 | 2 | 9 | 5 | 9 | 5 | 9 | 9 | 9 | 9 | 0 |  |
|   |         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |

Month Day of M. Day of W Hour Minute Second S\*0.01 S\*0.0001

This illustration shows the maximum value of the single BCD digits (four bit groups), not the maximum value of the byte. These are different for

Month : 11 Day of M. : 31, 30, 29 or 28 Hour : 23

Three reset commands exist:

Latch reset Counter reset and "Go" command.

The latch reset and counter reset clear the byte specified by the data in the write command:

Only one bit may be set, and the byte to be cleared is pointed out as follows:

D0 : Sec. X 0.0001 D1 : Sec. X 0.01 D2 : Seconds D3 : Minutes D4 : Hours D5 : Day of week D6 : Day of month D7 : Month

The same is done by writing a zero into the corresponding register.

By means of the "Go" command the second counter, and the "fraction of a second" counters are reset, to enable an exact starting time. By setting one or more bits in the interrupt control register, interrupt will occur on IR3 on one or more of the following events:

D0 : Counter: = latch D1 : sec. ¥ 0.1: = 0 D2 : Seconds: = 0 D3 : Minutes: = 0 D4 : Hours: = 0 D5 : Day of week: = 0 D6 : Day of month: = 0 D7 : Month: = 0

(:=) means that the counter rolls over.

By reading of the status register, it can be deduced which of the above mentioned reasons had caused the interrupt.

After the time is read the statusbit in address 14 H should be read also. This bit is gated to D0 and indicates if the counters have changed during the read operation, making the reading unsafe.

When bit no. 1 in the PPI port B "0" the following description of the internal registers and latches will be valid.

## Control register

| This register controls | the following:       |   |
|------------------------|----------------------|---|
| Frequency select       | (BO, B1)             |   |
| Start/stop             | (B2)                 |   |
| Counter/Latch Control  | (B3)                 |   |
| Clock select           | (B4, B5, B6, B7)     |   |
| 1 1                    |                      |   |
| Control register: B7   | B6 B5 B4 B3 B2 B1 B0 | ) |

The frequency select bits (B0, B1) must always be 00 (zero). This indicates that the reference frequency used by the RTC will be 32768Hz.

The start/stop bit (B2) starts and stops the RTC. B2 = 1 starts the RTC. B2 = 0 stops the RTC.

The counter/latch control selects the counter or the latch function of a certain register.

B3 = "0" = "Write to counter and disable alarm". B3 = "1" = "Write to latch and enable alarm".

If first B3 is set to "0" and then date is written to i.e. the address XX011 then the minutes counter is located. At the same time the alarm is disabled. I.e. that no RTC-interrupt will occur. When the contents of the counters matches the contents of the alarm latches. If the alarm is to be enabled the control register must be accessed and B3 set to "1". When data is written to address XX011 while B3="1" then the minutes alarm latch will be accessed.

The clock select bits (B7, B6, B5, B4) controls the rate of which interrupts occur.

An RTC-interrupt can be generated in two different ways: As described above an interrupt will occur when B3 in the control register is set to "1" and the content of the counters matches the content of the latches.

The second way to generate an RTC-interrupt is to choose a clock-signal (50% duty cycle) as the interrupt source. The following table shows the possible clock-signals.

| в7 | B6 | B5 | B4 |         |    |
|----|----|----|----|---------|----|
| 0  | 0  | 0  | 0  | disable |    |
| 0  | 0  | 0  | 1  | 488,2   | μS |
| 0  | 0  | ٦  | 0  | 976,5   | μS |
| 0  | 0  | 1  | 1  | 1953,1  | μS |
| 0  | 7  | 0  | 0  | 3906,2  | μS |
| 0  | ٦  | 0  | ٦  | 7812,5  | μS |
| 0  | 7  | 1  | 0  | 15,625  | μS |
| 0  | 1  | 1  | ٦  | 31,25   | μS |
| 1  | 0  | 0  | 0  | 62,5    | μS |
| 1  | 0  | 0  | 1  | 125     | μS |
| 1  | 0  | 1  | 0  | 250     | μS |
| ٦  | 0  | ٦  | ٦  | 500     | μS |
| ٦  | 1  | 0  | 0  | Sel.    |    |
| 1  | ٦  | 0  | 1  | Min.    |    |
| 1  | 1  | ٦  | 0  | Hour    |    |
| 1  | 1  | ٦  | 1  | Day     |    |

When an RTC-interrupt is detected the Interrupt status register can be read in order to determine the source of the interrupt.

When bit no. 7 (MSB) is set to "1" the interrupt source is the alarm. When bit no. 6 is set to "1" the interrupt source is the clock. Bit no. 0-5 in the Int. Status register will always be zero.

The counters and latches from seconds through months holds the time and alarm information in BCD.

The bit no. 7 (MSB) of the hours counter/latch irelicates AM and PM. The bit is set to "0" when AM and set to "1" when PM.

Bit no. 6 at the hours counter/latch determines 12 hours or 24 hours operation. When set to "1" the 12 hours operation is selected. When set to "0" the 24 hours operation is selected. When set to "0" the 24

# hours operation is selected.

The bit no. 7 (MSB) of the month counter should be set to "1" when the year is a loop year.

# 6. SOUND DEVICE

The sound generator creates sound to the loudspeaker located in the RC759 cabinet.

The Sound Generator (SOGE) is a write-only register. A special write-procedure must be performed to ensure that the SOGE accepts the written data.

### Write Procedure

| ADD.     | OPERATION |      | DATA BUS     |                  |
|----------|-----------|------|--------------|------------------|
| I/O BASE | WRITE     | READ | BIT NO.      |                  |
| +        |           |      | 76543210     | COMMENTS         |
| 56 H     |           | х    |              | Ignore the read  |
|          |           |      |              | data!            |
| 5 CH     | х         |      | 000xxxxx     | Prepare the SOGE |
|          |           |      |              | to receive data  |
| 5 AH     | х         |      | DATA TO SOGE | Write data to    |
|          |           |      |              | sound Generator  |
| 56 H     | х         |      | XXXXXXXXX    | Create a write-  |
|          |           |      |              | pulse to SOGE    |

X = dont care

Four of the dividers are ten bit wide, and may be programmed individually to devide a frequency of 62,5 KHz with any integer in the range 1 to 1024. The outputs are square waves with 50% dutycycle, and fed into each their attenuator.

The forth divider divides the 62,5 KHz with 16, 32 or 64 or just takes the output of the third of the above named dividers, and outputs the result into a pseudo random generator creating pink noise. The noise is fed into the fourth attenuator. Each attenuator can damp the input from 0 dB down to -28 dB in steps of 2 dB or turn the input entirely off.

6.

The generator has registers for the control of the above mentioned functions:

| register |        |
|----------|--------|
| 0        | tone 1 |
| 1        | tone 2 |
| 2        | tone 3 |
| 3        | noise  |

The frequencies require two bytes for update:

|             | bit | 7 | 6  | 5  | 4  | 3  | 2  | 1          | 0  |
|-------------|-----|---|----|----|----|----|----|------------|----|
| First byte  |     | 1 | ta | æ  | 0  | f3 | £2 | fl         | fO |
| -           |     |   |    |    |    |    |    |            |    |
|             | bit | 7 | 6  | 5  | 4  | 3  | 2  | 1_         | 0  |
| Second byte |     | 0 | x  | f9 | f8 | f7 | f6 | <b>f</b> 5 | f4 |
| -           | •   |   |    |    |    |    |    |            |    |

Where (f0-f9)+1 is the modulus for the selected divider.

The noise generator is programmed with one byte:

bit 7 Х FB NF1 NFO 

Where FB selects noise type:

FB = 0: periodic noise
 l: white noise and
NF selects "noise frequency":
NF 1,0 =
00: 3,90 KHz
01: 1,95 KHz
10: 0,98 KHz
11: output from tone 3.

The attennators are programmed with one byte each:

A0 to A3 control four stages at attennation: A0 damps 2 dB when 1 A1 damps 4 dB when 1 A2 damps 8 dB when 1 A3 damps 16 dB when 1 if A0-A3 = 1111 the output is off.

The Sound Generator is a single-source, i.e. that one cannot always be sure on the presence of the Sound generator. To detect whether the SOGE is present or not, the following procedure can be performed.

Present Detection

| ADD.     | OPERAT | TION | DATA BUS |                   |
|----------|--------|------|----------|-------------------|
| I/O BASE | WRITE  | READ | BIT NO.  |                   |
| +        |        |      | 76543210 | COMMENTS          |
| 5 CH     | х      |      | 000XXXXX | Prepare the SOGE  |
|          |        |      |          | to receive data   |
| 5 AH     | x      |      | 1111111  | Write data to     |
|          |        |      |          | SOGE              |
| 56 H     | X      |      | XXXXXXXX | Create a write-   |
|          |        |      |          | pulse to the SOGE |

X = dont care

Within 10 us after the above described procedure, a read-operation should be performed to PPI port B. If bit no. 2 in the read data is zero (0), then the Sound Generator is present. If the Sound Generator is not present, sound can be made by using the CPU timer no. 1.

### 7. **ISBX CONNECTOR**

This connector is supported in accordance to the iSBX bus standard from INTEL. In the following is listed the I/O addresses available to this connector. The iSBX connector is controlled by /PCS 6 (IO Base + 300 H) I/O decode output from the 80186 microprocessor. 7.

| I/O device number (Hex)           | is      | BX function       | Dir | ection |
|-----------------------------------|---------|-------------------|-----|--------|
| IO Base + 300<br>to IO Base + 30F | } Modul | Select /MCSO      | }   | I/0    |
| Io Base + 310<br>to IOBase + 31F  | } Modul | Select /MCS1      | }   | I/0    |
| IO Base + 320                     | DMA A   | cknowledge /MDACK |     | I/0    |
| IO Base + 330                     | Termi   | nal Count + TC    |     | 0      |

INTR 0 from iSBX is connected to INT1 of 80186. iNTR 1 from iSBX is connected to INT3 of 80186. OPTION 0 from iSBX is read from PPI port A bit 2. OPTION1 from iSBX is read from PPI port A bit 3. Bit 1 of PPI port A is zero if an iSBX module is inserted in the connector.

#### 8. CASSETTE INTERFACE

The cassette interface control is implemented in software. Timer 0 output from 80186 is used to control the data to the cassette recorder. Timer 0 is enabled by bit 0 in PPI port C. The cassette input data is read by PPI port A bit 0. Software algorithms are used to generate and read casette data. The cassette drive motor is controlled (ON/OFF) by PPI port C bit 1 (0/1). In the following is described the Cassette Write and read procedures.

#### 8.1 Cassette Write

The WRITE BLOCK routine writes a tape block on the cassette. The tape block is described in Data Record Architecture page (fig. 6).

The WRITE BLOCK routine turns on the cassette motor and a synchronization bit (0) and then writes 256 bytes of all ones, the leader, to the tape. Next, one or more data blocks are written. After each data block of 256 bytes, a two byte CRC is written.

The WRITE BYTE routine disassembles the byte and writes it a bit a time to the cassette. The method used is to set TIMER 0 to the period of the desired data bit. The timer is set to a period of 1.0 millisecond for a one bit and 0.5 millisecond for a zero bit.

The timer is set to output a square wave with period given by its count register. The timer's period is changed on the fly for each data bit to be written to the cassette. If the number of data bytes to be written is not an integral multiple of 256, then after the last desired date byte from memory has been written, the data block will be extended to 256 bytes by writing multiples of the last data byte. The last block will be closed with two CRC bytes as usual. After the last data block, a trailer consisting of four bytes of all one bits will be written. Finally, the motor will be turned off. 8.1



#### Fig. 5.

### 8.2 Cassette Read

The READ BLOCK routine turns on the cassette motor and then delays for approximataly 0,5 secs for it to come up to speed.

The READ BLOCK routine then searches for leader and must detect all one bits for approximately 1/4 of leader length before it can look for the sync byte. If a correct sync byte (X<sup>-</sup>16<sup>-</sup>) is not found, the routine goes back and searches for leader again. The data is read a bit at a time and assembled into bytes. After each byte is assembled it is written into memory.

After each multiple of 256 data bytes are read, the CRC is read and compared to the CRC generated.



#### Fig. 6.

Leader 256 bytes (of ones)
 Sync byte ASCII Sync Char (X<sup>-</sup>16<sup>-</sup>)
 Sync byte (X<sup>-</sup>16<sup>-</sup>)
 Data Blocks 256 bytes
 CRC -- 2 bytes -- for each data block

ERROR RECOVERY

Error recovery is handled by software. A cyclic redundancy check (CRC) is used to detect errors. The polynominal used is:

Which is the polynominal used by the SDLC interface. Essentially, as bits are written/read from tape, they are passed through the CRC-register in software. After a block of data is written, the complemented value of the calculated CRC-register is written on tape. On reading the cassette data, the CRC bytes are read and compared to the generated CRC value.

# 9. Floppy/Printer Connector

This connector is used to control an external box with a Floppy interfacec + drive and a parallel printer interface. This floppy and printer can be shared by 4 Piccoline's, so the Floppy or Printer has to be reserved before use. After the reservation is acknowledged the unit is owned by the current Piccoline until released again. In the following is listed the I/O device groups used to control the external floppy/printer unit.

|        | I/O device<br>(HEX)  | Direction         | Description                                                               |
|--------|----------------------|-------------------|---------------------------------------------------------------------------|
| IOBASE | +280<br>+282<br>+284 | I/0<br>I/0<br>I/0 | Addresses to the Floppy Controller refer to section 9.1.                  |
|        | +286                 | I/O               | Floppy drive kind select                                                  |
|        | +288                 | 0                 | Refer to section 9.1.                                                     |
|        | +28A                 | I/0               | Printer Data } refer to section 9.2.                                      |
|        | 28C                  | I/0               | Printer Control }                                                         |
|        | +28E                 | 0                 | Reserve Floppy                                                            |
|        | +290                 | 0                 | Release Floppy                                                            |
|        | +28E                 | I                 | Bus 7=1 means Reserve Ack of Floppy<br>Bus 7=0 means wait upon Floppy.    |
|        | +292                 | 0                 | Reserve Printer                                                           |
|        | +294                 | 0                 | Release Printer                                                           |
|        | +292                 | I                 | Bus 7=1 means Reserve Ack of Printer.<br>Bus 7=0 means wait upon Printer. |

The Floppy controller is connected to DMA channel 1 on the 80186 microprocessor. Interrupt from the Floppy connector is connected to IRO of the 8259 interrupt controller. Interrupt from the Printer connector is connected to IR2 of the 8259 interrupt controller.

### 9.1 Floppy Disc Controller

The floppy disc controller is based on the WD 1797/WD2797 controller chip and supports the follow-ing.

- Up to two 5 1/4 inch drives connected in daisy chain
- Data transfer by DMA
- 8" compatible 5 1/4 inch drives
- Dual Side/Single Density 125 kbps, FM
- Dual Side/Dual Density 250 kbps, MFM
- Dual Side/Quadriple Density 250 kbps, MFM
- Dual/Side/Dual Density 500 kbps, MFM
- Multisector transfer capability
- Programmable Write Precompensation

### 9.1.1 FDC/CPU I/O Interface

The floppy disc controller (FDC) and an external control register (FCR) (for clock selection, precompensation, motor on/off and drive select) are accessed by I/O commands as follows:

I/O Base Addr.

| offset (HEX) | I/0    | FUNCTION                                            |
|--------------|--------|-----------------------------------------------------|
| 280          | I<br>O | Read FDC Status Register<br>Write Control Command.  |
| 282          | I<br>O | Read FDC TRACK Register<br>Write FDC TRACK Register |
| 284          | I<br>O | Read Sector Register<br>Write Sector Register       |
| 286          | I<br>O | Read Data Register<br>Write Data Register           |
| 288          | O<br>I | Write FCR Register<br>Not defined                   |

For further information on programming the registers on addr. 280-286 refer to Western Digital data sheet on WD1797. 9.1.1

# 9.1.2 FDC/DMA Interface

The floppy disc controller is normally initialized to transfer data in DMA-mode and then requires a DMA channel to be allocated (DMA channel 1).

The FCR register has the following layout: Bit-No

| (0          | = | LSB) | Name                   | Description                                                                                        |
|-------------|---|------|------------------------|----------------------------------------------------------------------------------------------------|
|             | 0 |      | Drive sel.             | Selects between drives, a o<br>selects drive 0. a drive is<br>only selected if its motor is<br>on. |
|             | 1 |      | Motor 0.               |                                                                                                    |
|             | 2 |      | Motor 1                | 0: Motor OFF, 1: Motor ON.                                                                         |
|             | 3 |      | Precomp Enabl          | e Write precompensation 0: Disabled<br>l: Enabled                                                  |
|             | 4 |      | Precom <u>p</u> ensati | on.<br>125 nsec<br>250 nsec                                                                        |
|             | 5 |      |                        | 0: Dual density<br>1: Single density                                                               |
|             | 6 |      |                        | WD 1797 Clock select<br>0: 1 MHz (5 1/4")<br>1: 2 MHz (8")                                         |
| -<br>-<br>- | 7 |      | READY CONTROL          | 0: Ready from drive<br>1: Ready always set                                                         |

Precompensation is only used in MFM-mode and is normally applied in the following way together with LOW CURRENT:

| CYLINDER NO | PRECOMPENSATION |
|-------------|-----------------|
| 0-43        | 125 nsec.       |
| 44-77       | 250 nsec.       |

This control sceme may be refined as required by the actual drives.

9.1.2

# 9.2 External Printer Controller

This parallel printer interface ("Centronic compatible") is controlled by programmed I/O instruction.

#### 9.2.1 Set Printer Data

Output to device <IOBASE + 28A> puts the contents of the microprocessor bus into the printer data register.



#### 9.2.2 Read Printer Data

Input from device <IOBASE + 28 A> reads the contents of the Printer Data Register back to the microprocessor.

# 9.2.3 Set Printer Control

Output to device <IOBASE + 28 C> sets the printer control register.



#### 9.2.4 Read Printer Status

Input from device <IOBASE + 28C>



9.2.2

9.2

9.2.1

9.2.4

Status bit 7 - 5 is the inverted signals from the Control register bit 3, 2 and 0 (set in section 9.2.3). Status bit 4 - 0 represents the printer status.

When the printer shifts from BUSY to NOT BUSY status, an interrupt is generated (IR2 to the 8259 controller). à.

# 10. LOCAL PRINTER CONTROLLER

This parallel printer interface ("Centronic compatible") is identical to that described in section 9.2, but controlled by I/O instructions to different device numbers.

I/O device

| <u>number (hex)</u> | Direction | Function                   |
|---------------------|-----------|----------------------------|
| IOBASE + 250        | 0         | Set printer Data Register  |
| + 250               | I .       | Read Printer Data Register |
| + 260               | 0         | Set Printer Control        |
| + 260               | I         | Read Printer Status        |

The printer interrupt (BUSY  $\longrightarrow$  NOT BUSY) is connected to IR6 on the 8259 interrupt controller.

# 11. PPI 8255

The parallel ports in the 8255, connected to the addresses IOBASE + 70 to IOBASE + 76 are used in the following way:

### 11.1 Port A (IOBASE + 70)



- CASSETTE DATA IN contains the serial data stream from the cassette tape.

- /MPST is zero if an iSBX module is installated.
   OPTION 0 (1) are optional status signals from iSBX modules. The function of these signals depends on the used iSBX module.
- /MEM IDENT 0 (1) defines the memory configuration.

| /MEM IDENT 0     | /MEM IDENT 1     | RAM memory size                                                                       |
|------------------|------------------|---------------------------------------------------------------------------------------|
| 1<br>1<br>0<br>0 | 1<br>0<br>1<br>0 | 256 kbytes<br>256 + 128 kbytes<br>-256 + 512 K (using<br>256 k x 1 bit chip)<br>640 K |

The shown ram size is excl. the 32 kbytes pixel memory,

- /DPC CONNECT is zero, if connection to external Floppy/printer box is installed.

11.1

# 11.2 PORT B (IOBASE + 72)



- /NET IDENT is zero if the MICRONET controller is present in the RC PICCOLINE
- /RTC SEC SOURCE is zero if the second source real time clock chip (RCA CDP1879) is used.
- /SOGE is used to detect presence of the sound generator as described in section 6.0.
- MONOCHROME is one if a monochrome CRT monitor is connected.
- 22kHZ is one if a CRT monitor with a linefrequency of 22kHZ is used.

# 11.3 PORT C (IOBASE + 74)



11.2

- ENABLE CAS enables output from the 80186 timer generating the bitstream to the cassette tape. and the ram memory.
- MOTOR OFF, if one stops the cassette tape motor.
- DROSEL 0(1) selects the source for the 2 dma channels in the 80186 microprocessor.

| DRQSEL<br>0 - 1                       | DMA 0 SOURCE | DMA 1 SOURCE                                                                                  |
|---------------------------------------|--------------|-----------------------------------------------------------------------------------------------|
| 0 0<br>0 1<br>1 0<br>1 1<br>NVMA0 (1) | -            | DPC (external Floppy)<br>0<br>1<br>0<br>block address to the non<br>nory as described in sec- |
| /GRAPHIC                              |              | mode of the CRT logic. If c mode is selected.                                                 |
| KBON                                  |              | e power to the keyboard. If<br>keyboard is supplied with                                      |

# 11.4 Control word (IOBASE + 76)

This register is used to define the mode of the 8255 PPI. This register should initially be loaded with the following contents.

IOBASE + 76 : 1 0 0 1 0 0 1 0 (or 92 H)

power.

The bits in port C may be set/reset in the following way:

| o o o o bit no. v | IOBASE + | 76 | : | 7 | 6 | 5 | 4 | 3   | 2   | 1 | 0 |
|-------------------|----------|----|---|---|---|---|---|-----|-----|---|---|
|                   |          |    |   | 0 | 0 | 0 | 0 | bit | no. |   | v |

The value of V is loaded into part c (bit no).

46

ŝ,

| 10 | area | Peripheral                              | Direction  | Interrupt | DMA<br>Request |
|----|------|-----------------------------------------|------------|-----------|----------------|
| IO | base | + 0 8259 Interrupt crt                  | -          |           |                |
| IO | base | + 20 Keyboard                           | I          | 1         |                |
| IO | base | + 50 Sound<br>+ real time clock         | 0          | 3         |                |
| IO | base | + 60 CRT control                        | 0          | 4         | 3              |
| IO | base | + 70 PPI Port A                         | I.         |           |                |
| IO | base | + 72 PPI Port B                         | I          |           |                |
| 10 | base | + 74 PPI Port C                         | 0          |           |                |
| 10 | base | + 76 Control for 70-74                  | 0          |           |                |
| IO | base | + 80<br>to FE NVM                       | I/O        |           |                |
| 10 | base | + 100 Ch. AH to NET                     |            |           |                |
| IO | base | + 180<br>to 19F Palet                   | 0          |           |                |
| IO | base | + 280 Floppy control                    | I/0        | 0         | 0              |
| IO | base | + 282 track                             |            |           |                |
| 10 | base | + 284 sector                            |            |           |                |
| IO | base | + 286 data                              | •<br>•     |           |                |
| IO | base | + 288 Floppy control                    | 0          |           | •              |
| IO | base | + 230 Reset Int<br>CRT                  |            |           | •              |
| 10 | base | + 240 Ch. Att.                          |            |           |                |
|    |      | + 28A ext.printer data<br>+ 28C control | I/0<br>I/0 | 2         |                |
| 10 | base | + 28E Reserve Floppy<br>+ 290 Release - | 0<br>0     |           |                |

| IO | base       | + | 28E        | Test Floppy                   | I      |                 |
|----|------------|---|------------|-------------------------------|--------|-----------------|
| 10 | base       |   |            | Reserve Printer<br>Release -  | 0<br>0 |                 |
| IO | base       | + | 292        | Test Printer                  | I      |                 |
| 10 | base       |   |            | local Printer data<br>control | •      | 6               |
| ΙΟ | base<br>to |   | 300<br>30F | iSBX                          | I/O    | INT]<br>(80186) |
| 10 |            |   | 310<br>31F | iSBX                          | I/O    | INT3<br>(80186) |
| IO | base       | + | 320        | DMA ACK to iSBX               | 0      |                 |
| 10 | base       | + | 330        | TC to iSBX                    | 0      |                 |

-

Canal of the

| <u>A.</u>  | INDICES                        |                  |
|------------|--------------------------------|------------------|
| <u>A.l</u> | Survey of Figures              |                  |
|            |                                |                  |
| 1.         | Piccoline Block Diagram        | 3                |
| 2.         | Memory Address Layout          | 5                |
| 3.         | Blockdiagram of the CRT system | 9                |
| 4.         | 82730 Block Diagram            | 1 0 <sup>.</sup> |
| 5.         | •••••••••••••••                | 36               |
| 6.         | ••••••••••••                   | 37               |

د ۲

A.1

3

5

Α.

 $\supset$  $\mathcal{D}$ 

# **RETURN LETTER**

3

#### Title: RC759 CU Board Reference Manual

RCSL No.: 99- 0 00825

A/S Regnecentralen af 1979/RC Computer A/S maintains a continual effort to improve the quality and usefulness of its publications. To do this effectively we need user feedback, your critical evaluation of this manual.

Please comment on this manual's completeness, accuracy, organization, usability, and readability:

Do you find errors in this manual? If so, specify by page.

How can this manual be improved?

\_\_\_\_\_

Other comments?

| Name:    | <br>Title: | <br>· · · · |        |
|----------|------------|-------------|--------|
| Company: | <br>• .    | <br>        |        |
| Address: | <br>· .    | <br>        |        |
|          |            | Date:       | -<br>- |

. .

.

Thank you

Do not tear - Fold here and staple

Fold here

. .

Affix postage here



Information Department Lautrupbjerg 1 DK-2750 Ballerup Denmark