# SINGLE CHIP SEMI-GRAPHIC DISPLAY PROCESSOR - SINGLE CHIP LOW-COST CRT CONTROL-I FR - UP TO 60 Hz SCREEN REFRESH RATE - 32 KBYTE DEDICATED MEMORY ADDRESS-ING SPACE - 2 SCREEN FORMATS: 25 ROWS OF 40 CHARACTERS 25 ROWS OF 80 CHARACTERS - ON-CHIP 154 ALPHANUMERIC AND 128 SEMIGRAPHIC CHARACTER GENERATOR - FASY EXTENSION OF USER DEFINED ALPHANUMERIC OR SEMI-GRAPHIC SETS (>1K characters) - 40 CHARACTERS/ROW ATTRIBUTES: FOREGROUND AND BACKGROUND COLOR, DOUBLE HEIGHT, DOUBLE WIDTH, BLINKING, CONCEAL, INSERT - 80 CHARACTERS/ROW ATTRIBUTES: UNDERLINING. BLINKING. REVERSE. COLOR SELECT - PROGRAMMABLE ROLL-UP, ROLL-DOWN, UPPER OR LOWER SERVICE ROW - ON-CHIP R. G. B SHIFT REGISTERS - ANALOG COMPOSITE LUMINANCE SIGNAL OUTPUT - VERSATILE I/O CONFIGURATION : VIDEO AND SYNC OR GENERAL PURPOSE I/O **PORTS** - ADDRESS/DATA MULTIPLEXED BUS DI-RECTLY COMPATIBLE WITH STANDARD MICROCOMPUTERS SUCH A 6801, 6301, 8048, 8051 #### DESCRIPTION A complete display control unit may be implemented with TS9347 and a single standard memory package. This new advanced CRT controller drastically reduces IC cost and PCB area for low-end color or monochrome terminal. # ORDERING INFORMATION | Part Number | Package | Pin<br>Configuration | |---------------|---------|----------------------| | TS9347CP/1R00 | DIP40 | 1R00 | | TS9347CP/2R00 | DIP40 | 2R00 | September 1993 1/33 7929237 0058988 088 # PIN CONNECTIONS | TS | DIP40<br>59347CP/1R00 | | - | DIP<br>(\$93470 | | | |------------------|-----------------------|------|-------------------|-----------------|-----------|---| | v <sub>ss</sub> | 1 40 | ADM0 | v <sub>ss</sub> [ | 1, 7 | 40 ADM0 | | | v <sub>ssc</sub> | 2 39 | ADM1 | V <sub>ssc</sub> | 2 | 39 ADM1 | 1 | | OE T | 3 38 | ADM2 | ŌĒ [ | 3 | 38 ADM2 | | | WE 🗏 | 4 37 | ADM3 | WE | 4 | 37 ADM3 | | | ASM [ | 5 36 | ADM4 | ASM | 5 | 36 ADM4 | | | V <sub>DO</sub> | 6 35 | ADM5 | V <sub>DO</sub> | 6 | 35 ADM5 | ŀ | | <b>y</b> ∃ | 7 34 | ADM6 | Υ [ | 7 | 34 ADM6 | | | в | 8 33 | ADM7 | В | 8 | 33 🔲 ADM7 | | | R 🗍 | 9 32 | AM8 | R [ | 9 | 32 AM8 | | | G 📋 | 10 31 | AM9 | G [ | 10 | 31 AM9 | | | CLKOUT [ | 11 30 | AM10 | XTAL [ | 11 | 30 AM10 | | | XTAL. | 12 29 | AM11 | CLK [ | 12 | 29 AM11 | | | CLK 🗌 | 13 28 | AM12 | SYNC IN | 13 | 28 AM12 | | | SYNC IN | 14 27 | AM13 | AS | 14 | 27 AM13 | | | AS 🗀 | 15 26 | AD7 | DS [ | 15 | 26 AM14 | | | DS [ | 16 25 | AD6 | R/W [ | 16 | 25 AD7 | | | P√W □ | 17 24 | AD5 | ADO | 17 | 24 AD6 | | | ADO 🗌 | 18 23 | AD4 | AD1 | 18 | 23 AD5 | | | AD1 | 19 22 | AD3 | AD2 | 19 | 22 AD4 | | | AD2 | 20 21 | cs | cs [ | 20 | 21 AD3 | | | | | | | | | | # PIN DESCRIPTION (All the input/output pins, XTAL and Y excepted, are TTL compatible) | AD (0:7) | 1/0 | Multiplexed<br>Address/Data Bus | These 8 bidirectional pins provide communication with the microprocessor system bus. | |----------|-----|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AS | I | Address Strobe | The falling egde of this control signal latches the address on the AD (0:7) lines, the state of the Data Strobe (DS) and Chip Select (CS) into the chip. | | DS | I | Data Strobe | <ul> <li>When this input is strobed high by AS, the output buffers are selected while DS is low for a read cycle (R/W = 1).</li> <li>In write cycle, data present on AD (0:7) lines are strobed by R/W low (set timing diagram 2).</li> </ul> | | | | | <ul> <li>When this input is strobed low by AS, R\walday\wideteq gives the direction of data<br/>transfer on AD (0:7) bus. DS high strobes the data to be written during a<br/>write cycle (R\w = 0) or enables the output buffers during a read cycle<br/>(R\w = 1) (see timing diagram 1).</li> </ul> | | R/W | ı | Read/Write | This input determines whether the internal registers get written or read. A write is active low ("0"). | | CS | 1 | Chip Select | The TS9347 is selected when this input is strobed low by AS. | Description # MEMORY INTERFACE Pin Type Name **Function** | ADM (0:7) | 1/0 | Multiplexed<br>Address/Data Bus | Lower 8 bits of memory address appear on the bus when $\overline{\text{ASM}}$ is high. It the becomes the data bus when ASM is low. | | |-----------|-----|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--| | AM (8:14) | 0 | Memory<br>Address/Data Bus | Theses 7 pins provide the high order bits of the memory address. | | | ŌE | 0 | Output Enable | When low, this output selects the memory data output buffers. | | 2/33 ■ 7929237 0058989 Tl4 1 872 347-02 TBL # PIN DESCRIPTION (continued) | Name | Pin<br>Type | Function | Description | |----------|-------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MEMOR | Y INTE | RFACE (continued) | | | WE | 0 | Write Enable | This output determines whether the memory gets read or written. A write is active low ("0"). | | ASM | 0 | Memory<br>Address Strobe | This signal cycles continuously. Address can be latched on its falling edge. | | VIDEO II | NTERF | ACE | | | R | 0 | Red/<br>Composite Sync | - When $TGS_5=0$ , this output delivers the Red component of the video signal. It is low during the H and V blanking intervals. | | | | | - When TGS <sub>5</sub> = 1, this output delivers the composite synchronization signal. | | G | 0 | Gree/Insert/Port1 | - When $TGS_4$ = $TGS_5$ = 0, this output delivers the Green component of the video signal. It is low during the V and H blanking intervals | | | ;<br>;<br>! | | - When $TGS_4 = 1$ , this output delivers the insert attribute. It allows to insert the video signals in another external video for captionning purposes for example. It can also be used as a general purpose attribute or color. | | | | | <ul> <li>When TGS<sub>5</sub> = 1 and TGS4 = 0, this pin is a general purpose output port its<br/>state is programmed by the value of PAT2.</li> </ul> | | В | 0 | Blue/Port2 | - When $TGS_5=0$ , this output delivers the Blue component of the video signal. It is low during the V and H blanking intervals. | | | | | - When $TGS_5 = 1$ , this pin is a general purpose output port programmed by the value of PAT7. | | Y | 0 | Composite<br>Luminance | This analog output delivers the composite luminance signal with 8 different grey levels plus the synchronization level. | | Sync | ı ı | Sync Input/<br>Input Port | <ul> <li>When TGS<sub>3</sub> = 1, this input allows to vertically and, if TGS<sub>2</sub>, is set, horizontally<br/>synchronize the TS9347 on an external signal.</li> </ul> | | | | | <ul> <li>When TGS<sub>2</sub> = TGS<sub>3</sub> = 0, the logic state of this input may be read by the<br/>microprocessor, and acts as a general purpose input port</li> </ul> | | | | | - This input must be grounded if not used. | # OTHERS PINS | _ | CLK<br>XTAL | 1/0 | Crystal/Clock Input<br>Crystal Output | These pins allow to connect a crystal to generate the input frequency from 12 to 15MHz. If an external signal is used, it must be applied on CLK input, XTAL is left unconnected. | |---|--------------------------------------|-----|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | CLK<br>OUT | 0 | Clock Output | When internal oscillator is used, this pin provides a TTL compatible oscillator output for general operation. | | | Vss | s | Power Supply | Ground | | | $V_{DD}$ | s | Power Supply | +5V | | , | V <sub>SSC</sub><br>V <sub>DDC</sub> | s | Power Supply<br>Power Supply | These pins provide separate 0V and 5V power supply for the Y analog converter, allowing easier noise reduction. | #### **BLOCK DIAGRAM** # **ABSOLUTE MAXIMUM RATINGS** | Symbol | Parameter | Value | Unit | |-------------------|-----------------------------|-----------|------| | V <sub>CC</sub> * | Supply Voltage | 0.3, 7.0 | V | | V <sub>IN</sub> * | Input Voltage | 0.3, 7.0 | V | | TA | Operating Temperature Range | 0, +70 | °C | | T <sub>stq</sub> | Storage Temperature Range | -55, +150 | °C | | Pom | Max. Power Dissipation | 0.75 | W | With respect to Vss. 4/33 7929237 0058991 672 Stresses above those hereby listed may cause permanent damage to the device. The ratings are stress ones only and functional operation of the device at these or any conditions beyond those indicated in the operations (sections of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. Standard MOS circuits handling procedure should be used to avoid possible damage to the device. # **ELECTRICAL OPERATING CHARATERISTICS** $V_{CC} = 5.0V \pm 5\%$ , $V_{SS} = 0$ , $T_{amb} = 0$ to $70^{\circ}$ C (unless otherwise specified) | Symbol | Parameter | MIn. | Тур. | Max. | Unit | |--------------------|-----------------------------------------------------------------------------------------------------------------------|----------|------|-----------------|--------| | Vcc | Supply Voltage | 4.75 | 5 | 5.25 | ٧ | | $V_{IL}$ | Input Low Voltage | -0.3 | - | 0.8 | ٧ | | V <sub>IH</sub> | Input High Voltage CLK (external CLK) Other Inputs | 2.2<br>2 | - | V <sub>CC</sub> | V<br>- | | IIN | Input Leakage Current (execpt CLK) | - | - | 10 | μА | | Vон | Output HIgh Voltage (I <sub>load</sub> = 500μA) | 2.4 | - | - | ٧ | | V <sub>OL</sub> | Output Low Voltage I <sub>load</sub> = 4mA : AD (0:7), ADM (0:7)<br>I <sub>load</sub> = 1 mA : Other Outputs Except Y | - | - | 0.4 | ٧ | | PD | Power Dissipation | - | 350 | 500 | mW | | CIN | Input Capacitance | - | - | 15 | pF | | ITSI | Three State (off state) Input Current | - | - | 10 | μА | | t <sub>start</sub> | Crystal Oscillator Start Time | - | - | 1 | ms | Figure 1 : On Chip Oscillator Figure 2: Typical Crystal Parameters 5/33 #### **MEMORY INTERFACE** MEMORY INTERFACE CHARACTERISTICS (V<sub>CC</sub> = 5.0V ±5%, T<sub>amb</sub> = 0 to +70°C) Clock: Duty Cycle 40 to 60%; $t_r$ , $t_f < 5$ ns, $V_{IH} = 2.2V$ Reference Levels : $V_{IL} = 0.8V$ and $V_{IH} = 2V$ , $V_{OL} = 0.4V$ and $V_{OH} = 2.4V$ | ldent. | | 8 | FIN = | 12MHz | F= | 1/T | Unit | |--------|-------------------|----------------------------------------------------------------|-------|-------|--------|-------|-------| | Number | Symbol | Parameter | Min. | Max. | Min. | Max. | Uilli | | 1 | telel | Memory Cycle Time | 5 | 00 | 6 | Т | ns | | 2 | t <sub>D</sub> | Output Delay Time from CLK Rising Edge (ASM, OE, WE) | - | 60 | - | 60 | ns | | 3 | t <sub>EHEL</sub> | ASM High Pulse Width | 120 | - | 2T -33 | - | ns | | 4 | teldv | Memory Access Time from ASM Low | - | 250 | - | 4T-43 | ns | | 5 | t <sub>DA</sub> | Output Delay Time from CLK Rising Edge<br>ADM (0:7), AM (8:14) | - | 80 | - | 80 | ns | | 6 | tavel | Address SEtup Time to ASM | 30 | - | T-49 | - | ns | | 7 | telax | Address HOld Time from ASM | 55 | - | T -21 | - | ns | | 8 | tolaz | Address off Time | - | 80 | - | 80 | ns | | 9 | tgHDX | Memory Hold Time | 10 | - | 10 | - | ns | | 10 | toz | Data off Time from OE | - | 60 | - | T-19 | ns | | 11 | tGLDV | Memory OE Access Time | - | 150 | - | 2T-16 | ns | | 12 | tavwl | Data Setup Time (write cycle) | 30 | - | T-49 | - | ns | | 13 | twnqx | Data Hold Time (write cycle) | 30 | - | T-49 | - | ns | | 14 | twLwH | WE Pulse Width | 110 | - | 2T -48 | - | ns | Figure 3: Test Load Table 1 | IUDIC I | | | |---------|-------------------------|------------------------------| | Symbol | ADM (0, 7)<br>AD (0, 7) | Other<br>Outputs<br>Except Y | | С | 100pF | 50pF | | RL | 1kΩ | 3.3kΩ | | R | 4.7kΩ | 4.7kΩ | Figure 4: Memory Interface Timing Diagram 6/33 7929237 0058993 445 876 Powered by ICminer.com Electronic-Library Service CopyRight 2003 #### MICROPROCESSOR INTERFACE TS9347 is MOTEL compatible. It automatically selects the processor type by using AS input to latch to state of the DS input. No external logic is needed to adapt bus control signals from most of the common multiplexed bus microprocessors. | TS9347 | 6801 | INTEL Family | |--------|-----------|--------------| | | Timing 1 | Timing 2 | | AS | AS | ALE | | DS | DS, E, Ø2 | RD | | R/W | ¹ R/₩ | WR | MICROPROCESSOR INTERFACE TIMING CHARACTERISTICS (AD (0:7), AS, DS, R/W, CS) $V_{CC} = 5.0 \pm 5\%$ , $T_A = 0$ to $70^{\circ}$ C, $C_L = 100$ pF on AD (0:7) Reference Levels : $V_{IL} = 0.8V$ and $V_{IH} = 2V$ on All Inputs ; $V_{OL} = 0.4V$ and $V_{OH} = 2.4V$ on All Outputs. | ldent.<br>Number | Symbol | Parameter | Min. | Тур. | Max. | Unit | |------------------|------------------|---------------------------------------------------------------------------|------|------|------|------| | 1 | tcyc | Cycle Time | 400 | - | - | ns | | 2 | tasd | DS Low to AS High (timing 1)<br>DS High or R/W High to AS High (timing 2) | 26 | | - | ns | | 3 | tased | AS Low to DS High (timing 1)<br>AS High or DS Low or R/W Low (timing 2) | 30 | - | - | ns | | 4 | tpweh | Write Pulse Width | 200 | - | - | ns | | 5 | tpwash | AS Pulse Width | 76 | - | - | ns | | 6 | taws | R/W to DS Setup Time (timing 1) | 100 | - | - | ns | | 7 | t <sub>RWH</sub> | R/W to DS Hold Time (timing 1) | 10 | - | - | ns | | 8 | tasl | Address and CS Setup Time | 20 | - | - | ns | | 9 | tash | Address and CS Hold Time | 20 | | - | ns | | 10 | tosw | Data Setup Time (write cycle) | 100 | _ | - | ns | | 11 | tohw | Data Hold Time (write cycle) | 10 | | - | ns | | 12 | t <sub>DDR</sub> | Data Access Time from DS (read cycle) | - | - | 150 | ns | | 13 | tona | DS Inactive to High Impedance State Time (read cycle) | 10 | - | 63 | ns | | 14 | tacc | Address to Data Valid Access Time | | | 300 | ns | Figure 5: Microprocessor Interface Timing Diagram 1 (6801) 7/33 877 7929237 0058994 381 Figure 6: Microprocessor Interface Timing Diagram 2 (INTEL type) - READ CYCLE Figure 7: Microprocessor Interface Timing Diagram 2 (INTEL type) - WRITE CYCLE 8/33 7929237 0058995 218 🚾 —————— ### VIDEO INTERFACE R. G. B. I. $V_{CC} = 5.0V \pm 5\%$ , $T_{amb} = 0$ to $+70^{\circ}C$ , CLK Duty Cycle 50%, $C_L = 50 pF$ Reference Levels: VIL = 0.8V and VIH = 2.2V on CLK Inputs $V_{OL} = 0.4V$ and $V_{OH} = 2.4V$ on All Outputs. | Symbol | Parameter | Min. | Тур. | Max. | Unit | TBL | |----------------|----------------------------|------|------|------|--------|--------| | t <sub>D</sub> | Output Delay from CLK Edge | - | - | 60 | l ne i | 9347-1 | Figure 8 # INPUT CLK | Symbol | Parameter | Min. | Тур. | Max. | Unit | |-------------------------------------|---------------------------|------|------|------|------| | tpwch | CLK High Pulse Width | 25 | - | - | ns | | tpwcL | CLK Low Pulse Width | 25 | - | - | ns | | t <sub>rc</sub> , t <sub>fc</sub> | CLK Rise and Fall Time | - | - | 10 | пѕ | | twcoн | CLKOUT High Pulse Width | 20 | - | - | ns | | twcoL | CLKOUT Low Pulse Width | 20 | - | - | ns | | t <sub>rco</sub> , t <sub>tco</sub> | CLKOUT Rise and Fall Time | - | | 20 | ns | Figure 9: Case of External CLK Generation Figure 10: Case of Internal Oscillator (fin = 12MHz) Y OUTPUT: Composite Luminance. **7929237 0058996 154** 9/33 # REFERENCE LEVEL $V_{DDC} = V_{DD} = 5V$ , $V_{SSC} = V_{SS} = 0V$ | G | R | В | Signal | Level (V) | |---|-----|-----|---------|-----------| | 0 | 0 | 0 | SYNC | 0.06 | | ă | Ŏ | Ŏ | BLACK | 0.50 | | ŏ | Õ | l 1 | BLUE | 0.80 | | ŏ | 1 1 | Ó | RED | 0.92 | | ŏ | i i | ĺi | MAGENTA | 1.03 | | ĭ | Ó | Ó | GREEN | 1.15 | | 1 | Ō | 1 | CYAN | 1.26 | | 1 | 1 | Ó | YELLOW | 1.38 | | 1 | 1 | ĺi | WHITE | 1.50 | 347-12 TE # **ELECTRICAL SPECIFICATION** Over Full Temperature Range : V<sub>DDC</sub> = V<sub>DD</sub> = 5V (see note 1) $V_{SSC} = V_{SS} = 0 \text{V}, \ C_L = 20 \text{pF}, \ R_L > 100 \text{k}\Omega$ to $V_{SS}$ or $V_{DD}$ | Parameter | Min. | Тур. | Max. | Unit | | | | | | |----------------------------------------------|------------|------|------|------|--|--|--|--|--| | Monotonicity | Guaranteed | | | | | | | | | | Output Level Dispersion | - | 10 | 50 | mV | | | | | | | Propagation Delay (clock edge to 50% output) | - | - | 60 | ns | | | | | | | Rise and Fall Time (10 - 90%) | - | - | 30 | ns | | | | | | | Output Static Impedance | - | | 600 | Ω | | | | | | Note: The DAC is a 9 output potentiometric divider: therefore, each voltage variation on V<sub>DDC</sub> is repercuted on the output with the same relative value with respect to V<sub>SSC</sub>. Figure 11: Typical Application Figure 12: Test Condition 10/33 7929237 0058997 090 881 Figure 13 : Vertical and Horizontal Synchronization Outputs (T $\frac{1}{f_{CLK}}$ ) Powered by ICminer.com Electronic-Library Service CopyRight 2003 T27 #### **FUNCTIONAL DESCRIPTION** The TS9347 is a low cost, semigraphic, CRT controller. The TS9347 displays up to 25 rows of 40 characters or 25 rows of 80 characters, including either an upper or lower service row. The on-chip character generator provides a standard, 5 x 7, character set and standard semigraphic sets. More user definable (8x10) alphanumeric or semigraphic sets may be mapped in the 32 K x 8 private memory addressing space. These user definable sets are available only in 40 characters per row format. ### Microprocessor Interface The TS9347 provides an 8-bit, address/data multiplexed, microprocessor interface. It is directly compatible with popular (6801, 8048, 8051, 8085....) microprocessors. ### Registers The microprocessor directly accesses 8 registers: - R0 : Command/status register - R1: R2, R3: Data registers - R4, R5, R6, R7: Each of these register pairs points into the private memory. Through these registers, the microprocessor indirectly accesses the private memory and 5 more registers: - ROR, DOR: Base address of displayed page memory and of user external character generators. - PAT, MAT, TGS: Used to select the I/O configuration, the page attributes and format, and to program the timing generator options. ### **Private Memory** The user may partition the 32 K $\times$ 8 private memory addressing space between : - pages of character codes (2 K x 8 or 3 K x 8), - external character generators, - general purpose user area. Many types of memory components are suitable: - ROM, DRAM or SRAM, - 2 K x 8, 8 K x 8, 16 K x 4, 32 K x 8 organization, - Modest 400ns cycle time and 240ns access time is required. 40 Characters per Row : Character Code Formats and Attributes Once the 40 characters per row format has been selected, one character code format out of two must be chosen: - 24-bit format - All the attributes are provided in parallel. - 16-bit format : - Some parallel attributes, others are latched. The 16-bit fixed format is compatible with EF9345 CRT controller. Character attributes provided: - Back ground and foreground color (3 bits each), - Double height, double width, - Blinking, - Reverse, - Underlining, Conceal. - Insert. - 11 x 100 user definable character generator in memory. # **80 Characters per Row Format :** Character Code Format and Attributes Two character code formats are provided: - Long (12 bits) with 4 parallel attributes : Blinking, Underlining, Reverse, Color select - Short (8 bits): no attributes. #### **Timing Generator** The whole timing is derived from a 12 to 15MHz on chip oscillator. The RGB outputs are shifted at 8 to 10MHz for the 40 character/row format and at 12 to 15MHz for the 80 character/row. The timing generator allows different display modes: - Interlaced or not - Master or slave synchronization. # **Video Output** The video output is always available as a composite luminance signal on the analog output Y; the logic R, V, B, Syncout and Insert components may be selected on the RGB output pins. 12/33 7929237 0058999 963 1 #### MEMORY ORGANIZATION ### Logical and Physical Addressing The physical 32 Kbyte addressing space is logically partitioned by the TS9347 into 40-byte buffers (Figure 15). More precisely, a logical address is given by an X, Y, Z triplet where : - X = (0 to 39) points to a byte inside a buffer, - Y = (0,8 to 31) points to a buffer a 1 Kbyte block, - Z = (0 to 31) points to a block. Figure 14: Memory Row Buffer #### **Pointers** Each X, Y, and Z component of a logical address is binary encoded and packed in two 8-bit registers. Such a register pair is a pointer (Figure 15). TS9347 contains two pointers: - R6, R7 : main pointer - R4, R5 : auxiliary pointer. Both pointers have the same format. R7 (resp. R5) holds the X component and the two LSB's of the Z component. R6 (resp R4) holds the Y component and the three MSB's of the Z component. This package induce a partitionning of Z in 8 districts of 4 blocks each. Logical to physical translation is performed on chip following Figure 16 scheme. Figure 15: Pointer Auto Incrementation #### **Data Structures in Memory** A page is a data structure displayable on the screen up to 25 rows of characters. According to the character code format, each row on the screen is associated with 2 (or 3) 40-byte buffers. This set of 2 (or 3) buffers constitutes a row buffer (Figure 14). The buffers belonging to a row buffer must meet the following requirements: - they have the same Y address, - they have the same district number, - they lie at 2 (or 3) successive (modulo 4) block addresses in their common district. Consequently, a row buffer is defined by its first buffer address and its format. A Page is a set of successive row buffers: - with the same format, - with the same district number, - with the same block address of first buffer. This block address must be even. - lying at successive (modulo 24) Y addresses. 7929237 0059000 283 | 13/33 Figure 16: Logical to Physical Address Transcoding Performed on-chip Consequently, a page should not cross a district boundary. General purpose memory area may be used but should respect the buffer or row buffer structure. See Figure 15 for pointer incrementation implied by these data structures. ### Memory Time Sharing (see Figure 17) The memory interface provides a 500ns cycle time at $f_{\text{IN}}$ = 12MHz. That it to say a 2 Mbyte/s memory bandwidth is shared between : - reading a row buffer from memory to load the internal row buffer (up to 120 bytes once each row), - reading user defined characters slices from memory (1 byte each μs), - indirect microprocessor read or write operation, - refresh cycles to allow DRAM use, with no overhead. A fixed allocation sheme implements the sharing. During these lines, no microprocessor access is provided for 104µs; this holds too when no user defined character slices are addressed. Figure 17: Memory Cycle Allocation (12MHz operation). Notes: 1. Dumming cycles are read cycles at dummy addresses. RFSH cycles are read cycles performed by an 8-bit auto-incrementing counter. Low order address byte ADM (0:7) cycle through its 256 states in less than 1ms. The microprocessor may indirectly access the memory once every µs, except during the first and the last line of a row, when the internal buffer must be reloaded. 14/33 ■ 7929237 0059001 11T ■ #### SCREEN FORMAT AND ATTRIBUTES OUTPUTS CONFIGURATION The screen format and attributes are programmed through 5 indirectly accessible registers: ROR, TGS, PAT, MAT, and DOR. IND command allows accessing to these registers. TGS is also used to select the timing generator options (see Figures 18a and 18b). ### Row And Character Code Format: TGS (6:7) Two row formats and 4 character code formats are available but cannot be mixed in a given screen. # Timing Generator And Configuration Options: TGS (1:5) TGS1 = 0 : noninterlaced mode, 312 lines/frame. TGS1 = 1 : interlaced mode, 312.5 lines/frame. TGS (2,3): input synchronization configuration. The SYNC input may be interpreted as a synchronization signal or as a general purpose input port, which state can be read by the microprocessor in the status register (bit 2). Alternatively, the vertical synchronization output from the timing generator can be read in the same register. The composite incoming SYNC IN signal is separated into two internal signals: - Vertical Synchronization In (VSI) - Horizontal Synchronization In (HSI) Figure 18a: Screen Format Table TGS3 = 1 enables VSI to reset the internal line count: SYNC IN input is sampled at the beginning of the active area of each line. When the sample transits from 0 to 1, the line count is reset at the end of the current line. TGS3 = TGS2 = 1 enables HSI to control an internal digital PLL: HSI and on-chip generated H. SYNC OUT are considered as in phase if their leading edges match at plus or minus 1 clock period. When they are out of phase, the line period is lenghtened by 1 clock period (80 ns at 12 MHz). Screen Format Table resumes the different combinations. TGS (4,5): output configuration Three output pins may be configured to output either video signals or general purpose output ports. The Screen Format Table summarizes the possible configurations, with the following definitions: R, V, B: Red, Green and Blue Video components I : Insert signal HVS : Composite H and V synchro output P1 P2 : General purpose output ports PAT2 gives the value of P1, PAT7 gives the value of P2: a logical "1" will cause a "high" on the corresponding output, while a "0" results in a "low". 15/33 Figure 18b: Screen Format Table Screen Partition, Page Pointer ROR (see top of the Screen Format Table) The screen is partitioned in three areas: - The margin - The service row - The bulk or remaining rows MAT (0:3) declares the color of the margin and the value IM of its insert attribute. DOR7 and ROR register point to the page to be displayed: DOR7 gives the MSB of the Z address, ROR (7:5) three next bits, the LSB is implicitly Z0 = 0 (the page block address must be even). YOR (= ROR (4:0)) gives the first row to be dis- played at the top of the bulk area. The next row buffers to be displayed are fetched sequentially by incrementing the Y address (modulo 24). This address never gets out of the origin block. Incrementation of YOR by the microprocessor yields a roll up. Service Row: TGS0: PAT0 The 10 scan line service row can be displayed at the top or the bottom of the screen, depending on the value of TGS0. The service row is fetched from the origin block at Y=0; it does not roll; it may be disabled by PAT0 = 0; it is then displayed as a margin extension. 16/33 7929237 0059003 T92 ### Bulk: PAT1; MAT7 The bulk is displayed for 240 scan lines. Each row buffer is usually displayed for 10 scan lines. However, MAT7 = 1 doubles this figure: then every character appears in double height (double height characters are quadrupled). PAT1 = 0 disables the bulk. When disabled, the corresponding scan lines are displayed as a margin extension. # **Cursor: MAT (4:6)** To be displayed with the cursor attribute, a character must be pointed by the main pointer (R6, R7) and MAT6 must be set. The cursor attributes are given by MAT (4,5): - Complementation : - The R, G, $\underline{B}$ or each pixel is logically negated : R, G, $\overline{B} \rightarrow \overline{R}$ , $\overline{G}$ , $\overline{B}$ - Underline : - The underline attribute is negated - Flash: - The character is periodically displayed with, then without the cursor attribute $(50\%/50\% \approx 1 \text{ Hz})$ . # Flash Enable (PAT 6) - Conceal Enable (PAT3) Any character flashing attribute is a "don't care" when PAT6= 0. When PAT6 = 1, a character flashes if its flashing attributes is set. It is then periodically displayed as a space $(50\%/50\% \approx 0.5 Hz)$ . PAT3 is a 'don't care" for 80 char./row formats. When any 40 char./row format is in use: - if PAT3 = 0, the conceal attribute of any character is a "don't care" - if PAT3 = 1, the conceal attribute of each character is interpreted: a concealed character appears as a space on the screen. ### Insert Modes: PAT (4:5) These modes make sense only if the insert signal I is available on the G pin, that is to say when TGS4 = 1. During retrace, margin and extended margin periods, the I signal outputs the value of the insert margin attribute: I = IM = MAT3. During active line period, the I output is controlled by the insert mode, and I1 and I2, the insert attributes of each characters. The I output may have several uses: (See Figure ???). - As a margin/active area signal in the Active Area Mark mode - As a character per character marker signal in the Character Mark mode - As a video mixing signal in the other modes, provided that the TS9347 has been vertically and horizontally synchronized with an external video source: the I output allows mixing TS9347 video output (I = 1) and external video signal (I = 0). This mixing may occur for the complete character window (Boxing mode) or only for the foreground pixels (Inlay mode). # **Video Output during Active Periods** | Insert Mode | l1 l2 | | Char. Levels Pixels | 1 | Video Output | Comments | | | |------------------|-------------|-------------|-------------------------------|-------------|------------------------------------------|---------------------------------|--|--| | Active Area Mark | - | - | • | 1 | Unchanged | | | | | Character Mark | 0 | - | - | 0 | Unchanged<br>Unchanged | | | | | Inlay | 0<br>1<br>1 | - | Background<br>Foreground | 0<br>0<br>1 | Black<br>Black<br>Unchanged | Non insert<br>Inlaid | | | | Boxing and Inlay | 0<br>1<br>1 | 0<br>1<br>1 | -<br>Background<br>Foreground | 0<br>1<br>0 | Black<br>Unchanged<br>Black<br>Unchanged | Non inserted<br>Boxed<br>Inlaid | | | 47-14 IBL ## 40 Char/row Character Codes To display pages in 40 character per row format, one out of two character code formats must be selected : - Long (24 bits) code : all parallel attributes. - Short (16 bits) code : mix of parallel and latched attributes. Short codes are translated into long codes by the TS9347 during the internal row buffer loading process. The choise of the character code format is obviously a display flexibility/memory size trade off, left up to the user. ## **Long Codes** This is the basic 40 char/row code. Each 8 pixel x 10 lines character window on the screen is associated with a 3-byte code in memory, namely the C. B, and A bytes (Figure 19). A row on the screen is associated with a 120 byte row buffer in memory. ### 3-BYTE CODE STRUCTURE - C7 is a don't care, up to 128 characters may be addressed in each set, each user definable set holds only 100 characters: C-byte value ranges from 00 to 03 and 20 to 7F (hexa). - 2. B (3:7) give the type and the set number of the character. - 3. When I2, U, L are not programmable, the default value of these attributes is 0. 4. Character code byte a defines a two color set giving directly (Table 3) the two values (B1, G1, R1) and (B0, G0, R0) respectively affected to the 1's and the 0's of the character pattern, the negative attribute, when set, exchanges the two values. Figure 19: 40 Character Long Codes Table 2 | | Type a | nd Set | B (3:7) | | Number of Character Per Set | Set | Set | Cell | |----|----------|------------|---------|----|---------------------------------------------|------------|---------------|----------------| | B7 | B6 | <b>B</b> 5 | B4 | В3 | C (0:6) | Name | Туре | Location | | 0 | 12<br>12 | 1 | 0 | L | 128 STANDARD MOSAIC<br>32 COMPLEMENT. CELLS | G10<br>GOE | SEMI<br>GRAPH | ON CHIP<br>ROM | | | 12 | 0 | U | L | 128 ALPHANUMERICS | G0 | ALPHA | ] NOW | | | 0 | 0 | U | L | 100 ALPHA UDS | G'0 | ALFINA | | | 4 | 0 | | 0 | L | 100 SEMI-GRAPHICS UDS | G'10 | 0514 | EXTERNAL | | • | " | ' | 1 | L | 100 SEMI-GRAPHICS UDS | G'11 | SEMI<br>GRAPH | RAM | | | 1 | х | X | Х | 800 SEMI-GRAPHICS UDS | Q0:7 | 1 | | = Double width Notes: U = Underlined Double height, double width: a correct operation assumes that the same character code had been repeated in the page memory (five for double height or double width, four times for double size). Double height: each slice of the character is repeated; twice to get a 8 x 20 pattern. However for the alphanumeric characters, scheme is slightly different: the upper slice (SN = 0) is tripled, the next (SN = 1 to 8) are doubled, and the last (SN = 9) is displayed only once. 18/33 7929237 0059005 865 Table 3: Coloring a Character | L | В | G | R | Color Value | |---|---|---|---|-------------| | Г | 0 | 0 | 0 | BLACK | | | 0 | 0 | 1 | RED | | 1 | 0 | 1 | 0 | GREEN | | | 0 | 1 | 1 | YELLOW | | | 1 | 0 | 0 | BLUE | | | 1 | 0 | 1 | MAGENTA | | | 1 | 1 | 0 | CYAN | | | 1 | 1 | 1 | WHITE | Table 4: Shifting a Slice | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | Shift Direction : LSB First 1 = Foreground 0 = Background #### **Short Codes** These 16-bit codes achieve memory saving whith some penalties: - Q0 to Q7 and GOE cannot be reached. - Some attributes are latched and can be changed only while displaying a space (delimitor code). They are fully compatible with EF9345 (binary code and display interpretation) if the I2 attribute is given the value 0. Figure 22 gives the short to long translation process which occurs for each row - while loading the internal row buffer - before display. #### HANDLING SHORT AND LONG CODES The TLM, TLA, TSM, and TSA, commands allow an easy X, Y random or an X sequential access to/from the microprocessor from/to a memory row buffer (see Figures 20 and 21). # **User Defined Character Generator In Memory**: DOR REGISTER With 40 char./row, the elementary window dimensions on the screen are 10 slices x 8 pixels. Thus, a character cell holds 10 bytes in memory and 4 character cells are packed in one 40-byte buffer (Figure 23). The cells of one given character set should be layed in one block. Up to 100 character cells may be addressed in each set. The location in memory, where to fetch the sets in use, are declared by DOR register (Figure 24). For each type of set, it gives the MSB(s) of the Z block address. TS9347 reads the Z LSB(s) in the B byte of the (equivalent) long code. As usual, the character code is read in the C byte. SN is derived from the scan line rank in the row and the double height status. Figure 20 : Long Codes in Memory Triple Row Buffer Figure 21: Short Codes in Memory Double Row Buffer 19/33 7929237 0059006 7T1 | Figure 22: Fixed Short Code to Fixed Long Code Translation Figure 23: Packing Uds Cells in Memory Figure 24: UDS Fetch to Display 21/33 891 7929237 0059008 574 ### **Loading User Defined Character Set** Before loading a character set into RAM, the user must - Assign a name to the set : - G'0, G'10, G'11, or Q0-7 - Assign a character number to each character belonging to this set. Character numbers range from 0 to 3 and 32 to 127. - It is binary coded into 7 bits C (0.6) C (0.6) will be loaded later into a C byte character code in order to display the character. - A pointer to a character slice in memory is then manufactured from - the character number C (0.6), - the slice number SN (0.3), - the bloc number assigned to the set Z (0.4) Note: Different sets may be mixed in the same block, as long as the character have different code numbers. Figure 25: Accessing a Character Slice in Memory Figure 25 shows how to proceed with the auxiliary pointer and the TBM and TBA commands. Note: The main pointer may be also used. When sequentielly accessing slices of a given character, auto incrementation is helpless. # **On-chip Character Generator** - G0 and GOE are common to 40 and 80 char./row modes (Figure 26 and Figure 36). - G10 is the standard mosaïc set for videotex (Figure 27). - GOE cannot be reached from the 16 bit short codes (Figure 28). # Displaying the Attributes - For normal operation, a double height and/or double width character must be repeated in memory in two successive Y and/or X positions. The user may otherwise freely mix any character size. - 2. The attributes are logically processed in the following order: - Underline or underline cursor : foreground forced on the last slice (SN = 9). - Flash: background periodically forced on the whole window (≈ 0.5 Hz). The phase depends on the negative attribute. - Conceal: background forced permanently on the whole window. A concealed character neither blinks nor is underlined. - Negative: exchange the background and foreground color values when set. - Coloring. - Basic pixel shift frequency: fclk x 2/3 = 8 to 10MHz 22/33 **=** 7929237 0059009 400 | Figure 26: Go Alphanumeric Character Set in 40 Character/Row Mode-TS9347. | - | |-------------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 9947-34 EDS | | | 23/33 893 **■** 7929237 0059010 122 Figure 27: G<sub>10</sub> Semigraphic Character Set. | | | | | | SEPA | | EMI-GRA | | | | MI-GRAPI | | |-----|----|----|----|----------|------|----------|----------|---|----------|------|----------|---| | | | | | C6<br>C5 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | | | | | 85 | 0 | 1 | 0 | 1 | 0 | 0 | 1 0 | 1 | | СЗ | C2 | C1 | CO | C4 | | <u> </u> | <u> </u> | | <u> </u> | | | | | . 0 | 0 | 0 | 0 | | | | | | | | | | | 0 | 0 | 0 | 1 | | | | | | | | | | | 0 | o | 1 | 0 | | | | | | | | | | | 0 | 0 | 1 | 1 | | | | | | | | | | | 0 | 1 | 0 | 0 | | | | | | | | | | | 0 | 1 | 0 | 1 | | | | | | | | | | | 0 | 1 | 1 | 0 | | | | | | | | | | | o | 1 | 1 | 1 | | | | | | | | | | | 1 | 0 | 0 | o | | | | | | | | | | | 1 | 0 | 0 | 1 | | | | | | | | | | | 1 | 0 | 1 | 0 | | | | | | | | | | | 1 | 0 | 1 | 1 | | | | | | | | | | | 1 | 1 | 0. | o | | | | | | | | | | | 1 | 1 | 0 | 1 | | | | | | | | <br> | | | 1 | 1 | 1 | 0 | | | | | | | | | | | 1 | 1 | 1 | 1 | | | | | | | :::: | | | 24/33 7929237 0059011 069 🖿 Figure 28: GOE Extension Character Set #### 80 CHAR / ROW CHARACTER CODES To display pages in 80 character per row format, one of two character code formats must be selected: - Long (12 bits) code: 4 parallel attributes - Short (8 bits) code : no attribute. Both formats address the on-chip $G_0$ and GOE sets (154 characters 6 x 10) sets. None allows UDS addressing. # **Long Codes** Each 6 pixels x 10 lines character window on the screen is associated with a 12-bit code in memory, namely a C byte and an attribute nibble A (Figure 29). Figure 29: 80 Char/Row Character Code #### **Short Codes** They are derived from the long code by giving a 0 implicit value to each bit of the Anibble positive, not underlined, not flashing. # **Packing The Codes In Memory** Long codes are paired. A pair is packed in a 3-byte word. Therefore, the 80 codes of a row fill a 120-byte row buffer (Figure 30). The left most position on the screen is even. Its corresponding C byte is at the beginning of the first buffer. The next position on the screen is odd. Its corresponding C byte is at the beginning of the second buffer. Both nibbles are packed in the third buffer. With short codes, the same scheme yields 80-byte row buffers. #### Access To The Codes In Memory KRL command transfers 12 bits from/to the R1 and R3 registers to/from memory. The read modify write operation, necessary to write the A nibble in memory, is automatically performed provided that the A 7929237 0059012 TT5 **#** 25/33 nibble is repeated in the R3 register (Figure 31). Dedicated auto-incrementation is also performed when required. KRS command does a similar job the short codes (Figure 32). A very simple scheme allows the microprocessor to transcode an horizontal screen location into a pointer (Figure 33). The joint use of this scheme with the dedicated command alleviates all the packing/unpacking troubles. Figure 30: 80 Char / Row Code Packing Figure 31: KRL Command: Sequential Access to Long Codes Figure 32: KRS Command Sequential Access to Short Codes Figure 33: Transcoding an Horizontal Screen Location into a R7 Pointer 26/33 896 7929237 0059013 931 ■ \_\_\_\_\_ # **Displaying The Attributes :** DOR REGISTER (see Figure 34) Short code character are not flashing, not underlined and "positive". The attributes are processed in the following order: - Underline or underlined cursor : foreground is forced on the last slice (SN = 9). - Flash: background is periodically (0.5Hz 50%) forced on all the window. The phase depends on the negative attribute. - Color select: a "positive" character is displayed with a background color same as the margin color. The foreground color is selected in DOR register by the D attribute. - Negative: when the character is negative, background and foreground colors are exchanged. In complemented CURSOR position, these colors are complemented. - Insert: The D attribute selects one insert value in DOR register. This attribute is then processed up to the current insertion mode (see screen format and attribute insert section). Figure 34 | D | N | Background<br>Color | Foreground<br>Color | i | |---|-----|---------------------|---------------------|----| | 0 | 0 | C <sub>M</sub> | CO | 10 | | 0 | . 1 | C0 | C <sub>M</sub> | iO | | 1 | 0 | C <sub>M</sub> | C0 | 11 | | 1 | 1 | CO | C <sub>M</sub> | 11 | The pixel shift frequency is f <sub>CLK</sub> (12 to 15MHz) 9347 39 EPS Figure 35: GOE Alphanumeric Character Set in 80 Character/Row Mode - TS9347 | | | | | C7 0<br>C6 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | |----|----|----|----|--------------|---|---|-------|---|---------|---|---|---|---|--| | | | | | C5 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | | | СЗ | C2 | C1 | C0 | C4 0 | 1 | 0 | 1 | 0 | 1 1 | 0 | 1 | 0 | 1 | | | 0 | 0 | 0 | 0 | | | | | | | | | | | | | 0 | 0 | 0 | 1 | | | | | | - COCCO | | | | | | | 0 | 0 | 1 | 0 | | Ë | | | | | | | | | | | 0 | 0 | 1 | 1 | | | | | | | | | | | | | 0 | 1 | 0 | 0 | | | | | | | | | | | | | 0 | 1 | 0 | 1 | | | | | | | | | | | | | 0 | 1 | 1 | 0 | | | | | | | | | | | | | 0 | 1 | 1 | 1 | | | | | | | | | | | | | 1 | 0 | 0 | 0 | | | | | | | | | | | | | 1 | 0 | 0 | 1 | | | | ann a | | | | | | | | | 1 | 0 | 1 | 0 | | | | | | | | | | | | | 1 | 0 | 1 | 1 | | | | | | | | | | | | | 1 | 1 | 0 | 0 | | | | | | | | | | | | | 1 | 1 | 0 | 1 | | | | | | | M | | | | | | 1 | 1 | 1 | 0 | | | | | | | | | | | | | 1 | 1 | 1 | 1 | | | | | | | | | | | | 28/33 **■** 7929237 0059015 704 ### MICROPROCESSOR ACCESS COMMANDS A microprocessor bus cycle may transfer one byte from/to the microprocessor to/from a directly addressable register. These registers provide an indirect access: - to/from 5 on-chip indirect registers : ROR, DOR, MAT, PAT and TGS. - to/from the dedicated memory. Due to address/data multiplexing, a bus cycle is a 2 phase process (see Timing diagram 1 or Timing diagram 2). #### **Address Phase** The falling edge of AS latches the AD (0.7) bus state and CS signal into the temporary A address register (Figure 36). - A(0:2) = i - This register index designates one out of 8 direct access registers R<sub>i</sub>. - A3 = XQR This is the execution request bit. - A (4:7) = ASN This is the Auto-Selection Nibble. - A8 = LCS This is the latched value of $\overline{\text{CS}}$ input pin. TS9347 is selected when the following condition is met : ASN = 2 (Hexa) and $\overline{LCS}$ = 0. Therefore, TS9347 is mapped in the hexadecimal microprocessor addressing space from XX20 to XX2F, where XX is up to the user. When TS9347 is not selected, its AD bus pins float and no register can be modified (see Figure 37) #### **Data Phase - Registers** When TS9347 is selected and while AS input is low, the $R_{\rm l}$ register is accessed. R0 designates a write-only COMMAND register or a read-only STATUS register. R1 to R7 hold the arguments of a command. They are read/write registers. R1, R2, R3 are used to transfer the data. R4, R5 hold the Auxiliary Pointer (AP). R6, R7 hold the Main pointer (MP). (See Figure 36). # **Command Register** This register holds a 4-bit command type and 4 bits of orthogonal parameters (see COMMAND TABLE). # Type There are 3 groups of command: - The IND command which gives access to on-chip resources, - The character code transfer commands, - The general purpose commands. ## **Parameters** R/W : Direction 1 : to DATA registers (R1, R2, R3) 0 : from DATA registers. r : Internal resource index (see Figure 38) : Auto-incrementation 1 : with post auto-incrementation 0 : without auto-incrementation. : Pointer select 1 : auxiliary pointer 0 : main pointer s, s : Source, destination select 01: source: MP; destination: AP 10: source: AP; destination: MP a, a : Stop condition 01: stop at end of buffer 10: no stop. 7929237 0059016 640 📟 - 29/33 Figure 37 Figure 38: Indirect on-chip Ressource Access ## STATUS REGISTER This is a read-only, direct access register. S7: BUSY BUSY is set at the beginning of any command execution. It is reset at completion. S6, S5, S4: $LX_m$ or $LX_a$ is set when respectively AI, $LX_m$ , $LX_a$ the main pointer or the auxiliary pointer holds X = 39 before a possible incrementation. The alarm bit S6 is set when $LX_m$ or $LX_a$ is set and an incrementation is performed after access. S2: Gives the vertical synchronization signal state, or the input port value. This is maskable by the VRM command. In this case, its values is S3 = S1 = S0 = 0 Not used. S3 to S6 are reset at the beginning of any command. The COMMAND TABLE shows every command able to set, each of these status bits, after completion. #### **Notes on Command Execution** - The execution of any command starts at the trailing edge of DS when (and only when): - TS9347 has been selected, - XQR has been set. at the previous AS falling edge. This scheme allows loading a command and its argument in any order. For instance, a command, once loaded, may be re-executed with new or partly new arguments. - At power on, the busy state is undeterminated. It is recommanded to load first a NOP command with XQR = 1 before any effective command. - While Busy is set, the current command is under execution. Register access is then restricted. Register access with XQR = 0 - Read STATUS is effective. - Write COMMAND or any other register access are ineffective. That is to say, the microprocessor reads undertermined values and may not modify a register. Register access with XQR = 1 - Read STATUS or write COMMAND are effective, - Access to other registers is ineffective. However, the previous command is aborted and the new command execution launched (with an initial state undetermined for registers and memory locations handled by the aborted command). 4. Execution suspension The execution of any command (except VRM, VSM) is suspended during the last and first scan line of an active row. This is because the memory bus cannot be allocated for microprocessor access during this 208 memory cycle period. This holds too for internal resource access because on-chip data transfer uses internal data memory bus. # IND Command (see Figure 38) This command transfers one byte between R1 and an internal resource. The r parameter designates on on-chip indirect register. Figure 39 A slice in 40C only can be read from the internal character generator. The slice address must be initialized in R6, R7. 30/33 **■** 7929237 0059017 587 **■** # Character Code Access: TLM, TLA, TSM, TSA,KRL, KRS Each of these commands is dedicated to transfer one complete character code between DATA registers and memory. TLM, TLA transfers 24 bits with Main/Auxiliary Pointer TSM, TSA transfers 16 bits with Main/Auxiliary Pointer KRL transfers 12 bits with Main Pointer KRS transfers 8 bits with Main Pointer Code packing, pointer and data structures are explained in the corresponding character code section When auto-incrementation is enabled, MP or AP is automatically updated after access so as to point to the next location. This location corresponds to the next right position on screen. When last position (X = 39) is accessed, LX<sub>m</sub> is set. When last position is accessed with auto-incrementation, alarm is also set. MP or AP is then pointing back at the beginning of the row : there is no automatic Y incrementation. # General Purpose Access to a Byte : TBM, TBA This command uses either MP or AP pointer. When MP is in use, an overflow yields to a Y incrementation. ## Move Buffer Commands: MVB, MVD, MVT These are memory to memory commands which use R1 as working register. MVB transfers a byte from source to destination, post-increments the 2 pointers and iterates until the stop condition is met. MVD and MVT are similar but work respectively with 2 byte word an 3 byte word. That is to say, MVB works on buffers, MVD on double buffers and MVT on triple buffers. If the parameter a = 1, the process stops when either source or destination buffer end is reached. If the parameter a = 0, the process never stops until aborted. In this case, main pointer overflow yields to a Y incrementation in MP. So, a whole block or page may be initialized. # Miscellaneous Command: INY, VRM and VSM INY command increments Y in MP. VRM and VSM respectively reset and set a vertical synchronization status mask. When the mask is set, status bit S2 remains at 0. When the mask is reset, status S2 follows the vertical sync. state: it is reset for 2 TV lines per frame and stays at 1 during the remaining period. It becomes readable by the microprocessor from the status register. After power on, the mask state is undetermined. ## **REGISTER - MAP** # Figure 40a 7929237 0059018 413 31/33 # Figure 40b #### **COMMAND TABLE** | Туре | Memo | Code | | | | Parameter | | | | Status | | | Arguments | | | | | | Execution Time (1) | | | |-----------------------------|------|------|---|---|---|-----------|---|---|---|--------|-----|-----|-----------|----|----|----|----|----|--------------------|----------------------|------| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Ai | LXm | LX. | R1 | R2 | R3 | R4 | R5 | R6 | R7 | Write | Read | | Indirect | IND | 1 | 0 | 0 | 0 | R/W | - | r | - | 0 | 0 | 0 | D | - | • | · | - | М | Р | 2 | 35 | | 40 Characters - 24 Bits | TLM | 0 | 0 | 0 | 0 | R/W | 0 | 0 | ı | х | X | 0 | С | В | Α | - | - | М | P | 4 | 75 | | 40 Characters - 24 Bits | TLA | 0 | 0 | 1 | 0 | R/W | 0 | 1 | ı | Х | 0 | х | С | В | Α | AP | | - | | 4 | 7.5 | | 40 Characters - 16 Bits | TSM | 0 | 1 | 1 | 0 | R/W | 0 | 0 | ī | х | Х | 0 | A* | B* | - | - | - | М | P | 3 | 5.5 | | 40 Characters - 16 Bits | TSA | 0 | 1 | 1 | 1 | R/W | 0 | 0 | 1 | х | 0 | X | A* | В* | - | AP | | ١. | | 3 | 5.5 | | 80 Characters - 8 Bits | KRS | 0 | 1 | 0 | 0 | R/W | 0 | 0 | ı | х | х | 0 | С | - | - | - | - | М | Р | 9 | 9.5 | | 80 Characters - 12 Blts | KRL | 0 | 1 | 0 | 1 | R/W | 0 | 0 | ı | х | Х | 0 | С | - | Α | - | - | м | P | 12.5 | 11.5 | | Byte | ТВМ | 0 | 0 | 1 | 1 | R/W | 0 | 0 | 1 | х | х | 0 | D | - | - | | | М | P | 4 | 4.5 | | Byte | TBA | 0 | 0 | 1 | 1 | R/W | 1 | 0 | ī | Х | 0 | Х | D | - | - | A | P | - | | 4 | 4.5 | | Move Buffer | MVB | 1 | 1 | 0 | 1 | s | 5 | a | а | 0 | 0 | 0 | w | - | | A | P | М | Р | (2) 2 + 4.n | - | | Move Double Buffer | MVD | 1 | 1 | 1 | 0 | s | s | ā | а | 0 | 0 | 0 | w | - | - | AP | | М | Р | (2) 2 + 8.n | - | | Move Triple Buffer | MVT | 1 | 1 | 1 | 1 | s | s | ā | а | 0 | 0 | 0 | w | - | - | AP | | М | Р | (2) 2 + 12.n | | | Clear Page (4)<br>- 24 Brts | CLL | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | х | Х | 0 | С | В | Α | - | - | М | P | < 4700<br>(1 K code) | | | Clear Page (4)<br>- 16 Bits | CLS | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | х | X | 0 | Α* | В* | - | - | • | М | Р | < 3500<br>(1 K code) | • | | Vertical Sync Mask Set | VSM | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | - | - | - | - | - | - | - | 1 | - | | Vertical Sync Mask<br>Reset | VRM | 1 | 0 | 0 | 1 | ٥ | 1 | 0 | 1 | x | X | 0 | - | - | - | - | - | - | - | 1 | - | | Increment Y | INY | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | - | - | - | | Υ | - | 2 | - | | No Operation | NOP | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | - | - | - | - | - | - | - | 1 | - | s, s : Source, Destination 01: Source = MP, Destination = AP 10 : Source = AP, Destination = MP a, a : Stop Condition 01: Stop at End of Buffer 10: No Stop . Indirect Register Number : Not Affected W : Used as Working Register : Set or Reset Buffer : Pointer incrementation D : Data MP: Main Pointer AP: Auxiliary Pointe Unit: 12 clock periods (≈ 1µs) without possible suspension n . Total Number of Words ≤ 40 These commands repeat TLM or KRO with Y incrementation when X overflows. When the last position is reached in a row Y is incremented and the progress starts again on the next row theses command stop only They can also be used to initialize the page 80 char/row by writing character (3)pairs. 33/33