ADVANCE PRODUCT INFORMATION December 1986 # μPD72120 ## **Advanced Graphics Display Controller** **User's Manual** The information contained in this document is being issued in advance of the production cycle for the device. The parameters for the device may change before final production or NEC Electronics Inc., at its own discretion, may withdraw the device prior to production. The information in this document is subject to change without notice. NEC Electronics Inc. assumes no responsibility for any errors or omissions that may appear in this document. Devices sold by NEC Electronics Inc. are covered by the warranty and patent indemnification provisions appearing in NEC Electronics Inc. Terms and Conditions of Sale only. NEC Electronics Inc. makes no warranty, express, statutory, implied, or by description, regarding the information set forth herein or regarding the freedom of the described devices from patent infringement. NEC Electronics Inc. makes no warranty of merchantability or fitness for any purpose. NEC Electronics Inc. makes no commitment to update or to keep current the information contained in this document. No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Electronics Inc. | | | - | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---| | en en la Caracteria de Car<br>La caracteria de Caracteri | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | , | | | | | | | | | | | | | | | and the provided the section of the section of the section of the section of the section of the section of the<br>The section of the se | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ## Preliminary Product Information #### Table of Contents | 1.0 | verview | 1-1 | |------|-----------------------------------------------------|------| | | Features | 1-1 | | | Pin Configurations | 1-2 | | | Pin Configuration (Flat package) | 1-3 | | | Pin Configuration (PLCC package) | 1-4 | | | Block Diagram | 1-5 | | | Pin Functions | 1-6 | | | Clock Pins | 1-6 | | | System Bus Control Pins | 1-6 | | | Display Memory Control Pins | 1-8 | | | Video Timing Signal Related Pins | 1-9 | | * | Display Signal Related Pins | 1-9 | | | Power Supply and Ground Pins | 1-9 | | | Summary | 1-10 | | | | | | 2. F | unction Description | 2-1 | | 2.1 | Features | 2-1 | | | High Speed Graphics Drawing | 2-1 | | | Video Timing Signal Generation | 2-3 | | | Large Capacity Display Memory Control | 2-3 | | | CPU Interface | 2-3 | | 2.2 | Command/Parameter Exchange Between the CPU and AGDC | 2-5 | | 2.3 | Reset and Abort Operation | 2-9 | | | | | | 3. A | GDC Operation | 3-1 | | 3.1 | How to Use the Internal Register | 3-1 | | 3.2 | AGDC Control Registers | 3-3 | | | STATUS (Status) | 3-3 | | | BANK (Bank) | 3-5 | | | CTRL (Control) | 3-6 | | 3.3 | Display Related Registers | 3-7 | | | DISPLAY FLAGS (Display Flags) | 3–6 | | | DISPLAT PITCH (Display Pitch) | 3-14 | | | AC (Address Control) | 3-15 | | | DAD (Display Address) | 3-16 | | | WC (Word Count) | 3-1 | | | GCSRX (Graphics Cursor X Coordinate) | 3-18 | | | CRS (Cursor Out Select) | 3-1 | | CE (Cursor Display Enable) | 3-20 | |-----------------------------------------------|------| | GCSRYS (Graphics Cursor Y Coordinate Start) | 3-21 | | GCRSYE (Graphics Cursor Y Coordinate End) | 3-22 | | HS, HBP, HH, HD, HFP | 3-23 | | VS, VBP, L/F, VFP | 3-24 | | 3.4 Internal Register Table | | | | | | 4. Drawing Operations | 4-1 | | 4.1 Drawing Functions | 4-1 | | 4.2 Types of DRAW Commands | 4-1 | | Summary of Operation Flags | 4-4 | | 4.3 Detailed Description of DRAW Commands | 4-9 | | 4.3.1 Register Operation Commands | 4-9 | | 4.3.2 Graphics Drawing Commands | 4-10 | | 4.3.3 Paint Commands | 4-20 | | 4.3.4 COPY Commands | 4-25 | | 4.3.5 PUT/GET Commands | 4-30 | | 4.4 How to Use the Flag Bits | 4-32 | | 4.5 Painting Pattern Reference Examples | | | 4.6 Inter-plane Data Transfers | 4-46 | | 4.7 Drawing Related Registers | | | 4.8 Parameters Corresponding to DRAW Commands | | #### Section 1 #### Overview The uPD72120 Advanced Graphic Display Controller (ACDC) displays characters and graphics on a raster scan CRT according to commands and parameters received from a host processor or CPU. It has high speed graphic drawing capabilities, video timing signal generation, large capacity display memory control (including Video RAMs) and a versatile CPU interface. These are some of the features that allow the ACDC to control graphics drawing and display of bit mapped systems. #### Features - \* High speed graphics drawing functions - O Graphics drawing Dot, straight line, rectangle, circle, arc, sector, ellipse, ellipse arc and ellipse sector Maximum drawing speed: 500 ns/pixel (8 MHz, pixel mode) 500 ns/dot (8 MHz, plane mode) O Painting (High speed processing in word units) Non-arbitrary enclosed area painting (Fill): triangle, trapezoid and circle. Arbitrary enclosed area painting (Paint): boundary dot retrieval O Data transfers in display memory Multiplane transfers Data transformation $(90^{\circ}/180^{\circ}/270^{\circ})$ rotation and reversal) Transfer speed: 500 ns/word max. O Image Processing Slant, arbitrary angle rotation, 16/N enlargement, N/16 shrinkage (N any integer from 1 to 16) - O Position specification by X-Y coordinates - O Logic operations between planes - \* Video timing signal generation - O High speed processing by two system clocks: display (for video sync signal generator) and graphics drawing clocks - O External synchronization - \* Large capacity display memory control - O Display memory bus interface (24-bit address and 16-bit data bus for addressing up to 16 Mwords, 16 bits/word) - O Video RAM (VRAM) control - O Display memory bus arbitration - \* Host Processor (CPU) Interface - O System bus interface 20-bit address bus, 8 or 16 bit data bus - Ontroller Ontroller From system memory to display memory (PUT) From display memory to system memory (GET) - O High speed pipeline processing with preprocessor before drawing processor - OCPU memory or I/O mapping of internal registers and display memory efficient system interface - \* 8 MHz System Clock - \* CMOS Technology - \* Single +5 V Power Supply - \* 80-pin flat package (uPD72120G) or 84-pin PLCC (uPD72120L) #### Pin Configurations DMARQ: DMA Request DA23-16: Display Memory Address Bus DMAAK: DMA Acknowledge DAD15-0: Display Memory Data Bus INT: Interrupt Request DASTB: Display Memory Address Strobe READY: Ready DED: Display Memory Read RESET: Reset DWD: Display Memory Write CSIR: Internal Register HLDAK: Hold Acknowledge CSDM: Display Memory Chip Select DT/DISP: Data Transfer/Display Timing HLDRO: Hold Request RD: Read BLANK: Blanking Signal WR: Write HS/EXHS: Horizontrol Sync/ ASTB: Address Strobe External Horiz. Sync MA19-16: Main Address Bus VS/EXVS: Vertical Sync/External MAD15-0: Main Data Bus Verticl Sync NC: No connection GCSR: Graphics Cursor UBE: Upper Byte Enable SCLK: Sync Generator Clock CLK: Clock GWAIT: Graphics Wait DIBE: Display Memory Lower Byte Enable Byte Enable Display Memory Upper DUBE: Chip Select #### Pin Configuration (Plat) #### Pin Configuration (PLCC) #### AGDC BLOCK DIAGRAM ## Pin Functions ## Clock Pins | Terminal<br>Name | I/0 | Active<br> level | | |------------------|-----------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CLK | I I | - | Clock supplied to the circuits other than the the sync signal generator and display processor. The drawing processor and preprocessor speed depend on this clock frequency. | | SCLR | I<br> <br> <br> | <b>-</b> | Clock supplied to the sync signal generator and the display processor. This clock frequency is determined by the CRT timing requirements - i.e., horizontal sync frequency, the number of dots per line, etc. | ## System Bus Control Pins | Terminal<br>Name | I/O | Active<br>level | Function | | |------------------|-----|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | MAD15-0 | I/O | , 4 <del>-</del> 4. | I/O bus to the CPU consisting of multiplexed 16- bit address and a bidirectional data bus. | | | MA19-16 | I | - | Upper four address bits of the 20-bit address. | | | ASTB | I | E I | Latches the address on MA19-16 and MAD15-0 on the falling edge. | | | UBE | | L<br> | Together with MADO defines the data access format as shown below. UBE should be tied high when connected to an 8-bit CPU. MADO UBE Data Access Format 0 0 Even address word 0 1 Even address byte 1 0 Odd address byte 1 1 Odd address byte | | ## System Bus Control Pins (continued) | | <b>.</b> | <del></del> | | | |------------------|--------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Terminal<br>Name | I/O<br> | Active<br> level | | | | RO | I | | Performs a read of data from the AGDC by the host CPU. | | | WIR | I | L | Performs a write of data to the AGDC from the host CPU. | | | CSIR | I<br>I | 1 | Enables reading/writing of AGDC internal registers by the host CFU. The register is selected by the address input on MAD7-0. | | | CSDM | I<br>I | | Enables reading/writing of display memory through the AGDC by the host CPU. The display memory address is generated by the address input on MA19-16 and MAD15-0 and by the bank register. | | | READY | 0 | • | Activated by the data access request (RD/WR) for the AGDC. During the access, the signal is low. RESET will set the READY line high. | | | INT | 0 | H | Signals an interrupt from the AGDC. | | | DMARQ | 0<br> <br> | | Indicates a request for data transfer (PUT/GET) to an external DMA controller. DMARQ will be low after RESET. | | | DMAAK | l I | L | Acknowledgment of DMA request to the AGDC by the DMA controller. | | | RESET | l I | H<br> <br> | Initializes operation of the AGDC. The internal parameter register is not cleared by RESET (it is initialized by setting data). | | | | <del> </del> | <del> </del> | | | ## Display Memory Control Pins | <del></del> | <del>,</del> | | | | |------------------------------|--------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Terminal<br> Name | 1/0 | Active level | | | | DAD15-0 | 1/0 | - | I/O pins for display memory - 16-bit address multiplexed with data. | | | DA23-16 | 0 | <b>-</b> | Upper 8 bits of display memory address (the lower 16 bits of the 24-bit address are output on DAD15-0). | | | DASTB | 0 | l B | Indicates that a display memory address is present on the falling edge. | | | DUBE<br> DLBE<br> <br> <br> | 0<br> <br> <br> <br> <br> <br> | L<br> <br> <br> <br> | Defines the data format for accessing the display. RESET sets both pins low. DUBE DIBE Data access format AGDC 0 0 Word 16-bit CPU 0 0 Word 8/16-bit CPU 0 1 High (odd) byte 16-bit CPU 1 0 Low (even) byte 8-bit CPU 1 1 High (odd) byte | | | DRD | ,<br> 0<br> | L | Controls reading of the display memory by the AGDC. Set high by RESET. | | | <b>DW</b> R | O | L | Controls writing to the display memory by the AGDC. Set high by RESET. | | | HLDRQ | I | H | Requests control of the display memory bus by an external device to transfer display data | | | HLDAK<br> <br> <br> | 0 | | Indicates that the AGDC memory bus (DA23-16 and DAD15-0) is in the high impedance state so that an external device can have access to display memory bus. Set high by RESET. | | ## Video Timing Signal Related Pins | Terminal<br> Name | 1/0 | Active<br> level | · | |--------------------|-------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | VS/EXVS<br> <br> | I/O<br> <br> | H<br> <br> | When the AGDC operates as the master, VS is the vertical sync signal. When the AGDC operates as a slave, EXVS initializes the internal vertical sync signal on the rising edge. | | RS/EXRS | I/O<br> <br> <br> | H<br> <br> | When the AGDC operates as the master, HS is the horizontal sync signal output. When the AGDC operates as a slave, EXHS initializes the internal horizontal sync signal on the rising edge. | ## Display Signal Related Pins | Terminal<br> Name | 1/0 | Active level | | |--------------------|-----|--------------|------------------------------------------------------------------------------------------------------------------------------------------| | BLANK | . 0 | Ħ | Used to blank the display. | | DT/DISP | 0 | L | Set to DT in the DT mode (VRAMs used) and specifies the data transfer. In the cycle steal mode (VRAMs not used) indicates display cycle. | | GCSR | 0 | H | Specifies the display of the graphics cursor | | GWAIT | 0 | H | Graphics wait signal | ## Power Supply and Ground Pins | 1 1 | Terminal<br>Name | I/O<br> | Active<br>level | · · · · · · · · · · · · · · · · · · · | |-----|------------------|---------|-----------------|---------------------------------------| | 1 | $v_{DD}$ | - | - | +5 V power supply | | 1 | GND | - | - | Ground | #### Summary The AGDC is an LSI device that can be used to control a raster scan CRT connected to a personal computer, word processor, or various kinds of work stations. The AGDC not only generates the video timing signals needed by the CRT, but can draw various kinds of characters and graphics at high speed. The AGDC also has abundant functions required by many advanced system. The figure below shows the basic configuration of a system employing the AGDC. #### Section 2 #### **Functional Description** #### 2.1 Features High Speed Graphics Drawing O Graphics Drawing The AGDC has graphic drawing commands to draw dots, straight lines, rectangles, circles and arcs, all of which are indispensable for CAD/CAM, office automation, document processing and printing. In addition, the AGDC supports the drawing of sectors, ellipses, ellipse arcs and ellipse sectors as advanced graphic primitives. These high speed graphics are drawn at maximum rate of 500 ns/pixel (8 MHz clock) for a straigh line, l us/pixel for a curved line (arc, etc.). O Painting The AGDC can paint or fill in a triangle, rectangle, trapezoid or circle as well as any enclosed area. This powerful feature is useful not only for document processing but advanced three dimensional graphics as well. Since the tiling pattern for painting can be freely set in the display memory, the areas to be painted can be drawn with any of a wide assortment of colors. In the past, painting was performed by software on the host CPU which is time consuming. For this reason, painting was used in only limited applications. The ACDC can upgrade the performance for painting speed by as much as several hundred times compared to painting done by a host CPU. This enables painting to be applied more extensively through the use of the ACDC. O Transfer of Data in Display Memory (COPY) The 'COPY' commands refers to bit-block transfers (also known as bilblt). This commands transfer a rectangular area of any size and bit position to another similarly sized rectangle. The 'COPY' command performs powerful character drawing and window control functions. In the past, a character could be displayed only with a fixed size and at a set position (word boundary) on the screen. The word processing applications of today require more flexibility in the display of characters. As a result, it is necessary to display characters of different fonts, styles and sizes and to proportionally space characters. The 'COPY' function of the AGDC can satisfy all of these demands and at high speed - 500 ns/16 bits. Personal computers are making use of multiple windows on display screens. The 'COPY' command allows the user to easily specify the number, shape and size of multiple windows. Further, the 'COPY' command of the AGDC can perform various logical operations between source and destination planes. #### O Image Processing The AGDC is able to do more than just copy data. It can slant copy, arbitrary angle rotation copy, 16/n enlargement copy or n/16 shrink copy (n any integer from 1 to 16). These copies transfer data from a rectangular source area to a non-rectangular destination. The slant copy can be used for drawing italic characters. The arbitrary angle rotation copy is useful for document preparation because it can rotate characters, graphics, images, etc. The enlarge and shrink copies are effective for editing and patching documents. These AGDC commands relieve the host CFU of what was a software intensive function. The AGDC can quickly accomplish these image processing tasks and for a lower cost. #### O Position Specification by X-Y Coordinates The graphics drawing and copy parameters can be given as X-Y coordinates thereby relieving the host CPU of the address calculation requirements. #### O Hardware Clipping Clipping is used to draw either inside or outside a rectangular window defined by the user. For example, a command to draw a straight line from the outside to the inside of a window will only be seen inside (or outside) of the window when clipping is used. The AGDC implements clipping in hardware so that the user need only specify the coordinates of the rectangular window and the mode to indicate whether to clip inside or outside of the window. Inside drawing mode Outside drawing mode ( - - - Invisible line) #### Video Timing Signal Generation O High Speed Processing by Dual System Clocks Dual system clocks can be input to the AGDC - the drawing clock and the display clock. In a graphics system, the display rate depends on the resolution of the CRT; the clock frequency of the display controller depends on the display rate. In the past, only a single clock was used for the display controller. It was often necessary to limit the clock to 5 MHz even though the capacity of the display controller was 8 MHz. Therefore, the AGDC was designed to have the display clock independent of the drawing clock so that drawing can be performed at the highest possible speed. #### O External Sync Input In systems that incorporate a separate circuit to generate the video timing signals and use an AGDC only to draw graphics, or in systems that use multiple AGDCs to achieve higher performance, it is necessary to synchronize the AGDC with the external circuitry or the AGDC with other AGDCs. Therefore, the AGDC has external sync input capability to synchronize its operations with other AGDCs or with external circuitry. #### Large Capacity Display Memory Control - O Display Memory Bus Interface - With its 24-bit addressing and 16-bit data, 16 Mwords of 16 bits/word display memory can be configured with the AGDC. This means that up to 64 planes of 2048 x 2048 dots can be connected. - O Video RAM (VRAM) Control - VRAMs are dual-ported DRAMs with internal line buffer shift registers (i.e., uPD41264). The VRAMs provide a separate port for display data so that when drawing, memory access time is greatly reduced. As a result, most of the entire memory cycle can be used as the drawing cycle to improve system throughput. The AGDC supplies the signals needed to control VRAMs. - O Display Memory Bus Arbitration In a basic system, the display memory is accessed by the AGDC only. However, in a more advanced system, the display memory may be accessed by other processors. In other words, a local bus is established between the display memory and the AGDC or other processors. In this case, it is necessary for the AGDC to periodically provide refresh and display control and thus act as the local bus master. Other processors on the display memory bus (i.e., an image processor) are slaves and must request use of the bus from the AGDC. The AGDC controls the display memory bus and can grant the use of the bus to other processors. The AGDC incorporates display memory bus arbitration logic enabling higher performance systems to be constructed for a lower cost. #### CPU Interface - O System Memory Bus Interface - OFU Mapping of Internal Registers and Display Memory The AGDC system memory bus interface to the host CPU is independent of the display memory bus. The width of the address which the CPU can input to the AGDC is 20 bits and the data width is 8 or 16 bits. The 20-bit address is used when the display parameters, drawing parameters and commands are set and the CPU accesses the display memory directly. The internal AGDC registers and the display memory can be mapped in the CPU memory or I/O space. This allows the CPU to efficiently execute special drawing processing directly in the display memory. The mapping of AGDC registers in the CPU memory space provides for quick access of information to and from the AGDC. - O System Memory <--> Display Memory Data Transfer As described above, it is possible to map the display memory in the CPU memory space. It is also possible to execute PUT/GET commands to transfer the data between the system memory and the display memory at high speed through the use of an external DMA controller. PUT is the command to transfer data from the system memory to the display memory. GET is the command to transfer data from the display memory to the system memory. - O High Speed Pipeline Drawing Processing The parameters given by the CPU to the AGDC are greatly reduced by using X-Y coordinates. However, it is necessary for the AGDC to calculate physical memory addresses for the drawing processor. The process to convert the X-Y coordinates from the CPU into physical addresses is done by the drawing preprocessor. The drawing processor executes the actual drawing commands independent of the preprocessor. Therefore the drawing processor and preprocessor can operate concurrently. As shown in the figure below, the throughput of the system is improved by the use of the drawing preprocessor and the drawing processor in a pipeline. time #### 2.2 Command/Parameter Exchange Between the CPU and AGDC It is necessary for the CPU to set various parameters and commands to operate the drawing and display control functions of the AGDC. To set these parameters and commands, the CPU writes them directly to the AGDC internal registers. The internal registers of the AGDC can be classified into registers the CPU can read and write directly and registers in which reading or writing is prohibited. The registers which can be read and written are assigned unique addresses. They are mapped in the CPU memory or I/O space and referred to as the 'command/parameter table'. These registers are selected by the lower 8 bits (00H - FFH) of the address input on MADO - MADO to the AGDC when CSIR is low. The data to be read or written can be sent through the data bus in the same address cycle providing high speed command or parameter exchange. The AGDC incorporates a preprocessor for drawing preprocessing and a drawing processor for the actual drawing. The drawing preprocessor calculates the effective (physical) address from X-Y coordinates (logical address) given by the CPU and generates the parameters of the micro-level codes interpreted by the drawing processor. The drawing preprocessor decodes commands and performs the drawing preprocessing necessary to execute commands in the command/parameter table. It is not necessary to write all the parameters in the command/parameter table. Only the required parameters for the particular command need be written. Of the addresses 00H - FFH in the internal register space, 80H - FFH are not presently used. These are reserved for future use. The register addresses 00H-7FH can be grouped into four categories as shown in the following table. | Classification | Register Name | Address | CPU Access | |------------------|----------------------|------------------|------------------------| | (1) AGDC control | STATUS (Read) | 3CH - 3DH | Read - at any time | | | CTRL, BANK (Write) | 3CH - 3DH | Write - at any time | | (2) Display | DISPLAY FLAGS | 70H - 7FH | Read - inhibited | | related | DISPLAY PITCH | | Write at any time | | registers | DAD, WC, AC | | | | | GCSRX,GCSRYS,GCSRVE | | | | | CRS, CE | . ! | | | | HS, HBP, HH, HD, HFP | | | | | VS, VBP, L/F, VFP | | | | (3) Drawing | EADORG, dADORG | 00H - 1FH | Read at any time | | related | EAD1, dAD1 | 40H - 6FH | Write - 3 types of | | registers | EAD2, dAD2 | | handshaking selectable | | | PDISPS, PDISPD | • | A. status flag | | | PITCHS, PITCHD | | B. ready signal | | | PMAX,MOD1,MOD0 | | C. INT signal | | | PLANES | | | | | PINP, PINCNI | <b>,</b> | | | | STACK, SIMAX | | | | | CLIP | | 1 | | | XCLMIN, XCLMAX | | 1 | | | YCLMIN, YCLMAX | 1 | | | | MACH, MAGV | | | | | X,DX,XS,XE,XC,DH | La company | | | | Y,DY,YS,YE,YC,DV | ly the second of | | | | COMMAND | | | | (4) Data port | DMAPORT (during | 3EH - 3FH | | | | PUT/GET execution) | | | | | DX (during READ | 44H - 45H | | | | DP/READ COL | 1 | | | | execution) | - | • | Note: The DX register is used as the logical address (coordinate) setting register and at the same time as the data port during execution of the READ DP/READ COL command. The registers in the first classification - STATUS, CTRL and BANK - are assigned address 3CH - 3DH. The contents of the STATUS register can be read at any time. The CTRL and BANK registers can be written to by the CPU at any time. The registers in the second group - display related registers - are assigned addresses in the range 70H - 7FH. The contents of these registers cannot be read. Data can be written to these registers at any time. However, writing to these registers can disturb the CRT display. To prevent this, the display can be blanked while writing to these registers. First set the SD bit in the DISPLAY FLAGS register (address 70H-71H) to '1'. Second, write the data into the display related register group. Third, set the SD bit from '1' back to '0'. Follow these procedures to write data (SYNC parameters) such as HS, HBP, HH, HD, HFP, VS, VBP and L/F on the registers at address 7EH - 7FH: - 1. Set the SYNC bit in the DISPLAY FLAGS register (70H 71H) to '1' - 2. Write, in the order listed, HS, HBP, HH, HD, HFP, VS, VBP, L/F AND VFP (address 7EH 7FH). - 3. Set the SYNC bit to '0' The registers in the drawing related group are assigned addresses from 00H to 1FH and 40H to 6FH. The preprocessor resides in this register group. The read/write option of these registers are: #### - Read The CPU can read the contents of these registers at any time. The preprocessor stops for one clock while the contents of a register are read. #### - Write One of three writing procedures can be used: - 1. Check the STATUS register PPBSY flag (address 3CH) - 2. Use the READY signal - 3. Use the INT pin to signal an interrupt to the CPU The method described by (1) is the general method. The contents of the status flag are read to check that the preprocessor is not in operation. If the preprocessor is not busy, then data can be written to the command/parameter table. In the method described by (2), the CPU is tied to the AGDC's READY line. If the preprocessor is busy, the CPU cannot write the data until the preprocessor is finished and the READY line goes high. This procedure enables the command/parameter data to be sent at a higher speed. In the method described by (3), the CPU is interrupted by the AGDC when the preprocessor is available. The AGDC, through its INT line, informs the CPU to send command/parameter data. The CPU interrupt routine should send a command and parameters to the AGDC. The 'INT' line is enabled or disabled by a flag in the CTRL register (address 3DH). The three write methods are illustrated below. Procedure (C) .. Handshake by the INT signal Main routine The data port register, DMAFORT, is at address 3EH - 3FH. The drawing processor uses this register during execution of the drawing preprocessing. Therefore, to read/write this register, follow the method for reading or writing the drawing preprocessor. #### 2.3 Reset and Abort Operation The AGDC resets or aborts processing by any of the following procedures: - Reset Operation - 1. Set the RESET input signal (pin 5) to a high level (hardware reset) - 2. Set the RESET flag in the CRTL register to 'l' (software reset). - Abort Operation - 3. Set the ABORT flag in the CTRL register to 'l'. | Reset/Abort Operation | Operation | |-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Hardware Reset<br> <br> | - sets the display stop flag SD in the DISPLAY FLAGS register (70H - 71H) to '1' - sets all bits in the CTRL register (3DH) to '0' - all other registers maintain the same status - stops the preprocessor and the drawing processor - initializes the video timing signals - stops the image memory direct access | | (2) Software Reset | - same as the hardware reset but does not set the display stop flag in the DISPLAY FLAGS register (70H - 71H) to '1' and does not initialize the video timing signals | | (3) Abort | - all registers maintain their status<br>- stops the preprocessor and drawing processor | Section 3 ## AGDC Operation ## 3.1 How to Use the Internal Registers The internal registers of the AGDC are classified as shown in the table below: | Classification | Application | Register Name | Address (Hex) | |---------------------------------------|----------------------|------------------------|---------------| | AGDC control | Status | STATUS | <b>3</b> C | | r <b>e</b> gisters | Control | CIRL | 3D | | | Higher 8 bits of | BANK | <b>3</b> C | | | address in display | 1 | | | | memory direct access | | | | Display related | Display status | DISPLAY FLAGS | 70 - 71 | | registers | setting | | | | - | Display area | DISPLAY PITCH, | 72 - 77 | | | setting | DAD, WC | | | | Cursor setting | CRS, CE, GCSRX, | 78 - 7D | | • | | GCSRYS, GCSRVE | | | | Horizontal sync | HS, HBP, HH, | 7E - 7F | | • | signal setting | HD, HFP | | | | Vertical sync | VS, VBP, L/F, | 7E - 7F | | · · · · · · · · · · · · · · · · · · · | signal setting | VFP | | | Drawing related | Logical address | EADORG, dADORG | 00 - 03 | | registers | zero point setting | | <b>l</b> . | | · | Logical address | PITCHS, PITCHD | 58 - 5B | | | setting | | | | | Plane setting | PMAX, PDISPS, PDISPD | 0C - 15 | | | Inter-plane logical | MODO, MODI, | 16, 5E - 5F | | | operation setting | PLANES | | | | Clipping setting | CLIP, XCLMIN, | 6D, 62 - 69 | | | 1 | XCLMAX, YCLMIN, YCLMAX | • | | | Enlarge/Shrink | MAGH, MAGV | 1 6C | | | coefficient setting | • | | | s (Bex) | |--------------| | 1,60-63 | | | | | | E,5C-5I | | 08-02 | | | | | | , <b>0</b> B | | | | | | - 55 | | | | - 57 | | | | - 6F | | <del></del> | | - 3F | | | | - 1 | | - 45 | | - 45 | | | <sup>\*:</sup> The DX register is used as the logical address (X coordinate) value setting register and at the same time as the data port during the execution of a READ DP/READ COL command. #### 3.2 AGDC Control Registers #### STATUS (Status) No. of bits: 16 Address: 3CH - 3DH (Read) Application: The status of the internal operation of the AGDC. The format is as follows: | - | | 7 | • | . • | • | • | 2 | _ | • | | |----|-----|-------|-------|-------|------|-------|-------|-------|-------|---| | 10 | LIP | PGBSY | ODDFD | I VSB | l VS | DPERR | PPERR | DPBSY | PPBSY | 1 | | | | I | 1 | |-----|--------------------------|---------|----------------------------------------------------------------------------------| | Bit | Flag Name | Abbrev. | AGDC status when flag is 'l' | | 0 | PRE-PROCESSOR BUSY | PPBSY | The preprocessor is executing a command | | 1 | DRAWING PROCESSOR BUSY | DPBSY | The drawing processor is executing a command | | 2 | PRE-PROCESSOR ERROR | PPERR | An error was detected during the execution of the command by the preprocessor | | 3 | DRAWING PROCESSOR ERROR | DPERR | An error was detected during the execution of a command by the drawing processor | | 4 | VERTICAL SYNC PERIOD | i vs | Indicates vertical sync period | | 5 | VERTICAL BLANKING PERIOD | VSB | Indicates vertical blanking<br> period | | 6 | ODD FIELD | ODDFD | Indicates odd field during<br> interlaced scanning | | | | | | ## Status (continued) | | 1 | | <u> </u> | |------------------|--------------|--------------|---------------------------------------------------------------------------| | Bit | Flag Name | Abbrev. | AGDC status when flag is 'l' | | 7 | PUT/GET BUSY | PGBSY<br> | Indicates that data can be<br> transferred during a PUT/GET<br> command | | 8 | CLIPPING | CITA | Picking or object detected | | 9 <b>-</b><br>15 | | | Reserved for future use | | | <del>{</del> | <del> </del> | <del> </del> | #### BANK (Bank) No. of bits: Address: 3CH (Write) Application: The CPU interface on the AGDC accompdates 20-bit addresses. The AGDC can address 32 Mbytes of display memory (24 bits). When the CPU addresses display memory directly, the lower 16 bits provided by the CPU (bits 0 - 15) is combined with the upper 8 bits (bits 16-23) of the BANK register to form the 24-bit display memory address. ## CIRL (Control) No. of bits: Address: 3 3DH (Write) Application: | MSB | 7 | 6 | 5 | 4 | 3 | . 2 | 1 | . 0 | LSB | | |-----|--------------------------------------------------------------------------------------------------------------------------------|----------|-----|---------|------------------------|-----------------------------------|--------------------------------------------------|-------------------|----------|--| | | DBIE | PBIE | CIE | 0 | 0 | 1 0 | ABORT | RESET | +<br> | | | | | | | | | | | | <b>+</b> | | | Bit | F | lag Name | | Abbrev. | i ax | DC stati | us when f | l <b>a</b> g is ' | 1' | | | 0 | SOFTWAR | e reset | | RESET | Ini | tializes | AGDC* | | | | | 1 | PROCESSOR ABORT NOT USED | | | ABORT | per | pe any p<br>formed au<br>cessor b | the | | | | | 2 | NOT USE | D | | | | | - | | | | | 3 | NOT USED | | | | Mus | t be set | to '0' | | | | | 4 | NOT USE | D | | | 1 | | | | | | | 5 | CLIPPIN<br>ENABLE | G INTERR | UPT | CIE | pic | | s the INT signal when<br>g (drawing in the clipp | | | | | 6 | PRE-PROCESSOR BUSY PBIE Enables the INT signal INT pin. INT output INT pin. INT output | | | | when | | | | | | | 7 | DRAWING PROCESSOR BUSY DBIE Enables the INT of INTERRUPT ENABLE INT pin to be out drawing processor from BUSY to NOT | | | | be output<br>cessor st | tput when the r status changes | | | | | <sup>\*:</sup> Please refer to section 2.3, 'Reset and Abort Operation' #### 3.3 Display Related Register #### DISPLAY FLACS (Display Flags) No. of bits: 16 Address: 70H - 71H (Write) Application: To select the operation of the display processor and the video timing signal generator. Bit 0: VS (Vertical Sync) The AGDC incorporates a horizontal/vertical counter to keep track of the current position of the display by the scanning line number counted from the top of the screen or by the word number counted from the left side. When the AGDC is used in the slave mode, the VS defines the timing of the horizontal/ vertical counter by the external sync signal, EXVS. When the AGDC is used in the master mode, the VS is ignored. | 1 | vs | 1 | | | Funct | ior | n | | | | | | | | | | |---|----|-------|-----|-------|--------|-----|---------|-------|----|-----|-----|-----|-----|--------|----|------| | 1 | 0 | T<br> | The | total | number | of | display | lines | in | the | lst | and | 2nd | fields | is | even | | - | 1 | 1 | The | total | number | of | display | lines | in | the | lst | and | 2nd | fields | is | ∞dd | #### DISPLAY FLAGS (continued) #### Bit 1: SYNC (Sync Parameter Setting) This bit permits the writing of data in the registers (HS, HBP, HH, HFP, VS, VBP, LF and VFP) assigned to the address 7EH - 7FH. | SYN | Function | | |-----|-------------------------|--| | 1 0 | No writing is permitted | | | 1 | Writing is permitted | | #### Bit 2: LEO (Display Lines per Frame in Interlace Mode) This bit defines the total number of display lines per frame (the first and second fields) in the interlace mode (IN = 1 in DISPLAY FLAGS). For non-interlace mode (IN = 0), LEO is ignored. | 1 | 1 | Œ | | | | Funct | io | 1 | | | | | | | | | | |---|---|---|---|-----|-------|--------|----|---------|-------|----|-----|-----|-----|-----|--------|----|-------------| | 1 | | 0 | 1 | The | total | number | of | display | lines | in | the | lst | and | 2nd | fields | is | even | | 1 | | 1 | 1 | The | total | number | of | display | lines | in | the | lst | and | 2nd | fields | is | <b>od</b> d | #### Bit 3: SD (Stop Display) This bit defines the output status of the BLANK pin. This bit is set to 'l' when the RESET pin is high. | SD | Function | |----|------------------------------------------------------------------------------------------------| | | The BLANK pin is activated between the non-display period defined by the sync signal generator | | 1 | The BLANK output pin is activated in all the period | #### DISPLAY FLAGS (continued) #### Bit 4: M/S (Master/Slave) This bit defines the master/slave mode of the AGDC | | MS | 1 | | Function | |--------|----|---|-------------|-----------------------------------| | | 0 | 1 | The AGDC is | set to master mode (HSYNC, VSYNC) | | ı<br>I | 1 | 1 | The AGDC is | set to slave mode (EXHS, EXVS) | #### Bit 5: MASK (Mask) This bit defines the VSYNC output pin timing in the master mode (MS = 0 in DISPLAY FLAGS). It also defines the validity/invalidity of the EXHS and EXVS input pins in the slave mode (MS = 1 in DISPLAY FLAGS). | M | s I | MASK | FUNCTION | |---|-----|------|------------------------------------------------------------------------------------------------------------| | 0 | 1 | 0 | Only the VSYNC signal in the first field is output in the interlace display mode (IN = 1 in DISPLAY FLAGS) | | | 1 | 1 | The usual VSYNC signal is output | | , | | 0 | The EXHS and EXVS external sync input signals are valid | | 1 | i | 1 | The EXHS and EXVS external sysnc input signals are invalid | #### DISPLAY FLAGS (continued) #### Bit 6: TCCL (Timing Counter Clear) The AGDC display the data by using two cycles of D1 and D2 as one unit. Therefore, the AGDC incorporates the display cycle counter to recognize the D1 cycle and the D2 cycle during display. This bit defines the initializing timing of the display cycle counter by the EXVS external sync input signal. In the master mode (MS = 0 in DISPLAY FLAGS), TCCL is ignored. | 7 | ICCL | Function | |---|------|-------------------------------------------------------------------------------------------| | | | The display cycle counter is not initialized (to the Dl cycle) on the rising edge of EXVS | | | 1 | The display cycle counter is initialized (to the Dl cycle) on the rising edge of EXVS | #### Bit 7: FCCL (Field Counter Clear) The AGDC incorporates the field counter to recognize the first field and the second field in the interlace display mode. This bit defines the initializing timing of this field counter by the EXVS external sync input signal. In the master mode (MS = 0 in DISPLAY FLAGS) or in the non-interlaced display mode (IN = 0 in DISPLAY FLAGS), FCCL is ignored. | FCCL | Function | |------|--------------------------------------------------------------------------------------| | 0 | The field counter is not initialized (to the first field) on the rising edge of EXVS | | 1 | The field counter is initialized (to the first field) on the rising edge of EXVS | #### DISPLAY FLAGS (continued) Bit 8: SC (Steal Count) This bit defines the relationship between CLK and SCLK in the dual port DRAM (VRAM) drive mode (SE/DT = lx in DISPLAY FLAGS). In the cycle steal mode (SE/DT = 0x in DISPLAY FLAGS), SC is ignored. | 1 | sc | Function | | |---|----|--------------------------------------|---| | 1 | 0 | This bit is set to 0 when CLK = SCLK | 1 | | 1 | 1 | This bit is set to 1 when CLK = SCLK | | #### Bit 9: RE (Refresh Enable) This bit defines the DRAM refresh address output. | | sc sc | Function | + | |--|-------|-------------------------------------------------------|---| | | 0 | The DRAM refresh address is output when HSYNC is high | 1 | | | 1 | The DRAM refresh address is not output | T | #### Bit 10: IN (Interlace) This bit sets the display screen mode. | +- | IN | | | |----|-----|----------------------------------------|---| | 1 | 0 | The non-interlaced display mode is set | | | 1 | 1 . | The interlaced display mode is set | 1 | ## DISPLAY FLAGS (continued) Bits 11 - 13: DAD+ (Display Address Proceedings) These bits define the progressive form of display addressing. | DAD+ | | Progressive form | |------|---------|----------------------------------------------------------| | 000 | DAD+1 | DAD -> DAD+1 -> DAD+2 -> DAD+3 -> DAD+4 -> DAD+5 -> | | 001 | DAD+2 | DAD -> DAD+2 -> DAD+4 -> DAD+6 -> DAD+8 -> DAD+10 -> | | 010 | DAD+4 | DAD -> DAD+4 -> DAD+8 -> DAD+12 -> DAD+16 -> DAD+20 -> | | 011 | DAD+8 | DAD -> DAD+8 -> DAD+16 -> DAD+24 -> DAD+32 -> DAD+40 -> | | 100 | DAD+16 | DAD -> DAD+16 -> DAD+32 -> DAD+48 -> DAD+64 -> DAD+80 -> | | 101 | DAD+32 | DAD -> DAD+32 -> DAD+64 -> DAD+96 -> DAD+128 -> | | 110 | DAD+1/4 | DAD -> DAD -> DAD -> DAD -> DAD+1 -> | | 111 | DAD+1/2 | DAD -> DAD -> DAD+1 -> DAD+1 -> DAD+2 -> | #### DISPLAY FLAGS (continued) ## Bits 14-15: SE/DT (Steal Enable/Data Transfer Mode) These bits indicate whether VRAMs or DRAMs are used for the display memory. When DRAMs are used, drawing is accomplished by memory cycle stealing. When VRAMS are used, the timing mode of the data transfer signal DT is defined. | SE/DT | Function | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | The cycle steal mode (the DISP signal indicating the display period output) is used | | 1 | The DT signal is generated at the timing which satisfies at least one of the following three conditions: 1. At the start of the display on the screen 2. At the start of the display of each scan line on the screen 3. When all the lower 8 bits of the 24 bits of display address are 0 | | 11 | The DT signal is generated at the timing which satisfies at least one of the following two conditions: 1. At the start of the display on the screen 2. When all the lower 8 bits of the 24 bits of the display address are 0 | # DISPLAY PITCH (Display pitch) No. of bits: 12 72H - 73H (Write) Address: Application: Sets the number of addresses in the horizontal direction of the image memory plane. | <del> -</del><br> | DISPI | AY P | TCH | No. of addresses | | | |-------------------|-------|------|-------------|------------------|--|--| | +=<br> | 0000 | 0000 | 0000 | 0 | | | | I | 0000 | 0000 | 0001 | 1 | | | | ı | 0000 | 0000 | 0010 | 2 | | | | ı | | • | | | | | | l | | • | | | | | | | | • | | • | | | | | 1111 | 1111 | 1101 | 4093 | | | | I | 1111 | 1111 | 1110 | 4094 | | | | ı | 1111 | 1111 | 1111 | 4095 | | | | - | | | <del></del> | <del> </del> | | | #### AC (Address Control) No. of bits: 3 Address: 73H (Write) Application: These bits define the output of the 9 bit refresh address to the display address lines DA23 - DA16 and DAD15 - DAD0. The table below shows the change in the lower 8 bits of the display address which is used to set the output timing signal DT in the VRAM drive mode (SE/DT = 11 in DISPLAY FLAGS) according to the AC value. | AC | | The condition to activate the DT signal in the dual port DRAM drive mode | |-----|--------------|----------------------------------------------------------------------------| | 000 | DAD8 - DADO | When DAD7 - DAD0 are 0 | | 001 | <b>-</b> | prohibited | | 010 | - | prohibited | | 011 | <b>-</b> | prohibited | | 100 | DAD9 - DAD1 | When DAD8 - DAD1 are 0 | | 101 | DAD10 - DAD2 | When DAD9 - DAD2 are 0 | | 110 | DAD11 - DAD3 | When DAD10 - DAD3 are 0 | | 111 | DAD12 - DAD4 | When DAD11 - DAD4 are 0 | # DAD (Display Address) No. of bits: 24 Address: 74H - 76H (Write) Application: These bits set the display starting physical address in the memory. WC (Word Count) No. of bits: Address: 77H (Write) Application: These bits set the number of address in the display period for one scanning period. | 1 | WC | No. of address | ses | |------|-----------|----------------|-----| | <br> | 0000 0000 | 1 | | | i | 0000 0001 | 2 | 1 | | I | 0000 0010 | 3 | 1 | | 1 | • | • | 1 | | l | • | • | . 1 | | 1 | • | • | 1 | | 1 | 1111 1101 | 254 | 1 | | 1 | 1111 1110 | 255 | ı | | 1 | 1111 1111 | 256 | ı | # GCSEX (Graphics Cursor X Coordinate) No. of bits: 12 Address: 78H - 79H (Write) Application: These bits set the starting display address of the graphics cursor using the upper left corner of the screen as the origin. The graphics cursor display signal generation period in the horizontal direction is fixed to one display cycle period. | <b>GCSRX</b> | GCSR generation position/1 scan line | | | |----------------|--------------------------------------|--|--| | 0000 0000 0000 | Not defined | | | | 0000 0000 0001 | l lst display cycle | | | | • | La experience of the second second | | | | • . | <b>1</b> | | | | | | | | | 1111 1111 1110 | 4094th display cycle | | | | 1111 1111 1111 | 4095th display cycle | | | # CRS (Cursor Out Select) No. of bits: 1 Address: 79H (Write) Application: This bit selects the logical OR or the logical AND of the horizontal coincidence signal with the vertical coincidence signal to be output at the GCSR pin. | • | CRS | • | + | |---|-----|----------------|--------------| | - | | AND and output | 1 | | - | 1 | OR and output | <b>▼</b> + | # CB (Cursor Display Enable) No. of bits: 1 Address: 79H (Write) Application: Enables the graphics cursor output signal (GCSR) | + - | Œ | Function | + | |-----|---|-------------|---| | 1 | 0 | Not enabled | 1 | | 1 | 1 | enabled | 1 | # GCSRTS (Graphics Cursor Y Coordinate Start) No. of bits: 12 Address: 7AH - 7BH (Write) Application: These bits set the Y coordinate of the graphics cursor display start on the screen using the upper left corner of the screen as the origin. | GCSRYS | GCSR generation position/1 scan line | |------------------|--------------------------------------| | 1 0000 0000 0000 | Not defined | | 1 0000 0000 0001 | lst display cycle | | 1 | • | | | • | | | • | | 1111 1111 1110 | 4094th display cycle | | 11111 1111 1111 | 4095th display cycle | ## GCRETE (Graphics Cursor Y Coordinate End) No. of bits: 12 Address: 7CH - 7DH (Write) Application: These bits set the Y coordinate of the graphics cursor display end on the screen using the upper left corner as the origin. | GCSRYE | GCSR generation position/1 scan lin | | | | |----------------|-------------------------------------|--|--|--| | 0000 0000 0000 | Not defined | | | | | 0000 0000 0001 | lst display cycle | | | | | • | <b>!</b> | | | | | • | • | | | | | • | • | | | | | 1111 1111 1110 | 4094th display cycle | | | | | 1111 1111 1111 | 4095th display cycle | | | | ### < Graphics Cursor Output Form > When the value of GCSRYS < GCSRYE is not set, the graphics cursor output from the display line indicated by GCSRYS to the last display line is activated. When GCSRYS = GCSRYE, only one display line indicated by GCSRYS is displayed. #### BS, HEP, HE, HD, HPP HS (Horizontal Sync Signal) HRP (Horizontal Back Porch; non-displayed period on the left of the CRT screen) HH (Period from the HBP end to the center of one horizontal period) HD (Horizontal display period) HFP (Horizontal front porch; non-displayed period on the right of the CRT screen) No. of bits: 12 each Address: 7EH - 7FH (Write) Application: These registers set the horizontal video timing parameters. | HS, HBP, HH, HD, 1 | TP No. of display cycles | |--------------------|----------------------------| | 0000 0000 0000 | 1 | | 0000 0000 0001 | 2 | | 0000 0000 0010 | 1 3 | | • | • | | • | • | | | . 1 | | 1111 1111 1101 | 4094 | | 1111 1111 1110 | 1 4095 | | 1111 1111 1111 | j 4096 | ## VS, VEP, L/F, VFP VS (Vertical Sync signal) VBP (Vertical Back Porch; non-displayed period on the upper part of the CRT screen) L/F (Display period in the vertical direction) VFP (Vertical Front Porch; non-displayed period on the lower part of the CRT screen) No. of bits: 12 each Address: 7EH - 7FH Application: These registers set the vertical video timing parameters. | VS, VBP, L/F, VFP | No. of display cycles | |-------------------|-----------------------| | 0000 0000 0000 | 1 | | 0000 0000 0001 | 2 | | 0000 0000 0010 | 3 | | 100 | • | | 1 | • 1 | | • 1 | • | | 1111 1111 1101 | 4094 | | 1111 1111 1110 | 4095 | | 1111 1111 1111 | 4096 | # 3.4 Internal Register Table 20H - 3BH : AGDC working registers # Internal Register Table (continued) | MSB | | | | | * | | LSB | | | |-------------|--------|-------|----------|----------|-------------|------|-----|-------------|--------| | - | | | x - | | | | | <b>40</b> H | RV | | - | | | <u> </u> | | | | | <b>42</b> H | RV | | - | | | ox | | | | | 44H | RV | | | | | DY | | | | | 46H | RV | | - | | | xs | | | | | 48H | RV | | | | _1 _1 | YS | | | | | 4AH | RV | | | | | XE | | | | | 4CH | RV | | | | | YE | | <del></del> | | | 4EH | RV | | - | | | xc | | | | | 50H | RV | | <del></del> | | | | | | | | <b>52</b> H | RV | | | | | — DH | <u> </u> | | | | 54H | RV | | | | | DV | <u> </u> | | | | 56H | RV | | | | | | | | | | 58H | RV | | | | | - PITCH | | | | | | | | | | | - PITCHI | | | | | 5AH | RV | | | | | - STHUX | | 1 1 | | | 5CH | RV | | | | | - PLANE | | | | | 5EH | RV | | | | | - PTN_CX | | | | | <b>60</b> H | RV | | | | | - XCMII | 1 | _11_ | | | <b>62</b> H | RV | | - | | | - YCUIII | <u> </u> | | | | 64H | RV | | - | | | - XCLHA | <u> </u> | | | | <b>66</b> H | RW | | | | | - YCHW | ( | , , | 1 1 | | <b>68</b> H | RV | | | | | | | | | | 001 | n Part | | 0 0 0 | 0 6 | لمل | CLIP + | - MAGH | 71 | MA( | × 📑 | 6СН | RV | | | | | - Flacs | | 1 1 | | | <b>6</b> EH | R | | | COMMAN | ) - | | | FLACS ( | L) — | | нза | V | 6AH - 6BH : AGDC working registers # Internal Register Table (continued) | MSB LSB | | |---------------------------------------------------------|---------| | DISPLAY FLAGS | 70H V | | 0 - AC - - DISPLAY PITCH | 72H V | | DAD (H.L) | 74H V | | → VC → DAD (N) → | 76H V | | CRS CE 0 0 GCSRX | 78H V | | 0 0 0 0 GCSRYS | 7AH W | | 0, 0, 0, 0 GCSRYE, ———————————————————————————————————— | 7CH W | | 0, 0, 0, 0 + HS - HS | 7eh v | | 0, 0, 0, 0 + HBP | 7EH V | | 0,0,0,0 | 7EH V | | 0,0,0,0 | 7eh y | | 0, 0, 0, 0 HFP | 7EH V | | 0, 0, 0, 0 | 7eh v | | 0 0 0 0 VBP | 7EH W | | 0, 0, 0, 0 | . 7EH V | | 0, 0, 0, 0 VFP | 7EH V | RW : Read/Write W : Write only R : Read only H: Higher 8 bits of 24-bit word M: Middle 8 bits of 24-bit word L: Lower 8 bits of 24-bit word 80H - FFH : Reserved #### Section 4 #### Drawing Operations #### 4.1 Drawing Functions The AGDC is an LSI device that can perform graphics drawing and copying at high speed. The host system specifies the drawing parameters and commands by writing to specific internal AGDC registers. Only the parameters that are needed to perform the drawing command are written. When the DRAW command is written, the AGDC starts the drawing process. This section describes the variations of the DRAW command and the parameters required for each command. #### 4.2 Types of DRAW Commands The DRAW command is set in the COMMAND register at address 6EH - 6FH. The type of drawing is selected according to the operation code written to 6FH. Various combinations are selected by the flags set in the register at 6EH. The DRAW commands can roughly be classified as follows: - 1. Data read command - 2. Graphics drawing commands - Dot drawing - Straight line drawing - Curve drawing - 3. Paint commands - Non-arbitrary area paint - Arbitrary area paint - 4. Copy commands - Simple copy - 90° rotation copy - Arbitrary angle rotation copy - Enlarge/Shrink copy - 5. PUT/GET commands - PUT - ŒT - 900 rotation GET # List of DRAW commands: | | | Absolute<br> Coordinate system | Relative Coordinate system | |-----------------------|-----------------------------|---------------------------------|----------------------------| | Data read<br>commands | Coordinate value | READ DP | | | | Color information<br> read | READ COL | | | Graphics | Dot | DOT D | | | Drawing commands | 1 | A DOT M | RDOTM | | Commences | Straight Line | A LINE MO | R LINE MO | | | 1 | A LINE MI | R LINE M1 | | | 1 | A LINE M2 | R LINE M2 | | | 1 | A LINE DO | R LINE DO | | | 1 | A LINE D1 | R LINE D1 | | | 1 | A LINE D2 | R LINE D2 | | | | A LINE D3 | | | | Rectangle | A REC | R REC | | | Circle | CRL | | | | Arc | ARC | | | | Sector | SEC | | | | Circle Bow | CBOW | | | | Ellipse | ELPS | | | | Ellipse arc | EARC | 1 | | | Ellipse sector | I ESEC | 1 | | | Ellipse bow | EBOW | | | Paint Commands | Triangular area | A TRI FILL | | | | Rectangular area | A REC FILL | R REC FILL | | | Trapezoidal area | A TRA FILL | R TRA FILL | | | Circular area | CRL FILL | I see that the second | | | Elliptic | ELPS FILL | | | | Arbitrary | PAINT | | | | enclosed area | | | List of DRAW commands (continued): | | 1 | · | Relative<br>Coordinate system | |---------------------|-----------------------------------------|--------------|-------------------------------| | Copy Commands | Physical address-<br> physical address | A COPY AA | | | | Logical address-<br> phsical address | A COPY CA | <br> | | | Physical address-<br> logical address | A COPY AC | <b>i</b><br>! | | | Logical address-<br> logical address | I A COPY CC | <br> | | PUT/GET<br>Commands | | PUT<br> GET | <br> | #### Summary of Operation Flags: - (1). Data read commands there is no variation in these operation flags - (2). Graphics drawing commands the operation flags are shown in the figures below: - Dot drawing commands | | | | | | | | | œ | ere co | and | | | | | |---|----------------|----|---|---|---|---|---|------|--------|------|-------|---|---|----------| | | Operation Code | 11 | 0 | ı | 0 | 1 | 0 | PXEN | 1 | BPPX | <br>0 | 1 | 0 | <b>→</b> | | 7 | <b>6F</b> H | | | 1 | | | | | 6E | 3 | | - | | | PXEN: Pixel mode specification BPPX: No. of bits in one pixel - Straight line drawing commands ES: Enlarge/shrink or original size IP: Specification of initialization of the type of line to be drawn ED: Specification of thickening direction of line width in enlarge drawing PXEN: Pixel mode specification BPPX: Specification of the number of bits in one pixel ESH: Enlarge or shrink specification (kind of line to be drawn) # - Curve drawing commands Œ: Clockwise or counterclockwise drawing IP: Specification of initialization of type of line to be drawn PXEN: Pixel mode specification BPPX: Specification of the number of bits in one pixel ### (3). Paint Commands - the operation flags are shown in the figures below: - Non-arbitrary area paint commands IL: Paint by tiling specification SS: Color of monochromatic tiling specification WL: Left boundary dot paint specification WR: Right boundary dot paint specification #### - Arbitrary area paint commands IL: Paint by tiling specification SS: Color or monochromatic specification PMOD: Boundary color specification ## (4). Copy Commands - the operation flags are shown in following figures: #### - General 00: 90° rotation copy 01: slant copy 10: arbitrary angle rotation copy ll: enlarge/shrink $\infty$ py Copy plane specification SD SEL: # - Simple copy commands ESE: Source data reverse read specification REV: Reverse specification ROT: Rotation: 0 = no rotation; $1 = 180^{\circ}$ rotation ## - 900 Rotation Copy Commands ESE: Source data reverse read specification REV: Reverse specification ROT: Rotation: $0 = 90^{\circ}$ rotation; $1 = 270^{\circ}$ rotation #### - Slant Copy Commands | | • | | | Com | mand | | | | | |---|----------------|-----|-----------|-----|---------|-------------|---|-----|--------------| | 1 | Operation Code | ESE | REV ROT | 0 1 | SD SELL | 1 | 0 | 1 0 | <del>-</del> | | T | <b>6</b> FH | 1 | | 61 | CH CH | <del></del> | | 4 | | ESE: Source data reverse read specification REV: Reverse specification ROT: Rotation: 0 = no rotation; $1 = 180^{\circ}$ rotation ### - Arbitrary Angle Rotation Enlarge/Shrink Copy Commands ES: Enlarge/shrink or original size specification SF: Specification of a point not to be drawn ESH: Enlarge/shrink specification in horizontal direction ESV: Enlarge/shrink specification in vertical direction #### - Enlarge/Shrink Copy Commands ESH: Enlarge/shrink specification in the horizontal direction REV: Reversal specification ROT: Rotation specification: 0 = no rotation; $1 = 180^{\circ}$ rotation ESV: Enlarge/shrink specification in the vertical direction ## (5). PUT/GET Commands - the operation flags are shown in the following figures: #### - PUT REV: Reversal specification ROT: Rotation: 0 = no rotation; 1 = 1800 rotation SD SEL: Copy plane specification #### - ŒT REV: Reversal specification ROT: Rotation: 0 = no rotation; $1 = 180^{\circ}$ rotation SD SEL: Copy plane specification #### - 900 Rotation GET REV: Reversal specification ROT: Rotation: $0 = 90^{\circ}$ rotation; $1 = 270^{\circ}$ rotation SD SEL: Copy plane specification #### 4.3 <u>Detailed Description of DRAW Commands</u> ## 4.3.1 Register Operation Commands #### (1) READ DP (Read Drawing Pointer) By this command, the drawing pointer $(X^{\sharp}, Y^{\sharp})$ held in the AGDC is read in the register (X, Y) #### (2) READ COL (Read Color) By this command, the color information regarding the display memory location indicated by (X, Y) is read in the register #### 4.3.2 Graphics Drawing Commands #### (1) DOT D (Dot Direct) PMEN: Pixel mode specification BPPX: Number of bits in one pixel One dot is drawn at the drawing pointer (X‡, Y‡) held in the AGDC. In this case, it is not necessary to set (X, Y) again. #### (2) A DOT M (Absolute Dot with Move) PXEN: Pixel mode specification BPPX: Number of bits in one pixel One dot is drawn at the coordinate indicated by (X, Y). The drawing pointer (X‡, Y‡) is converted into (X, Y). The dot which is enlarged by any magnification can be drawn by giving the horizontal magnification 'MAGH' and the vertical magnification 'MAGV'. #### (3) R DOT M (Relative Dot with Move) PXEN: Pixel mode specification BPPX: Number of bits in one pixel One dot is drawn at the coordinate point (X+DX, Y+DY) generated by (X, Y) and (DX, DY). The drawing pointer $(X\ddagger, Y\ddagger)$ changes to (X+DX, Y+DY). ### (4) A LINE MO, A LINE M1, A LINE M2 (Absolute Line with Move 0, 1 or 2) ES: Original size or enlargement specification IP: Initialization of the type of line to draw ED: Specification of thickening direction of line width in enlarge drawing PXEN: Pixel mode specification BPPX: Number of bits in one pixel ESH: Specification of the thickness of a line to draw A straight line is drawn from (X, Y) as the drawing start coordinates to the coordinates indicated by (XE, YE). However, the coordinates (XE, YE) are not drawn. The drawing pointer (X\*, Y\*) changes to (XE, YE). A straight line can be enlarged/shrunk in the drawing direction and enlarged in thickness by giving the horizontal magnification 'MAGH', the vertical magnification 'MAGV' and the thickening parameters. The differences among these three commands are as follows: A LINE MO: (X, Y) changes to (XE, YE) A LINE M1: Both (X, Y) and (XS, YS) do not change A LINE M2: (XS, YS) changes to (X, Y) and (X, Y) changes to (XE, YE) #### (5) A LINE DO, A LINE D1, A LINE D2, A LINE D3 (Absolute Line Direct 0 - 3) ES: Original size or enlargement specification IP: Initialization of the type of line to draw ED: Specification of thickening direction of line width in enlarge drawing PXEN: Pixel mode specification BPPX: Number of bits in one pixel ESH: Specification of the thickness of the line to draw A straight line is drawn from (X, Y) as the drawing start coordinates to the coordinates indicated by (XE, YE). However, the coordinates (XE, YE) are not drawn. The drawing pointer $(X^{\frac{1}{2}}, Y^{\frac{1}{2}})$ changes to (XE, YE). It is not necessary to set (X, Y) again. A straight line can be enlarged/shrunk in the drawing direction and enlarged in thickness by giving the horizontal magnification 'MAGH', the vertical magnification 'MAGV' and the thickening parameters. The differences among these four commands are as follows: A LINE DO: (X, Y) changes to (XE, YE) A LINE D1: Both (X, Y) and (XS, YS) do not change A LINE D2: (XS, YS) changes to (X, Y) and (X, Y) changes to (XE, YE) A LINE D3: The command is executed after changing (XE, YE) to (XS, YS). It is not necessary to set (XE, YE) again. #### (6) R LINE MO, R LINE M1, R LINE M2 (Relative Line with Move 0 - 2) ES: Original size or enlargement specification IP: Initialization of the type of line to draw ED: Specification of thickening direction of line width in enlarge drawing PXEN: Pixel mode specification BPPX: Number of bits in one pixel ESH: Specification of the thickness of the line to draw A straight line is drawn from (X, Y) as the drawing start point to the coordinates (X+DX, Y+DY) generated by (DX, DY). However, the coordinates (X+DX, Y+DY) are not drawn. The drawing pointer $(X^{\ddagger}, Y^{\ddagger})$ changes to (X+DX, Y+DY). A straight line can be enlarged/shrunk in the drawing direction and enlarged in thickness by giving the horizontal magnification 'MAGH', the vertical magnification 'MAGV' and the thickening parameters. The differences among these three commands are as follows: R LINE MO: (X, Y) changes to (X+DX, Y+DY) R LINE M1: Both (X, Y) and (XS, YS) do not change R LINE M2: (XS, YS) changes to (X, Y) and (X, Y) changes to (X+DX, Y+DY) #### (7) R LINE DO, R LINE D1, R LINE D2 (Relative Line Direct 0 - 2) ES: Original size or enlargement specification IP: Initialization of the type of line to draw ED: Specification of thickening direction of line width in enlarge drawing PXEN: Pixel mode specification BPPX: Number of bits in one pixel ESH: Specification of the thickness of the line to draw A straight line is drawn from (X, Y) as the drawing start point to the coordinate (X+DX, Y+DY). The point (X+DX, Y+DY) is not drawn. The drawing pointer $(X^{\frac{1}{2}}, Y^{\frac{1}{2}})$ changes to (X+DX, Y+DY). It is not necessary to set (X, Y) again. A straight line can be enlarged/shrunk in the drawing direction and enlarged in thickness by giving the horizontal magnification 'MAGH', the vertical magnification 'MAGV' and the thickening parameters. The differences among these three commands are as follows: R LINE MO: (X, Y) changes to (X+DX, Y+DY) R LINE M1: Both (X, Y) and (XS, YS) do not change R LINE M2: (XS, YS) changes to (X, Y) and (X, Y) changes to (X+DX, Y+DY) #### (8) A REC (Absolute Rectangle) | MSB | 6FH | бен | LSB | |------|------------------------|----------------------------------------|-------------| | ++ | <del> -</del> | <del></del> | ++ | | 1011 | 10101110 | 0 0 ES IP 0 PXEN <bppx></bppx> | ESH 1 | | ++ | <del></del> | <del></del> | <del></del> | ES: Original size or enlargement specification IP: Initialization of the type of line to draw PXEN: Pixel mode specification BPPX: Number of bits in one pixel ESH: Specification of the thickness of the line to draw A rectangle defined by (X, Y) as the drawing start coordinates and the diagonal coordinates (XS, YS) is drawn. A straight line enlarge/shrink in the drawing direction (by so doing, (XS, YS) does not change but the diagonal coordinates change) and enlarged in thickness can be drawn by giving the horizontal magnification 'MAGH' and the vertical magnification 'MAGC'. #### (9) R REC (Relative Rectangle) ES: Original size or enlargement specification IP: Initialization of the type of line to draw PXEN: Pixel mode specification BPPX: Number of bits in one pixel ESH: Specification of the thickness of the line to draw A rectangle defined by (X, Y) as the drawing start coordinates and the diagonal coordinates (X+DX, Y+DY) generated by (DX, DY) is drawn. A rectangle enlarge/shrink in the drawing direction (by so doing, (X+DX, Y+DY) does not change, but the diagonal coordinates change) and enlarged in the thickness direction can be drawn by giving the horizontal magnification 'MAGH' and the vertical magnification 'MAGV'. #### (10) CRL (Circle) | MSB | 6FH | <b>6EH</b> | LSB | |------------|-------------|-------------------------------|-------------| | + | <del></del> | <del> </del> | <del></del> | | 10 1 0 | 11101010 | 0 CP IP 0 PXEN CBPPX> | 0 1 0 1 | | ++ | <del></del> | <del> -</del> | | CF: Clockwise or counterclockwise drawing specification IP: Initialization of the type of line to draw PXEN: Pixel mode specification BPPX: Number of bits in one pixel A circle defined by the center coordinates (XC, YC) and the radius (DX) is drawn. ## (11) ARC (Circle Arc) | MSB | 6FH | | 6EH | LSB | |-----------------|---------------|------------------|-----------------------|-------------| | 10111 | 0 1 0 1 | 10 0 CF II | P 0 PXEN (BPPX> 0 | 101 | | <del> </del> | <del></del> | <del></del> | <del></del> | <del></del> | CF: Clockwise or counterclockwise drawing specification IP: Initialization of the type of line to draw PXEN: Pixel mode specification BPPX: Number of bits in one pixel A circle arc defined by the center coordinates (XC, YC), the radius (DX), the drawing start coordinates (XS, YS) and the drawing end coordinates (XE, YE) is drawn. #### (12) CSEC (Circle Sector) | MSB | 6FH | | 6EH | LSB | |------|-------------|---------------|--------------------|-------------| | + | | + | | <del></del> | | 1011 | 1011110 | 101010 | IP 0 PXEN CBPPX> 0 | 101 | | + | <del></del> | <del> </del> | | <del></del> | CF: Clockwise or counterclockwise drawing specification IP: Initialization of the type of line to draw PXEN: Pixel mode specification BPPX: Number of bits in one pixel A sector defined by the center coordinates (XC, YC), the radius (DX), the circle arc drawing start coordinates (XC, YC) and the circle arc drawing end coordinates (XE, YE) is drawn. #### (13) CBOW (Circle Bow) CF: Clockwise or counterclockwise drawing specification IP: Initialization of the type of line to draw PXEN: Pixel mode specification BPPX: Number of bits in one pixel A circle bow defined by the center coordinates (XC, YC), the radius (DX), the circle arc drawing start coordinates (XC, YC) and the circle arc drawing end coordinates (XE, YE) is drawn. #### (14) ELPS (Ellipse) | MSB | 6FH | | <b>6EH</b> | LSB | |-------|-------------|----------------|----------------------------------------|-----| | + | | <del> </del> | <del></del> | -+ | | 10111 | 0 1 1 | 111010 | CF IP O PXEN <bppx> O </bppx> | 0 1 | | ++ | <del></del> | <del> </del> | <del></del> | | CF: Clockwise or counterclockwise drawing specification IP: Initialization of the type of line to draw PXEN: Pixel mode specification BPPX: Number of bits in one pixel An ellipse defined by the center coordinates (XC, YC), the radius in the X axis direction (DX), the radius in the Y axis direction (DY), the square ration of the radius in the X axis and the square ratio of the radius in the Y axis direction is drawn (DH: $DV = DX^2: DY^2$ ). #### (15) EARC (Ellipse Arc) CF: Clockwise or counterclockwise drawing specification IP: Initialization of the kind of line to draw PXEN: Pixel mode specification BPPX: Number of bits in one pixel An ellipse arc defined by the center coordinates (XC, YC), the radius in the X direction (DX), the radius in the Y direction (DY), the square ratio of the radius in the X axis (DH), the square ratio of the radius in the Y axis direction (DY), the drawing start coordinates (XS, YS) and the drawing end coordinates (XE, YE) is drawn (DH: DV = $DX^2$ : $DY^2$ ). #### (16) ESEC (Ellipse Sector) | MSB | 6FH | | 6EH | LSB | |--------|-------------|-------------------|--------------------|---------------| | + | <del></del> | <del></del> | | ++ | | 10 1 | 1 0 0 | 1 0 0 0 1 | IP 0 PXEN CEPPX> 0 | 101 | | ++ | <del></del> | | <del></del> | <del></del> + | CF: Clockwise or counterclockwise drawing specification IP: Initialization of the kind of line to draw PXEN: Pixel mode specification BPPX: Number of bits in one pixel An ellipse sector defined by the center coordinates (XC, YC), the radius in the X axis direction (DX), the radius in the Y axis direction (DY), the square of the radius in the X axis direction (DH), the square of the radius in the Y axis direction (DV), the ellipse arc drawing start coordinates (XS, YS) and the ellipse arc drawing coordinates (XE, YE) is drawn (DH: $DV = DX^2 : DY^2$ ). #### (17) EBOW (Ellipse Bow) CF: Clockwise or counterclockwise drawing specification IP: Initialization of the kind of line to draw PXEN: Pixel mode specification BPPX: Number of bits in one pixel An ellipse bow defined by the center coordinates (XC, YC), the radius in the X direction (DX), the radius in the Y direction (DY), the square ratio of the radius in the X axis (DH), the square ratio of the radius in the Y axis direction (DY), the ellipse arc start coordinates (XS, YS) and the ellipse arc end coordinates (XE, YE) is drawn (DH: DV = $DX^2$ : $DY^2$ ). #### 4.3.3 Paint Commands #### (1) PAINT (Arbitrary Paint within Enclosed Pattern) | MSB | 6FH | <b>6E</b> H | LSB | |------------|------------------|----------------------------------|-----| | + | <del></del> | | ++ | | 10 1 1 | 101110101 | 0 TL 0 1 SS PMOD 0 0 | 101 | | + | <del>- -</del> | - <del></del> | ++ | TL: Specification of painting by tiling SS: Color or monochromatic tiling specification PMOD: Boundary color specification An enclosed area between the boundary points is painted starting from the coordinates (X, Y). The boundary color is specified by DX (the DX specification is not required for painting with the color different from the boundary color). #### (2) A REC FILL (Absolute Rectangle Fill) TL: Specification of painting by tiling SS: Color or monochromatic tiling specification WL: Specification of whether to paint on left edge WR: Specification of whether to paint on right edge FAST: Specification of normal or fast fill speed A rectangle defined by the screen upper left coordinates (X, Y) as the drawing start coordinates and the screen lower right coordinates (XS, YS) as the diagonal coordinates is painted. # (3) R REC FILL (Relative Rectangle Fill) | MSB | | 6FH | | 6EH LSB | |-----|-------------|---------------|----------------|-------------------| | + | <del></del> | <del></del> | <del></del> | <del> </del> | | 11 | 10101 | 1 0 0 0 | 0 TL 0 1 | SS WL WR FAST 0 | | + | <del></del> | | <del></del> | <del> </del> | TL: Specification of painting by tiling SS: Color or monochromatic tiling specification WL: Specification of whether to paint on left edge WR: Specification of whether to paint on right edge FAST: Specification of normal or fast fill speed A rectangle defined by the screen upper left coordinates (X, Y) as the drawing start coordinates and the screen lower right coordinates generated by (DX, DY) as the diagonal coordinates (X+DX, Y+DY) is painted. #### (4) CRL FILL (Circle Fill) TL: Specification of painting by tiling SS: Color or monochromatic tiling specification WL: Specification of whether to paint on left edge WR: Specification of whether to paint on right edge A circle defined by the center coordinates (XC, YC) and the radius (DX) is painted. # (5) ELPS FILL (Ellipse Fill) | MSB | 6FH | <b>6EH</b> | LSB | |--------|---------------|----------------------------|-------------| | + | | <del></del> | <del></del> | | 101110 | 1 1 1 0 | 0 TL 0 1 SS WL WR | 0 0 | | + | <del></del> | <del></del> | <del></del> | TL: Specification of painting by tiling SS: Color or monochromatic tiling specification WL: Specification of whether to paint on left edge WR: Specification of whether to paint on right edge An ellipse defined by the center coordinates (XC, YC), the radius in the X axis direction (DX), the radius in the Y axis direction (DY), the square ratio of the radius in the X axis direction (DH) and the square ratio of the radius in the Y axis direction (DV) is painted (DH: $DV = DX^2 : DY^2$ ). # (6) A TRI FILL (Absolute Triangle Fill) | MSB | 6FH | 6EH LS | В | |------------|-----------------------------|-------------------------|---| | ++ | | <del> </del> | + | | 10 1 1 | 0 1 1 0 0 111 0 | 1 1 SS WL WR 0 0 | I | | +++ | <del></del> | <del> </del> | + | TL: Specification of painting by tiling SS: Color or monochromatic tiling specification WL: Specification of whether to paint on left edge WR: Specification of whether to paint on right edge A triangle defined by the three coordinates (X, Y), (XS, YS) and (XC, YC) is painted. #### (7) A TRA FILL (Absolute Trapezoid Fill) | MSB | 6FH | 6eh | LSB | |------------|--------------------------------|------------------|-------------| | + | | | <del></del> | | 10 1 1 | 1 0 0 0 0 11 0 1 | SS WL WR 0 | 0 1 | | + | <del></del> | <del></del> | | TL: Specification of painting by tiling SS: Color or monochromatic tiling specification WL: Specification of whether to paint on left edge WR: Specification of whether to paint on right edge A trapezoid defined by 6 kinds of parameters showing four coordinates (X, Y), (XS, Y), (XC, YE) and (XE, YE) is painted. # (8) R TRA FILL (Relative Trapezoid Fill) | MSB | | 6FH | | | | 6EH | LSB | |------|-----|-------|------|--------|------|--------|-----------| | 1011 | 11. | 1 0 | 1110 | 0 1 11 | 1011 | SS WL | WR 0 0 | TL: Specification of painting by tiling SS: Color or monochromatic tiling specification WL: Specification of whether to paint on left edge WR: Specification of whether to paint on right edge A trapezoid defined by the screen upper left coordinates (X, Y), the screen upper right coordinates (XS, Y), the height (DY), the distance from the screen lower left point to the X axis (DX) and the distance from the screen lower right point to XS (XC) is painted. #### 4.3.4 COPY Commands #### (1) A COPY AA (Absolute Copy Address to Address) #### SD SEL: Transfer plane specfication The data in a rectangular area defined by the address (EAD2) of the transfer start word of the display memory, the address (dAD2) of the transfer start dot in the word, the number of the dots in the horizontal direction 'DH' and the number of the dots in the vertical direction 'DV' is transferred to a rectangular area defined by the address (EAD1) of other transfer start word, the address 'dAD1' of the transfer start dot in the word, 'DH' and 'DV'. # (2) A COPY CA (Absolute Copy Coordinate to Address) SD SEL: Transfer plane specfication The data in a rectangular area defined by the transfer start coordinates (XS, YS) on the display memory, the number of dots in the horizontal direction 'DH' and the number of dots in the vertical direction 'DV' is transferred to another rectangular area defined by the address 'EAD1' of the transfer start word, the address 'dAD1' of the transfer start dot in the word, 'DH' and 'DV'. # (3) A COPY AC (Absolute Copy Address to Coordinates) # SD SEL: Transfer plane specfication The data in a rectangular area defined by the transfer start coordinates (XS, YS) in the display memory, the number of dots in the horizontal direction 'DH' and the number of dots in the vertical direction 'DV' is transferred to a rectangular area defined by the other transfer start coordinates (X, Y), 'DH' and 'DV'. # (4) A COPY CC (Absolute Copy Coordinate to Coordinate) SD SEL: Transfer plane specfication The data in a rectangular area defined by the transfer start coordinates (XS, YS) in the display memory, the number of dots in the horizontal direction 'DH' and the number of dots in the vertical direction 'DV' is transferred to a rectangular area defined by the other transfer start coordinates (X, Y), 'DH' and 'DV'. # (5) R COPY CC (Relative Copy Coordinate to Coordinate) #### SD SEL: Transfer plane specfication The data in a rectangular area defined by the transfer start coordinates (XS, YS) in the display memory, the number of dots in the horizontal direction 'DH' and the number of dots in the vertical direction 'DV' is transferred to a rectangular area defined by the other start coordinates (XS+XC, YS+YC) generated by (XS, YS), (XC, YC), and 'DH' and 'DV'. #### (6) Copy function extensions The function of each COPY command can be extended by changing the lower 2 bits of the command code. This extension is defined in the lower byte (6EH) of the command register. # (a) 900 COPY (900 Rotation Copy) ESE: Reverse data read specification REV: Reversal specification ROT: Rotation angle specification SD SEL: Transfer plane specification The transfer area is rotated by 90°. #### (b) SL COPY (Slant Copy) ESE: Reverse data read specification REV: Reversal specification ROT: Rotation angle specification SD SEL: Transfer plane specification The data in a rectangular area in the display memory is slanted by 'DX' in the X axis direction according to the change in the Y axis direction to transfer it into a parallogram area. # (c) ES COPY (Enlarge/Shrink Copy) ESH: Enlarge/shrink specification (horizontal direction) REV: Reversal specification ROT: Rotation angle specification ESV: Enlarge/shrink specification (vertical direction) SD SEL: Transfer plane specfication The transfer area is enlarged/shrunk by any magnification by giving the horizontal magnification 'MAGH' and the vertical magnification 'MAGV' factors. # (d) FR ES COPY (Free Angle Rotation Enlarge and Shrink Copy) | MSB | | | ľ | 1 | | | | | | | |-----|-----|----|----|---|---------|----|----|---|--|--| | ESE | ESV | FS | 11 | 1 | SD SEIL | 11 | 10 | Ì | | | ESH: Enlarge/shrink specification in horizontal direction ESV: Enlarge/shrink specification in wertical direction SF: Specification of point not to be drawn SD SEL: Transfer plane specification The transfer area is rotated by any angle are enlarged/shrunk by giving the horizontal magnification 'MAGH', the vertical magnification 'MAGV', and the angle defined by DX and DY. # 4.3.5 PUT/GET Commands # (1) PUT A (Put Data to Address Field) REV: Reversal Specification ROT: Rotation Specification SD SEL: Transfer plane specfication The data from the host system is transferred to a rectangular area defined by the address 'EAD1' of the transfer start word in the display memory, the address 'dAD1' of the transfer start dot in the word, the number of dots in the horizontal direction 'DH' and the number of dots in the vertical direction 'DV'. ## (2) PUT C (Put Data to Coordinate Field) REV: Reversal Specification ROT: Rotation Specification SD SEL: Transfer plane specfication The data from the host system is transferred to a rectangular area defined by the transfer start coordinates (X, Y) of the display memory, the number of dots in the horizontal directions 'DH' and the number of dots in the vertical direction 'DV'. # (3) GET A (Get Data from Address Field) | MSB | 6FH | 6EH | LSB | |-----|-----|----------------------------------------------------|-----| | | | - - - - - - - - - - | | | - | | <del> - - - - - - - - - -</del> | • | REV: Reversal Specification ROT: Rotation Specification SD SEL: Transfer plane specfication The data from the host system is transferred to a rectangular area defined by the address 'EAD1' of the transfer start word in the display memory, the address 'dAD1' of the transfer start dot in the word, the number of dots in the horizontal direction 'DH' and the number of dots in the vertical direction 'DV'. #### (4) GET C (Get Data from Coordinate Field) REV: Reversal Specification ROT: Rotation Specification SD SEL: Transfer plane specfication The data from the display memory is transferred to the host system from a rectangular area defined by the transfer start coordinates (X, Y) of the display memory, the number of dots in the horizontal directions 'DH' and the number of dots in the vertical direction 'DV'. #### 4.4 How to Use the Flag Bits (1) PXEN: Pixel Drawing Enable (2) BPPX: Bits per Pixel Sixteen pixels are assigned to one 16-bit word in the display memory controlled by the AGDC principally to construct the plane configuration. The number of bits per pixel can easily be extended by increasing the number of planes in the display memory. In the packed configuration, in which each pixel is assigned to one word, straight lines, rectangles, circles, circle arcs, circle bows, arc sectors, ellipses, ellipse arcs, ellipse bows and ellipse arc sectors can still be drawn. The plane or the pixel configuration is selected by PXEN and the number of bits in one pixel is defined by BPPX. | | BPPX | | PXEN | N bits/pixel | |-------|------|----------|------|--------------| | 1 | XX | 1 | 0 | 1 | | 1 | 00 | 1 | 1 | 1 2 | | 1 | 01 | ı | 1 | 4 | | 1 | 10 | 1 | 1 | 8 | | 1 | 11 | 1 | 1 | 1 16 | | ·<br> | | <u>.</u> | | · | (3) ES: Enlarge/Shrink (4) ESH: Enlarge/Shrink Horizontal (5) ESV: Enlarge/Shrink Vertical Whether or not the enlarge/shrink function by any magnification (16/N or N/16, N an integer between 1 and 16) is enabled is determined by ES. The enlarge/shrink in the horizontal direction is selected by ESH. The enlarge/shrink in the vertical direction is selected by ESV. The horizontal magnification and the vertical magnification are set by the MAGH and MAGV registers, respectively. | + - + | ES | + | ESH | | ESV | 1 | Function | -<br> | |-------|----|---|-----|-----|-----|---|--------------------|---------| | 1 | 0 | 1 | X | 1 | X | 1 | No enlarge/shrink | - ,<br> | | ı | 1 | 1 | 0 | I | X | ı | Horizontal shrink | ı | | 1 | 1 | 1 | 1 | į | X | 1 | Horizontal enlarge | 1 | | 1 | 1 | 1 | X | į | 0 | 1 | Vertical shrink | I | | 1 | 1 | Ì | X | I | 1 | İ | Vertical enlarge | İ | | + | | + | | -+- | | + | | + | | • | <br> <br> | 1 | | · · · · · · | 4 | 1 | ES | SH = | 0 | | 1 | | • | 1 | | | |---------------|-----------|-----|-----|-------------|-----|----|----|------|----|-----|-----|-----|-----|-----|-----|-----| | • | | | * | 13 | | | | | | | | | - | | | - | | Magnification | 11 | 1_2 | 1_3 | _4<br> 16 | 1.5 | 16 | 17 | 1_8 | 19 | 110 | 111 | 112 | 113 | 114 | 115 | 116 | | | | | | | | | ES | H = | 1 | | | | | | | | |------------------------|----|-----|-----|-----|-----|-----|------------------|-----|-----|-----|-----|-----|-----|-----|-----|----| | MAGH | 15 | - | = | • | - | - | 19 | • | • | - | - | - | - | | | 10 | | <br> Magnification<br> | | 116 | 116 | 116 | 116 | 116 | <u>16</u><br> 10 | 116 | 116 | 116 | 116 | 116 | 116 | 116 | 116 | | When enlarging straight lines or rectangles, the enlarge/shrink magnification of 16/N or N/16 of the line pattern is defined by MAGH. The integral magnification of the line width is defined by MAGV. # (6) ED: Enlargement Direction ED selects the widening direction of a straight line drawing, as shown in the following table: SP Quadrant Definition XF Quadrant Definition # (7) IP: Initial Pattern Pointer This bit selects the initialization/non-initialization of the pointer which specifies the drawing of a specific bit in the register storing the type of line (dotted, alternate long and short dashed, etc). In the case of drawing a folded line graph, etc., an alternate long and short dashed line is still drawn after passing the end point if this pointer is not initialized. | + | IP | Function | |---|----|----------------------------------------| | | 0 | The pattern pointer is not initialized | | T | 1 | The pattern pointer is initialized | # (8) CF: Clockwise Flag This bit selects the drawing direction of a circle, ellipse, etc. | CF | Drawing direction | |-----|-------------------| | 101 | Counterclockwise | | 111 | Clockwise | - (9) TL: Tiling Pattern - (10) SS: Single Source Pattern This bit selects the pattern in painting. The following three selections are possible: | | | en e | |-----|--------------|------------------------------------------------------------------------------------------| | IL | l ss | Selection | | 0 | 1 0 | Not used | | ) O | 1 | The same pattern set in the 'PTNCNT' register referred to for all the planes | | 1 | 0<br> | The pattern stored in the display memory is read each time for each plane referred to it | | 1 | 1<br> | The same pattern stored in the display memory is referred to for all the planes | | | <del> </del> | | To clear all the planes to '0', set TL = 0 and SS = 1, then it is not necessary to frequently read the pattern to be painted. This will allow the planes to be cleared quicker. When it is necessary to paint with a different color for each bit, set TL = 1 and SS = 0. # (11) PMOD: Paint Mode This bit selects one of the two types of arbitrary enclosed areas shown in the following table: | PMOD | Type of area | |------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | The boundary color is retrieved according to the type of boundary color preliminarily given and the space between the boundary points is painted | | | The color information at the start point of the boundary point retrieval. The boundary point is retrieved for all the colors other than the color of the boundary and the space between the boundary points is painted | (12) WL: Write Left (13) WR: Write Right These bits specify the drawing of points on the boundary line in a quadrangle, circle, ellipse, triangle and trapezoid fill. | Function | |--------------------------------------------------------| | The points on the left boundary line are not painted | | The points on the left boundary line are also painted | | | | Function | | The points on the right boundary line are not painted | | The points on the right boundary line are also painted | | ֡֡֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜֜ | # (14) ESE: Exchange Start with End This bit defines the reading order of the source data in the $\infty py$ operation. $\underline{X}$ : Reading start point # (15) REV: Reverse This bit defines the use of the reverse drawing in the copy operation. X: Drawing start point # (16) ROT: Rotation This bit defines the use of the 1800 rotation drawing in the $\infty py$ operation. # (17) SD SEL: Source Destination Mode Select This bit selects the data transfer mode between the planes as shown in the table below (please refer to the section on inter-plane data transfer): | SD SEL | Function | |--------|-----------------------------------| | 00 | Single source and destination | | 01 | Multiple sources | | 10 | Multiple destinations | | 11 | Multiple sources and destinations | # (18) FS: Fill Shortage When the coordinate conversion is made during the arbitrary angle rotation copy, some points may not be drawn. This bit specifies whether to draw these points or not. ☆ : The points #### (19) PUT: Put This bit specifies the transfer by the PUT command or transfer by the GET command. | PUT | Function | + 1 | |-----|-----------------|-----| | 0 | Transfer by GET | 1 | | 1 1 | Transfer by PUT | 1 | # (20) FAST: Fast This bit specifies the normal or fast mode for drawing. | FAST | Function | |------|--------------| | 1 0 | Normal speed | | 1 | Fast speed | However, the FAST mode cannot be used for all drawing operations: REC FILL: The FAST mode cannot be used if clipping or painting with a tiling pattern. It can only be used for replacing data. COPY: The FAST mode can be used only for ordinary COPY with replace. It cannot be used with other COPY operations or with multiple sources. # 4.5 Painting Pattern Reference Examples # (1) TL = 0, SS = 1 In this case, the contents of the 16-bit register, PTNCNT, in the AGDC is referred to as the painting pattern. When painting two or more planes is specified, painting is made in the same pattern. #### Parameters to be set: | (A) | Plane | to | be | selected | in | drawing | ••• | PLANES | |-----|-------|----|----|----------|----|---------|-----|--------| |-----|-------|----|----|----------|----|---------|-----|--------| - (B) Maximum number of planes to be selected in drawing ... PMAX - (C) Painting pattern to be referred to ... PINCMT Drawing Example: PLANES = 7, PMAX = 4, PINCNT = 5555H | 1010101010101010101010 | 10101010101010101010 | 1010101010101010101010 | |------------------------|----------------------|------------------------| | 1010101010101010 | 101010101010101010 | 1010101010101010 | | 10101010101010101010 | 10101010101010101010 | 10101010101010101010 | First plane Second plane Third plane # (2) TL = 1, SS = 1 In this case, multiple painting patterns previously stored in the display memory are referred to. The painting pattern is automatically updated according to the move of the Y coordinate. When painting covering two or more planes is specified and when the Y coordinates are the same, the same pattern is referred to. #### Parameters to be set: | (A) | Plane to be | selected | in | drawing | | | PLANES | |-----|-------------|----------|----|---------|--|--|--------| |-----|-------------|----------|----|---------|--|--|--------| - (B) Maximum number of planes to be selected in drawing ... PMAX - (C) The first address of the display memory containing the pattern ... PTNP - (D) The number of words to be repeated for the painting pattern ... PINCNT Second plane Drawing Example: PLANES = 7, PMAX = 4, PINCNT = 4 First plane | 10011001100110011001<br>0110011001100110110 | 10011001100110011001<br>0110011001100110110 | |---------------------------------------------|---------------------------------------------| | 00110011001100110011 | 00110011001100110011 | | 10011001100110011001 | 10011001100110011001 | Third plane # (3) TL = 1, SS = 0 The multiple painting patterns previously stored in the display memory are referred to. The painting pattern is automatically updated according to the move of the Y coordinate. When painting covering two or more planes is specified, the painting pattern corresponding to each plane is referred to. #### Parameters to be set: | (A) | Plane to be selected in drawing | PLANES | |-----|-----------------------------------------------------|--------| | (B) | Maximum number of planes to be selected in drawing | PMAX | | (C) | The first address of the display memory containing | | | | the pattern | PINP | | (D) | The number of words to be repeated for the painting | | (D) The number of words to be repeated for the painting pattern ... PINCNT (E) The address displacement between the painting pattern prepared for each plane ... PDISPS Drawing Examples: PLANES = 7, PMAX = 4, PINCNT = 4, PDISPS = 4 | 1001100.1100110011001 10000111100001111000 11001100110011001100 11000011110000111100 0110011001100110011 1110000111100001111 10011001100110011001 10000111100001111 | 1010101010101010101010<br>0101010101010101 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------| |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------| First plane Second plane Third plane # 4.6 Inter-plane Data Transfers #### 4.7 Drawing Related Registers The internal registers in which the parameters required for drawing are stored are described in this section. # (1) EADORG (Execution Address Origin) No. of Bits: 24 Address: 00H - 02H Application: This register sets the physical address (effective address) in the display memory corresponding to the origin (0,0) on the logical plane (the X-Y coordinate plane). #### (2) dADORG (Dot Address Origin) No. of Bits: 4 Address: 03H Application: This register sets the dot position in the physical address (effective address) in the display memory corresponding to the origin (0,0) on the logical plane (the X-Y coordinate plane). #### (3) EAD1 (Execution Address 1) No. of Bits: 24 Address: 04H - 06H Application: This register sets the drawing start physical address value in the drawing processing when the drawing start position is given by the physical address (effective address). # (4) dAD1 (Dot Address 1) No. of Bits: Address: 07H Application: This register sets the dot position in the display memory when the drawing start position is given by the physical address (effective address). #### (5) EAD2 (Execution Address 2) No. of Bits: 24 Address: HAD - H80 Application: This register sets the drawing start physical address in the drawing processor when the drawing start position is given by the physical address (effective address). # (6) dAD2 (Dot Address 2) No. of Bits: 4 Address: 0BH Application: This register sets the dot position in the display memory when the drawing start position is given by the physical address (effective address). #### (7) PDISPS (Plane Displacement Source) No. of Bits: 24 Address: OCH - OEH Application: This register sets the number of words which occupy one memory plane in the case of display memory configured with two or more planes. In the case of execution of the COPY command, the number of words per source plane is set. In the case of execution of the PAINT command, the number of words per plane containing the painting pattern (tiling pattern) is set. # (8) PDISPD (Plane Displacement Destination) No. of Bits: 24 Address: 10H - 12H Application: This register sets the number of words which occupy one memory plane in the case of display memory configured with two or more planes. In the case of execution of drawing commands, the number of words per plane for graphics drawing is set. In the case of execution of COPY commands, the number of words per destination plane is set. In the case of execution of painting commands, the number of words per painting plane is set. # (9) PMAX (Plane Maximum) No. of Bits: 16 Address: 14H - 15H Application: This register sets selects the number of planes (up to 16) in the display memory to be drawn, as shown in the following table: | Until 1st plane | |------------------| | Until 2nd plane | | Until 3rd plane | | 1 | | 1 . | | 1 | | Until 15th plane | | Until 16th plane | | | #### (10) MODO (Drawing Mode 0) No. of Bits: 4 Address: 16H Application: This registers defines the type of logical operation performed during drawing processing. When the bit in PLANES corresponding to the memory plane is 0 during drawing processing, the logical operation defined by MODO is executed. # (11) MOD1 (Drawing Mode 1) No. of Bits: 4 Address: 16H Application: This registers defines the type of logical operation performed during drawing processing. When the bit in PLANES corresponding to the memory plane is 1 during drawing processing, the logical operation defined by MODO is executed. #### (12) PINP (Pattern Pointer) No. of Bits: 24 Address: 18H - 1AH This registers sets the first physical address in the display Application: memory area containing the painting (tiling) pattern. #### (13) STACK (Stack Pointer) No. of Bits: 24 Address: 1CH - 1EH Application: This registers sets the first physical address in the display > memory area to save data such as coordinates, etc., during the retrieval of the boundary point in the arbitrary enclosed area painting. It may be considered as the working area of the AGDC in the execution of the PAINT command. #### (14) X, Y, DX, DY, XS, YS, XE, YE, XC, YC, DE, DV No. of Bits: 16 each Address: 40H - 57H, respectively This is the group of registers used to set the parameters Application: > required for the execution of various drawing commands. However, the DX registers is also used as the data port to output data read by the AGDC during execution of the READ COL command. #### (15) PITCHS (Pitch Source) No. of Bits: 16 Address: 58H - 59H Application: This register sets the number of addresses in the horizontal direction of the source plane in the display memory during execution of the COPY command. #### (16) PITCHD (Pitch Destination) No. of Bits: 16 Address: 5AH - 5BH Application: This registers set the number of addresses in the horizontal direction of the drawing plane in the display memory during execution of paint commands. # (17) STMAX (Store Maximum) No. of Bits: 16 Address: 5CH - 5DH Application: This register set the size of the display memory area used to save data such as coordinates, etc., during retrieval of the boundary point in the arbitrary enclosed area painting. It may be considered as the working area size of the ACDC during execution of the PAINT command. # (18) PLANES (Plane Select) No. of Bits: 16 Address: 5EH - 5FH Application: This register selects the type of logical operation in the drawing processing. Each bit in the PLANES registers directly corresponds to a plane. For the plane in which the logical operation defined by register MODO is to be executed, the corresponding bit in PLANES must be 0. For the plane in which the logical operation defined by register MOD1 is to be executed, the corresponding bit in PLANES must be 1. # (19) PINCAT (Pattern Count) No. of Bits: ] 16 Address: 60H - 61H Application: This register is set in the two ways listed below according to the painting pattern in the execution of the painting command: 1. In the case of painting by using the painting pattern previously generated in the display memory (TL = 1), the range of words from the address specified by the register PTNP to be referred to as the painting pattern is defined by the number of words. 2. When the 16-bit data in the register PINCNT is used as the painting pattern (TL = 0), the actual painting pattern is defined. # (20) XCIMIN, YCIMIN, XCIMAX, YCIMAX (X/Y Clipping Minimum/Maximum) No. of Bits: 16 each Address: 62H - 69H, respectively Application: These registers define the rectangular clipping area to be referred to during the drawing processing. # (21) MAGE (Horizontal Magnification) No. of Bits: 4 Address: 6CH Application: This register sets the enlargement/shrink magnification in the horizontal direction during execution of enlarge/shrink drawing. In the case of enlargement drawing, the magnification is 16/(MAGH+1). In the case of shrink drawing, the magnification if (MAGH+1)/16. # (22) MAGV (Vertical Magnification) No. of Bits: 4 Address: 6CH Application: This register sets the enlargement/shrink magnification in the vertical direction during execution of enlarge/shrink drawing. In the case of enlarge drawing, the magnification is 16/(MAGV+1). In the case of shrink drawing, the magnification is (MAGV+1)/16. # (23) CLIP (Clipping Mode) No. of Bits: 2 Address: 6DH Application: This register selects the clipping operation as shown in the following table: | | <del> </del> | <del></del> | |-------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------| | CLIP | Function (Other than PAINT command) | Function (Paint command | | 00 | Drawing only in the defined rectangular area | Boundary point retrieval<br> and drawing only in<br> defined rectangular area | | 01 | No clipping operation | | | 10<br> <br> | Drawing only outside the defined<br> rectangular area<br> | Boundary point retrieval<br> and drawing only outside<br> the defined rectangular<br> area | | 11 | Not Used | | # (24) FLAGS, COMMAND (Flags, Command) No. of Bits: 16 Address: 6EH - 6FH Application: This is the register used to write the command to be executed by the AGDC. It consists of the operation code (6FH) and the operation flags (6EH). When the operation code is written to the command register, AGDC begins processing. # 4.8 Parameters Corresponding to DRAW Commands The parameters required for DRAW commands are illustrated in this section. (X+DR, Y+DG) [ DOT] (X,Y)(X, Y) -DX- $[A_DOT]$ [R\_DOT] (XE, YE) (X+DX, Y+DY) [LINE] (X,Y)DX. (X,Y)[ALLINE] [R\_LINE] (XS, YS) (X+DX, Y+DY) [ RECTANGLE] (X,Y)[)\<mark>.</mark>-(X,Y)[A\_REC] [R\_REC] [CIRCLE] $\mathbb{D}\mathbb{X}$ (XC, YC) [CRL] [ELLIPSE] DY ! $\mathbb{D}_{\mathbb{N}}^{n}$ DX (XC,YC) (XC, YC) DH: DU=DX2:DY2 [ELPS] 4-55 4-60 # [ENLARGE/SHRINK COPY] [ES\_COPY] SOURCE REU=0, ROT=0 ESH=1, ESU=0 ESH=3, ESU=1 REU=0, ROT=1 ESH=1, ESV=8 ESH=0, ESH=1. REU=1. ROT=0 ESH=0, ESU=0 ESH=1, ESU=0 REV=1. ROT=1 E9H=0, E9U=1 ESH=1, ESH=1 · RASTER OPERATION MODE (1) # • RASTER OPERATION MODE (2) · 以对外外的物理等的 401 Ellis Street P 0 Box 7241 Mountain View, CA 94039 TEL 415-960-6000 TWX 910-379-6985 For Literature Call Toll Free: 1-800-632-3531 1-800-632-3532 (In California) No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Electronics Inc. The information in this document is subject to change without notice. Devices sold by NEC Electronics Inc are covered by the warranty and patent indemnification provisions appearing in NEC Electronics Inc. Terms and Conditions of Sale only. NEC Electronics Inc. makes no warranty, express, statutory, implied, or by description, regarding the information set forth herein or regarding the freedom of the described devices from patent infringement. NEC Electronics Inc. makes no warranty of merchantability or timess for any purpose. NEC Electronics Inc. assumes no responsibility for any errors that may appear in this document. NEC Electronics Inc. makes no commitment to update or to keep current the information contained in this document.