# HD6845R/HD6845S - CRT Controller (CRTC)

The CRTC is a LSI controller which is designed to provide an interface to microcomputers to raster scan type CRT displays. The CRTC belongs to the HD6800 family LSI family and has full compatibility with MPU in both data lines and control lines. Its primary function is to generate timing signal which is necessary for raster scan type CRT display according to the specification programmed by MPU. The CRTC is also designed as a programmable controller, so applicable to wide-range CRT display from small low-functioning character display up to raster type full graphic display as well as large high-functioning limited graphic display.

### \* FEATURES

- Number of Displayed Characters on the Screen, Vertical Dot Format of One Character, Horizontal and Vertical Sync Signal, Display Timing Signal are programmable
- 3.7Mhz High Speed Display Operation (HD6845S)
- 3.0Mhz High Speed Display Operation (HD6845R)
- Line Buffer-Less refreshing
- 14-bit Refresh Memory Address Output (16k Words max access)
- Programmable Interlace/Non-Interlace Scan Mode
- Built-in Cursor Control Function
- Programmable Cursor Height and its Blink
- Paging and Scrolling Capability
- TTL compatible
- Single +5V Power Supply

# \* SYSTEM BLOCK DIAGRAM

# \* PIN ARRANGEMENT

Hitachi HD6845 Cathode Ray Tube Controller

|           | — , <i>–</i> |                    |
|-----------|--------------|--------------------|
| ¥ss [     | 1            | 40 VSYNC           |
| ∕RES □    | 2            | зэрналис           |
| LPSTB 🗆   | 3            | 38 🗆 RAØ           |
| MA0 🗆     | 4            | 37 🗆 RA1           |
| MA1 🗆     | 5            | 36 🗆 RA2           |
| MA2 🗆     | 6            | 35 🗆 RA3           |
| маз 🗆     | 7            | 34 🗆 RA4           |
| MA4 🗆     | 8            | 33 <b> </b> ] DØ   |
| MA5 🗆     | 9            | 32 🗆 D 1           |
| MA6 🗆     | 10           | 31 🗘 D 2           |
| M87 🗆     | 11           | 30 🗆 D 3           |
| MAS 🗆     | 12           | 29 🗆 D4            |
| MA9 🗆     | 13           | 28 🗆 D 5           |
| MA10 🗆    | 14           | 27 <b> </b> ] D6   |
| MA11 🗆    | 15           | 26 🗆 D 7           |
| MA12 🗆    | 16           | 25¤∕cs             |
| MA 1 3 🗆  | 17           | 24 🗆 RS            |
| DISPTMG 🗆 | 18           | 23 🗆 E             |
| CUDISP    | 19           | 22 <b>□</b> ⁄₩ / R |
| Vec 🗆     | 20           | 21 🗆 С.К           |
|           |              |                    |

# **\* ORDERING INFORMATION**

| CRTC     | <b>Bus Timing</b> | CRT Display Timing |
|----------|-------------------|--------------------|
| HD6845S  | 1.0 Mhz           |                    |
| HD68A45S | 1.5 Mhz           | 3.7 Mhz max        |
| HD68B45S | 2.0 Mhz           |                    |
| HD6845R  | 1.0 Mhz           |                    |
| HD68A45R | 1.5 Mhz           | 3.0 Mhz max        |
| HD68B45R | 2.0 Mhz           |                    |

# \* ABSOLUTE MAXIMUM RATINGS

# \* **RECOMMENDED OPERATING CONDITIONS**

### **Figure 5 Test Loads**

# \* SYSTEM DESCRIPTION

The CRTC is a LSI which is connected with MPU and CRT display device to control CRT display. The CRTC consists of internal register group, horizontal and vertical timing circuits, linear address generator, cursor control circuit, and light pen detection circuit. Horizontal and vertical timing curcuit generate RA0-RA4, DISPTMG, HSYNC and VSYNC. RA0-RA4 are raster address signals and uses as input signals for Character Generator. DISPTMG, HSYNC and VSYNC signals are recieved by video control circuit. This horizontal and vertical timing circuit consists of internal counter and comparator circuit.

Linear address generates refresh memory address MA0-MA13 to be used for refreshing the screen. By these address signals, refresh memory is accessed periodically. As 14 refresh memory address signals are prepared, 16k words max are accessible. Moreover, the use of start address register enables paging and scrolling. Light pen detection circuit detects light pen position on the screen. When light pen strobe signal is received, light pen register memorizes linar address generated by linear address generator in order to memorize where light pen is on the screen. Cursor control circuit controls the position of cursor, its height, and its blink.

### Figure 6 Internal Block Diagram of CRTC

# \* FUNCTION OF SIGNAL LINE

The CRTC provides 13 interface signals to MPU and 25 interface signals to CRT display.

### \* Interface Signals to MPU

### **Bi-directional Data Bus (D0-D7)**

#### I/O Pin No. 33-26

Bi-directional data bus (D0-D7) are used for data transfer between the CRTC and MPU. The data bus outputs are 3-state buffers and remain the high-impedance state except when MPU performs a CRTC read operation.

### Read/Write /W / R

#### **Input Pin No.22**

Read/Write signal (/W / R) controls the direction of data transfer between the CRTC and MPU. When /W / R is at "High" level, data of CRTC is transferred to MPU. When /W / R is at "low" level, data of MPU is transferred to CRTC.

### Chip Select (/CS)

#### Input Pin No. 25

Chip Select signal (/CS) is used to address the CRTC. When /CS is at a "low" level, it enables Read/Write operation in CRTC internal registers. Normally this signal is derived from decoding address signal of MPU under the condition that VMA of MPU is at "High" level.

### **Register Select**

#### Input Pin No. 24

Register Select signal (RS) is used to select the address register and 18 control registers of the CRTC. When RS is at "low" level, the address register is selected and when RS is at "high" level, control registers are selected. This signal is normally a derivative of the lowest bit (A0) of MPU address bus.

### Enable (E)

#### Input Pin No. 23

Enable signal (E) is used as strobe signal in MPU Read/Write operation with the CRTC internal registers. This signal is normally a derivative of the HD6800 System Ø, clock.

### Reset (/RES)

Reset Signal (/RES) is an input signal used to reset the CRTC. When /RES is at "low" level, it forces the CRTC into the following status:

- All the counters in the CRTC are cleared and the device stops the display operation
- All the outputs go down to "low" level.
- Control registers in the CRTC are not affected and remain unchanged.

This signal is different from other HD6800 family LSIs in the following functions and has restrictions for usage:

- /RES has capability of reset function only when LPSTB is at "low" level.
- The CRTC starts the display operation immediatly after /RES goes "high" level.

### \* Interface Signals to CRT Display Device

### **Character Clock (CLK)**

#### Input Pin No. 21

CLK is a standard clock input signal which defines character timing for the CRT display operation. CLK is normally derived from the external high-speed dot timing logic.

### Horizontal Sync (HSYNC)

### Output Pin No. 39

HSYNC is an active "high" level signal which provides horizontal syncronization for display device.

### Vertical Sync (VSYNC)

#### **Output Pin No. 40**

VSYNC is an active "high" level signal which provides vertical sychronization for display device.

### **Display Timing (DISPTMG)**

#### **Output Pin No. 18**

DISPTMG is an active "High" level signal which defines the display period in horizontal and vertical raster scanning. It is necessary to enable video signal only when DISPTMG is at "High" level.

### **Refresh Memory Address (MA0-MA13)**

#### **Output Pin. No 4-17**

MA0-MA13 are refresh memory address signals which are used to access to refresh memory in order to refresh the CRT screen periodically. These outputs enables 16k words max, refresh memory access. So, for instance, these are applicable to up to 2000 characters/screen and 8-page system.

### **Raster Address RA0-RA4**

#### Output Pin No. 38-34

RA0-RA4 are raster address signals which are used to select the raster of the character generator or graphic pattern generator etc.

### **Cursor Display (CUDISP)**

#### **Output Pin No. 19**

CUDISP is a active "High" level video signal which is used to display the cursor on the CRT screen. This output is inhibited while DISPTMG is at "low" level. Normally this output is mixed with video signal and provided to the CRT display device.

### Light Pen Strobe (LPSTB)

#### Input pin no.3

LPSTB is an "active" level input signal which accepts strobe pulse detected by the light pen and control circuit. When this signal is activated, the refresh memory address (MA0-MA13) which are shown in Fig. 2 are stored in the 14-bit light pen register. The stored refresh memory address need to be corrected in software, taking the delay time of he display device, light pen and light pen control circuits into account.

# **\* REGISTER DESCRIPTION**

|         |    |   |                     |   |   |   |            | Table                           |                      | Sisters | assignmen | 10 |  |   |   |   |   |   |   |  |
|---------|----|---|---------------------|---|---|---|------------|---------------------------------|----------------------|---------|-----------|----|--|---|---|---|---|---|---|--|
| /<br>CS | RS |   | Address<br>Register |   | - |   | Register # | Register<br>Name                | Program<br>Unit READ | ) WRITE | Data Bit  |    |  |   |   |   |   |   |   |  |
| CS      |    | 4 | 3                   | 2 | 1 | 0 |            | Ivame Unit                      |                      |         | 7         | 6  |  | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 1       | X  | X | X                   | x | x | X |            |                                 | -                    | -       | -         |    |  |   |   |   |   |   |   |  |
| 0       | 0  | x | x                   | x | x | x | AR         | Address<br>Register             | -                    | X       | 0         |    |  |   |   |   |   |   |   |  |
| 0       | 1  | 0 | 0                   | 0 | 0 | 0 | R0         | Horizontal<br>Total*            | Character            | X       | 0         |    |  |   |   |   |   |   |   |  |
| 0       | 1  | 0 | 0                   | 0 | 0 | 1 | R1         | Horizontal<br>Displayed         | Character            | X       | 0         |    |  |   |   |   |   |   |   |  |
| 0       | 1  | 0 | 0                   | 0 | 1 | 0 | R2         | Horizontal<br>Sync<br>Position* | Character            | X       | 0         |    |  |   |   |   |   |   |   |  |

#### **Table 1 Internal Registers Assignment**

| 0 | 1 | 0 | 0 | 0 | 1 | 1 | R3  | Sync Width                    | Vertical-<br>Raster,<br>Horizontal-<br>Character | X | 0 | wv3 | wv2        | wv1 | wv0 | wh3 | wh2 | wh1 | wh0 |
|---|---|---|---|---|---|---|-----|-------------------------------|--------------------------------------------------|---|---|-----|------------|-----|-----|-----|-----|-----|-----|
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | R4  | Vertical<br>Total*            | Line                                             | X | 0 |     |            |     |     |     |     |     |     |
| 0 | 1 | 0 | 0 | 1 | 0 | 1 | R5  | Vertical<br>Total Adjust      | Raster                                           | X | 0 |     |            |     |     |     |     |     |     |
| 0 | 1 | 0 | 0 | 1 | 1 | 0 | R6  | Vertical<br>Displayed         | Line                                             | X | 0 |     |            |     |     |     |     |     |     |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | R7  | Vertical<br>Sync<br>Position* | Line                                             | X | 0 |     |            |     |     |     |     |     |     |
| 0 | 1 | 0 | 1 | 0 | 0 | 0 | R8  | Interlace<br>and Skew         | -                                                | X | 0 | c1  | <b>c</b> 0 | d1  | d0  |     |     | v   | S   |
| 0 | 1 | 0 | 1 | 0 | 0 | 1 | R9  | Maximum<br>Raster<br>Address  | Raster                                           | X | 0 |     |            |     |     |     |     |     |     |
| 0 | 1 | 0 | 1 | 0 | 1 | 0 | R10 | Cursor Start<br>Raster        | Raster                                           | X | 0 |     | В          | Р   |     |     |     |     |     |
| 0 | 1 | 0 | 1 | 0 | 1 | 1 | R11 | Cursor End<br>Raster          | Raster                                           | X | 0 |     |            |     |     |     |     |     |     |
| 0 | 1 | 0 | 1 | 1 | 0 | 0 | R12 | Start<br>Address (H)          | -                                                | 0 | 0 |     |            |     |     |     |     |     |     |
| 0 | 1 | 0 | 1 | 1 | 0 | 1 | R13 | Start<br>Address (L)          | -                                                | 0 | 0 |     |            |     |     |     |     |     |     |
| 0 | 1 | 0 | 1 | 1 | 1 | 0 | R14 | Cursor (H)                    | -                                                | 0 | 0 |     |            |     |     |     |     |     |     |
| 0 | 1 | 0 | 1 | 1 | 1 | 1 | R15 | Cursor (L)                    | -                                                | 0 | 0 |     |            |     |     |     |     |     |     |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | R16 | Light Pen<br>(H)              | -                                                | Ο | X |     |            |     |     |     |     |     |     |
| 0 | 1 | 1 | 0 | 0 | 0 | 1 | R17 | Light Pen<br>(L)              | -                                                | 0 | X |     |            |     |     |     |     |     |     |

### NOTE

- The registers marked \*: {Written value} = {Specified Value} 1
- Written Value of R9 is mentioned below.
  - Non-Interlace Mode, Interlace Mode: {Written value} = {Specified Value} -1
  - Interlace Sync & Video Mode: {Written value} = {Specified Value} 2
- C0 and C1 specify skew of CUDISP. D0 and D1 specify skew of DISPTMG

When S is '1', V specifies video mode, S specifies the Interlace Sync Mode

- B specifies the cursor blink, P specifies the cursor blink period.
- wv0-wv3 specify the pulse width of Vertical Sync Signal.

wh0-wh3 specify the pulse width of Horizontal Sync Signal.

- R0 is ordinally programmed to be odd number in interlace mode.
- O; Yes, X; No.

# \* FUNCTION OF INTERNAL REGISTERS

# \* Address Register (AR)

This is a 5-bit register used to select 18 internal control registers (R0--R17). Its contents are the address of one of 18 internal control registers. Programming the data from 18 to 31 produces no results. Access to R0--R17 requires, first of all, to write the address of corresponding control register into this register. When RS and /CS are at "low" level, this register is selected.

### \* Horizontal Total Register (R0)

This is a register used to program total number of horizontal characters per line including the retrace period. The data is 8bit and its value should be programmed according to the specification of the CRT. When M is total number of characters, M-1 shall be programmed to this register. When programming for interlace mode, M must be even.

### \* Horizontal Displayed Register (R1)

This is a register used to program the number of horizontal displayed characters per line. Data is 8-bit and any number that is smaller than that of horizontal total characters can be programmed.

### \* Horizontal Sync Position Register (R2)

This is a register used to program horizontal sync position as multiples of the character clock period. Data is 8-bit and any number that is lower than the horizontal total number can be programmed. When H is character number of horizontal Sync Position, H-1 shall be programmed to this register. When programmed value of this register is increased, the display position on the CRT screen is shifted to the left. When programmed value is decreased, the position is shifted to the right. Therefore, the optimum horizontal position can be determined by this value.

### \* Sync Width Register (R3)

This is a register used to program the horizontal sync pulse width and the vertical sync pulse width. The horizontal sync pulse width is programmed in the lower 4-bits as multiples of the character clock period. "0" can't be programmed. The vertical sync width is programmed in higher 4-bit as multiples of the raster period. When "0" is programmed in higher 4-bit, 16 raster period (16H) is specified.

|     | V   | SW  | Pulse Width |     |
|-----|-----|-----|-------------|-----|
| 2^7 | 2^6 | 2^5 |             |     |
| 0   | 0   | 0   | 0           | 16H |
| 0   | 0   | 0   | 1           | 1   |
| 0   | 0   | 1   | 0           | 2   |
| 0   | 0   | 1   | 1           | 3   |

| Table 2: Pulse | Width of | Vertical Sync Signal |
|----------------|----------|----------------------|
|----------------|----------|----------------------|

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

### H; Raster Period

### Table 3 Pulse Width of Horizontal Sync Signal

|     | ł   | ISW | Pulse Width |          |
|-----|-----|-----|-------------|----------|
| 2^3 | 2^2 | 2^1 | 2^0         |          |
| 0   | 0   | 0   | 0           | - (Note) |
| 0   | 0   | 0   | 1           | 1 CH     |
| 0   | 0   | 1   | 0           | 2        |
| 0   | 0   | 1   | 1           | 3        |
| 0   | 1   | 0   | 0           | 4        |
| 0   | 1   | 0   | 1           | 5        |
| 0   | 1   | 1   | 0           | 6        |
| 0   | 1   | 1   | 1           | 7        |
| 1   | 0   | 0   | 0           | 8        |
| 1   | 0   | 0   | 1           | 9        |
| 1   | 0   | 1   | 0           | 10       |
| 1   | 0   | 1   | 1           | 11       |
| 1   | 1   | 0   | 0           | 12       |
| 1   | 1   | 0   | 1           | 13       |
| 1   | 1   | 1   | 0           | 14       |
| 1   | 1   |     | 1           | 15       |

CH; Character clock period (Note) HSW = "0" can't be used

### \* Vertical Total Register (R4)

This is a register used to program total number of lines per frame including vertical retrace period. The data is within 7-bit and its value should be programmed according to the specification of the CRTC. When N is total number of lines, N-1 shall be programmed to this register.

### \* Vertical Total Adjust Register (R5)

This is a register used to program the optimum number to adjust total number of rasters per field. This register enables to decide the number of vertical deflection frequency more strictly.

### \* Vertical Displayed Register (R6)

This is a register used to program the number of displayed character rows on the CRT screen. Data is 7-bit and any number that is smaller than that of vertical total characters can be programmed.

### \* Vertical Sync Position Register (R7)

This is a register used to program the vertical sync position on the screen as multiples of the horizontal character line period. Data is 7-bit and any number that is equal to or less than vertical total characters can be programmed. When V is character number of vertical sync position, V-1 shall be programmed to this register. When programmed value of this register is increased, the display position is shifted up. When programmed value is decreased, the position is shifted down. Therefore, the optimum vertical position may be determined by this value.

### \* Interlace and Skew Register (R8)

This is a register used to program raster scan mode and skew (delay) of CUDISP and DISPTMG.

### Raster Scan Mode Program Bit (V,S)

Raster scan mode is programmed in the V,S bit.

| V | S | Raster Scan Mode            |
|---|---|-----------------------------|
| 0 | 0 | Non-interlace mode          |
| 1 | 0 |                             |
| 0 | 1 | Interlace Sync Mode         |
| 1 | 1 | Interlace Sync & Video Mode |

#### Table 4 Raster Scan Mode (2^1,2^0)

In the non-interlace mode, the rasters of even number field and odd number field are scanned duplicatedly. In the interlace sync mode, the rasters of odd number field are scanned in the middle of even number field. Then it is controlled to display the same character position in two fields. In the interlace sync & video mode, the raster scan method is the same as the interlace sync mode, but it is controlled to display different character pattern in two field.

### Skew Program Bit (C1,C0,D1,D0)

These are used to program the skew (delay) of CUDISP and DISPTMG. Skew of these two kinds of signals are programmed seperatly.

| <b>D1</b> | <b>D0</b> | DISPTMG            |
|-----------|-----------|--------------------|
| 0         | 0         | Non-Skew           |
| 0         | 1         | One-character Skew |
| 1         | 0         | Two-character skew |
| 1         | 1         | Non-output         |

#### Table 5 DISPTMG Skew bit (2^5,2^4)

#### Table 6 CUDISP Skew Bit (2^7,2^6)

| <b>C1</b> | C0 | CUDISP             |
|-----------|----|--------------------|
| 0         | 0  | Non-Skew           |
| 0         | 1  | One-character Skew |
| 1         | 0  | Two-character skew |
| 1         | 1  | Non-output         |

Skew function is used to delay the output timing of CUDISP and DISPTMG in LSI for he time to access refresh memory, character generator or pattern generator, and to make the same phase with serial video signal.

### \* Maximum Raster Address Register (R9)

#### (See comparison of HD6845S and HD6845R on page 40.

This is a register used to program maximum raster address within 5-bit. This register defines total number of rasters per character including line space. This register is programmed as follows.

#### Non-Interlace mode, Interlace Sync Mode

When total number of rasters is RN, RN-1 shall be programmed.

### Interlace Sync & Video Mode

When total number of rasters is RN, RN-2 shall be programmed.

This manual defines total number of rasters in non-interlace mode, interlace sync mode and interlace sync & video mode as follows:

Non-Interlace Mode

```
0 ----- Total Number of rasters: 5

1 ----- Programmed value: Nr=4

2 ----- (The same as displayed total number of rasters)

3 ------

4 ------

Raster address
```

Interlace Sync Mode

Hitachi HD6845 Cathode Ray Tube Controller

```
0 -----
               Total Number of Rasters: 5
              Programmed value: Nr=4
 . . . . . . . . . . . 0
1 _____
               (In the interlace sync mode, total number of rasters
               in both the even and odd fields is ten. On programming,
 .....1
2 -----
               the half of it is defined as total number of rasters.)
 3 -----
 4 -----
 Raster address
Interlace Sync & Video Mode
0 -----
              Total number of Rasters: 5
 .....1
              Programmed Value: Nr=3
2 -----
              (Total number of rasters displayed in the even field
 ..... 3
               and the odd field).
4 _____
```

### \* Cursor Start Raster Register (R10)

This is a register used to program the cursor start raster address by the lower 5-bit  $(2^{-2^{4}})$  and the cursor display mode by higher 2-bit.  $(2^{5},2^{6})$ 

| B | P | Cursor Display Mode   |
|---|---|-----------------------|
| 0 | 0 | Non-blink             |
| 0 | 1 | Cursor-non-display    |
| 1 | 0 | Blink 16 Field Period |
| 1 | 1 | Blink 32 Field Period |

#### Table 7 Cursor Display Mode (2^6, 2^5)

**Blink Period** 

light dark

16 or 32 Field Period (see comparison of HD6845S and HD6845R on page 40).

### \* Cursor End Raster Register (R11)

Tbis is register used to program the cursor end raster address.

## \* Start Address Register (R12, R13)

These are used to program the first address of refresh memory to read out. Paging and scrolling is easily performed using this register. The register can be read but the higher 2-bit (2^6, 2^7) of R12 are always "0".

### \* Cursor Register (R14,R15)

These tow read/write registers stores he cursor location. The higher 2-bit (2^6, 2^7) of R14 are always "0".

### \* Light Pen Register (R16,R17)

These read only registers are used to catch the detection address of the light pen. The higher 2-bit (2^6, 2^7) of R16 are always "0". Its value needs to be corrected by software because there is time delay from address output of the CRTC to signal input LPSTB pin of the CRTC in the process that raster is 1H after address output and ligh pen detects it. Moreover, delay time shown in Fig 2 needs to be taken into account.

Restriction on Programming Internal Register

- 0<Nhd<Nht+1<=256
- 0<Nvd<Nvt+1<=128
- 0<=Nhsp<=Nht
- 0<=Nvsp<=Nvt\*
- 0<=Ncstart<=Ncend<=Nr (Non-interlace, Interlace Sync Mode)

0<=Ncstart<=Ncend<=Nt+1 (Interlace sync & video mode)

- 2<=Nr<=30 (Interlace Sync & Video Mode)
- 3<=Nht (Except non-interlace mode) 5<=Nht (Non-interlace mode only)

\* In the interlace mode, pulse width is changed  $\pm \frac{1}{2}$  raster time when vertical sync signal extends over two fields.

#### Notes for Use

The method of directly using the value programmed in the internal registers of LSI for controlling the CRT is adopted. Consequently, the display may flicker on the screen when the contents of the registers are changed from bus side asynchonously with the display operation.

### **Cursor Register**

Writing into this register at frequent intervals for moving the cursor should be performed during horizontal and vertical retrace period.

### **Start Address Register**

Writing into the start address register at frequent intervals for scrolling and paging should be performed during horizontal and vertical display period. It is desireable to avoid programming other registers during display operation.

### **\* OPERATION OF THE CRTC**

### \* Time Chart of CRT interface signals

The following example shows the display operation in which values of Table 8 are programmed to the CRTC internal registers. Fig 7 shows the CRT screen format. Fig 10 shows the time chart of signals output from the CRTC.

### Figure 7 CRT Screen Format

| Register | Register Name            | Value     | Register | Register Name       | Value |
|----------|--------------------------|-----------|----------|---------------------|-------|
| R0       | Horizontal Total         | Nht       | R9       | Max Raster Address  | Nr    |
| R1       | Horizontal Displayed     | Nhd       | R10      | Cursor Start Raster |       |
| R2       | Horizontal Sync Position | Nhsp      | R11      | Cursor End Raster   |       |
| R3       | Sync Width               | Nvsw,Nhsw | R12      | Start Address (H)   | 0     |
| R4       | Vertical Total           | Nvt       | R13      | Start Address (L)   | 0     |
| R5       | Vertical Total Adjust    | Nadj      | R14      | Cursor (H)          |       |
| R6       | Vertical Displayed       | Nvd       | R15      | Cursor (L)          |       |
| R7       | Vertical Sync Position   | Nvsp      | R16      | Light Pen (H)       |       |
| R8       | Interlace & Skew         |           | R17      | Light Pen (L)       |       |

#### **Table 8 Programmed Values into the Registers**

Note: Nhd<Nht, Nvd<Nvt

The relation between values of Refresh Memory Address (MA0-MA13) and Raster Address (RA0-RA7) and the display position on the screen is shown in Fig 16. Fig 16 shows the case where the value of Start Address is 0.

### **Interlace Control**

Fig. 8 shows an example where the same character is displayed in the non-interlace mode, interlace sync mode, and interlace sync & video mode.

### Non-Interlace Mode Control

In non-interlace mode, each field is scanned dupicatedly. The values of raster address (RA0-RA4) are counted up one from 0.

### Interlace Sync Mode Control

In the interlace sync mode, raster addressed in the even field and the odd field are the same as addressed in the noninterlace mode. One character pattern is displayed mutually and its display position in the odd field is set to ½ raster space down from that in the even field.

### Figure 8. Example of Raster Scan Display





Non-interlace Mode







Interlace Sync & Video Mode (Total number of rasters in a line is odd.)

### Interlace Sync & Video Mode Control

In interlace sync and video mode, the output raster address when the number of rasters is even is different from that when the number of rasters is odd.

| Total number of Rasters in a Line | Field       | <b>Even Field</b> | Odd Field    |
|-----------------------------------|-------------|-------------------|--------------|
| Even                              |             | Even Address      | Odd Address  |
| Odd                               | Even Line * | Even Address      | Odd Address  |
|                                   | Odd Line *  | Odd Address       | Even Address |

#### Table 9 The Output Of Raster Address in Interlace Sync & Video Mode

\* Internal line address begins from 0.

• 1) Total number of rasters in a line is even:

When number of rasters is programmed to be even, even raster address is output in the even field and odd raster address is output in the odd field.

• 2) Total number of rasters in a line is odd:

When total number of rasters is programmed to be odd, odd and even addressess are reversed according to the odd and even lines in each field. In this case, the difference in numbers of dots displayed between even field and odd field is usually smaller than case of 1). Then interlace can be displayed more stably.

**NOTE**: The wide disparity of dots between number of dots between even field and odd field influences beam current of CRT. CRT, which has a stable high-voltage part, can make interface display normal. On the contrary, CRT, which has unstable high-voltage part, moves deflection angle of beam current and also dots displaued in the even and odd fields may be shifted. Characters appears distorting on a border of the screen. So 2) programming has an effect to decrease such evil influences as mentioned above. Figure 13 shows fine chart in each mode when interlace is performed.

### **Cursor Control**

Fig 9 show the display patterns where each value is programmed to the cursor start raster register and the cursor end raster register. Programmed values to the cursor start raster register and the cursor end raster register need to be under the following condition.

Cursor Start Raster Register<=Cursor End Raster Register<=Maximum Raster Address Register.

Time chart of CUDISP is shown in Fig 14 and Fig 15.

### Figure 9 Cursor Control



### Figure 10 CRTC Time Chart

Figure 12 Fine Adjustment Period of Frame in Vertical Display (Expansion of fig 10 - R

Figure 13 Interlace Control

Figure 15 CUDISP Timing (Expansion of Fig 14. C

Figure 16 Refresh Memory Address (MA0--MA13

\* How to use the CRTC

### \* DISPLAY SEQUENCE AFTER /RES REKEASE OF HD6845S

HD6845S starts the display operation immediatly after the release of /RES. The operation at the first field is different from the normal subsequent display operation.

[Operation at the first field after the /RES release]

- DISPTMG and CUDISP are not output. (They remain at "Low" level. The display is inhibited.)
- The data programmed in the start address register is not used. (MA and RA start at "0").
- The sequences are shown in the following figures.

### Figure 42 /RES Release sequence

Figure 43 Release sequence in the Non-Interlace Mode

Figure 44 Release sequence in the Interlace Mode (1)

Figure 44 Release sequence in the Interlace Mode (2)

# \* ANOMALOUS OPERATIONS IN HD6845S CAUSED BY REWRITING REGISTERS DURING DISPLAY OPERATION \*

| Register<br># | Register Name                                                                                                                                                                                                                           | Anomalous opeations caused by rewriting registers<br>& Conditions to avoid those operations                                                                                                                                                                          | Rewriting** OK or NG |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| R0            | Horizontal Total                                                                                                                                                                                                                        | The horizontal scan period is disturbed.                                                                                                                                                                                                                             | X                    |
| R1            | Horizontal Displayed                                                                                                                                                                                                                    | There are some cases where the width of DISPTMG<br>becomes shorter than the programmed value at the<br>moment of the rewrite operation. An error operation<br>occurs only during one raster period.                                                                  | ο                    |
| R2            | Horizontal Sync Position                                                                                                                                                                                                                | Horizontal Sync PositionThere are some cases where HSYNC is placed on the<br>position different from the programmed value or the<br>noise is output.X                                                                                                                |                      |
| R3            | Sync WidthWhen a rewrite operation is performed at a "High" level<br>on HSYNC pulse or VSYNC pulse, there are some<br>cases where the width pulse becomes shorter than the<br>programmed value at the moment of a rewrite<br>operation. |                                                                                                                                                                                                                                                                      | $\land$              |
| R4            | Vertical Total                                                                                                                                                                                                                          | When a rewrite operation is performed during the last<br>raster period in the line, there is a possibility that the<br>disturbance occurs during the vertical scan period.<br>There is no problem of a rewrite operation during raster<br>period except this period. | $\bigwedge$          |
| R5            | Vertical Total Adjust                                                                                                                                                                                                                   | When a rewrite operation is performed in the last<br>character time of the raster period, there are some cases<br>where the numbers of Adjust Register, specified by<br>program, are not added. (Only during the adjust raster<br>period).                           | $\land$              |
| R6            | Vertical Displayed                                                                                                                                                                                                                      | After the moment of a rewrite operation, there are some<br>cases where the Display is inhibited. However, the<br>display according to the programmed value is<br>performed from the next field.                                                                      | ο                    |
| R7            | Vertical Sync Position                                                                                                                                                                                                                  | There are some cases where VSYNC is placed on the position different from the programmed value or the noise is output.                                                                                                                                               | X                    |

| R8  | Interlace & Skew       | Neither scan mode bit nor skew bit is rewritten<br>dynamically. Dynamic Rewrite into scan mode bit and<br>skew bit is prohibited.                                                                                                                                                                                              | X           |
|-----|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| R9  | Maximum Raster Address | The internal operation will be disordered by a rewrite operation.                                                                                                                                                                                                                                                              | X           |
| R10 | Cursor Start Raster    | When a rewrite operation is performed in the last<br>character time of the raster period, there are some cases<br>where the jitter occurs on the cursor raster or the cursor<br>is not displayed correctly. There is also a possibility that<br>the blink rate becomes temporarily shorter than usual.                         | $\land$     |
| R11 | Cursor End Raster      | When a rewrite operation is performed in the last<br>character time of the raster period, there are some cases<br>where the jitter occurs on the cursor rraster or the cursor<br>is not displayed correctly. Moreover, there are also<br>some cases where the blink rate becomes temporarily<br>shorter than normal operation. | $\bigwedge$ |
| R12 | Start Address (H)      | R12 and R13 are used in the last raster period of the field. A rewrite operation can be performed except during this period. However, when R12 and R13 are rewritten in each field seperatly, the display operation,                                                                                                           | 0           |
| R13 | Start Address (L)      | whose start address is determined temporarily by<br>programming sequence, will be performed. A rewrite<br>operation should be performed during the horizontal/<br>vertical display period.                                                                                                                                     | 0           |
| R14 | Cursor (H)             | When a rewrite operation is performed during the<br>display period, there are some cases where the cursor is<br>temporarily displayed at the address different from the<br>programmed value. A rewrite operation should be                                                                                                     | 0           |
| R15 | Cursor (L)             | performed during the horizontal/vertical retrace period.<br>Also, when R14 and R15 are rewritten in each field<br>seperatly, the cursor is displayed temporarily at the<br>temporal address by programming sequence.                                                                                                           | 0           |

- \* ... means temporary abnormal operations in rewriting the internal registers during the display operation. Normally, afte a rewrite operation, the LSI performs the specified display operation from the next field. (The operations in this table are outside our guarantee and are regarded as materials for refrence).
- \*\* O... A rewrite operation is possible without affecting the screen in the display so much.; /.... If conditions are satisfied, a rewrite operation is possible. If conditions are not satisfied, there are some cases where flicker and so on occur temporarily; X.... When a rewrite operation is performed, there are some cases where flicker and so on occur temporarily.

### COMPARISON BETWEEN HD6845S AND HD6845R

### Comparison of function between HD6845S and HD6845R

No. Functional Difference

HD6845R

1

| Programming<br>Method of<br>Number of<br>Vertical<br>Characters | In HD6845R, number of characters is<br>vertically programmed in a unit of two<br>lines, as illustrated above. (Number of<br>vertical total characters, Number of vertical<br>displayed characters, Vertical Sync<br>Position). | In HD6845S, number of characters is<br>vertically programmed in a unit of one lines,<br>as illustrated above. (Number of vertical total<br>characters, Number of vertical displayed<br>characters, Vertical Sync Position).                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                 | Example of above figure                                                                                                                                                                                                        | Example of above figure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|                                                                 | Programmed number into Vertical Display<br>Register = 5                                                                                                                                                                        | Programmed number into Vertical Display<br>Register = 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Number of<br>Rasters per<br>Character<br>Line                   | Only even number can be specified.                                                                                                                                                                                             | Both even and odd number can be specified                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|                                                                 | Number of raster = 10 scan-line (specified)                                                                                                                                                                                    | When number of<br>raster per character<br>line is EVEN.<br>Number of raster =<br>10 scan line<br>(specified)When number of<br>raster per character<br>line is ODD. Number<br>of raster = 9 scan line<br>(specified)                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                                                                 | However, number which is programmed into register is calculated as follows.                                                                                                                                                    | However, number which is programmed into register is calculated as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|                                                                 | Programmed number (Nr) = (Number specified)-1                                                                                                                                                                                  | Programmed number (Nr) = (Number specified-2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| Cursor<br>Display                                               | Cursor is displayed in either EVEN field or<br>ODD field $ \begin{array}{c} 0 \\$                                                                                                                                              | Cursor is displayed in both EVEN and ODD<br>field $ \begin{array}{c}                                     $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|                                                                 | Method of<br>Number of<br>Vertical<br>Characters<br>Number of<br>Rasters per<br>Character<br>Line                                                                                                                              | Programming<br>Method of<br>Number of<br>Vertical<br>Charactersvertical total characters, Number of vertical<br>displayed characters, Vertical Sync<br>Position).Example of above figure<br>Programmed number into Vertical Display<br>Register = 5ConstraintsNumber of<br>Rasters per<br>Character<br>LineNumber of raster = 10 scan-line (specified)Number of<br>Rasters per<br>Character<br>LineNumber of raster = 10 scan-line (specified)Character<br>LineCursor is displayed in either EVEN field or<br>ODD fieldCursor<br>Display01Cursor<br>Display000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 |  |

| 2 | Vertical Sync Pulse<br>Width (VSYNC output) | Fixed at 16 raster scan cycle (16H)                                              | Programmable (1-16 raster scan cycle                                                                                                                                                     |
|---|---------------------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | SKEW function                               | Not included                                                                     | SKEW function is newly included in<br>DISPTMG, CUDISP signals                                                                                                                            |
| 4 | Start Address Register                      | Impossible to READ                                                               | Possible to READ                                                                                                                                                                         |
| 5 | RESET signal (/RES)                         | Output signals of MA0-MA13, RA0-RA4<br>synchronising with DLK "low" level, go to | MA0-MA13 Output, RA0-RA4, Other<br>Outputs - Asynchronous Reset<br>Output signals of MA0-MA13, RA0-RA4<br>and others go to "low" level immediatly<br>after /RES has gone to "low" level. |

### COMPATIBILITY OF HD6845S AND HD6845R

| Non-interlace Mode<br>Interlace Sync Mode | Fully compatible with HD6845R (note 1). HD6845R can be directly replaced by HD6845S in these modes.      |
|-------------------------------------------|----------------------------------------------------------------------------------------------------------|
| 5                                         | Not compatible with HD6845R in regard to programming and data for vertical direction need to be changed. |

• These functions added to HD6845S utilitize undefined bits of the Control Register in HD6845R. If "0" is programmed to the undefined bits in the initial set, it is possible to replace HD6845R with HD6845S without changing the parameters. (The restriction on programming of HD6845S and HD6845R should be taken into consideration).