

# Intel<sup>®</sup> OpenSource HD Graphics Programmer's Reference Manual (PRM) Volume 1 Part 5: Graphics Core – Blitter Engine (SandyBridge)

# For the 2011 Intel Core Processor Family

May 2011 Revision 1.0

#### NOTICE:

This document contains information on products in the design phase of development, and Intel reserves the right to add or remove product features at any time, with or without changes to this open source documentation.



#### **Creative Commons License**

You are free to Share — to copy, distribute, display, and perform the work

#### Under the following conditions:

**Attribution**. You must attribute the work in the manner specified by the author or licensor (but not in any way that suggests that they endorse you or your use of the work).

No Derivative Works. You may not alter, transform, or build upon this work.

INFORMATION IN THIS DOCUMENT IS PROVIDED IN CONNECTION WITH INTEL<sup>®</sup> PRODUCTS. NO LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE, TO ANY INTELLECTUAL PROPERTY RIGHTS IS GRANTED BY THIS DOCUMENT. EXCEPT AS PROVIDED IN INTEL'S TERMS AND CONDITIONS OF SALE FOR SUCH PRODUCTS, INTEL ASSUMES NO LIABILITY WHATSOEVER, AND INTEL DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY, RELATING TO SALE AND/OR USE OF INTEL PRODUCTS INCLUDING LIABILITY OR WARRANTIES RELATING TO FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT. Intel products are not intended for use in medical, life saving, or life sustaining applications.

Intel may make changes to specifications and product descriptions at any time, without notice.

Designers must not rely on the absence or characteristics of any features or instructions marked "reserved" or "undefined." Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them.

The SandyBridge chipset family, Havendale/Auburndale chipset family, Intel<sup>®</sup> 965 Express Chipset Family, Intel<sup>®</sup> G35 Express Chipset, and Intel<sup>®</sup> 965GMx Chipset Mobile Family Graphics Controller may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request.

Contact your local Intel<sup>®</sup> sales office or your distributor to obtain the latest specifications and before placing your product order. I2C is a two-wire communications bus/protocol developed by Philips. SMBus is a subset of the I2C bus/protocol and was developed by Intel<sup>®</sup>. Implementations of the I2C bus/protocol may require licenses from various entities, including Philips Electronics N.V. and North American Philips Corporation.

Intel and the Intel logo are trademarks of Intel Corporation in the U.S. and other countries.

\*Other names and brands may be claimed as the property of others.

**Copyright © 2011, Intel Corporation. All rights reserved.** 



# Contents

| 1. BLT Engine                                                    | 5  |
|------------------------------------------------------------------|----|
| 1.1 Introduction                                                 | 5  |
| 1.2 Classical BLT Engine Functional Description                  | 5  |
| 1.2.1 Basic BLT Functional Considerations                        |    |
| 1.2.2 Basic Graphics Data Considerations                         |    |
| 1.2.3 BLT Programming Examples                                   | 23 |
| 1.3 BLT Instruction Overview                                     | 29 |
| 1.4 BLT Engine State                                             | 29 |
| 1.5 Cacheable Memory Support                                     | 30 |
| 1.6 Device Cache Coherency: Render & Texture Caches              |    |
| 1.7 BLT Engine Instructions                                      |    |
| 1.7.1 Blt Programming Restrictions                               |    |
| 1.8 Fill/Move Instructions                                       |    |
| 1.8.1 COLOR_BLT (Fill)                                           |    |
| 1.8.2 SRC_COPY_BLT (Move)                                        | 32 |
| 1.9 2D (X,Y) BLT Instructions                                    |    |
| 1.9.1 XY_SETUP_BLT                                               |    |
| 1.9.2 XY_SETUP_MONO_PATTERN_SL_BLT                               |    |
| 1.9.3 XY_SETUP_CLIP_ BLT                                         |    |
| 1.9.4 XY_PIXEL_BLT                                               |    |
| 1.9.5 XY_SCANLINES_BLT                                           |    |
| 1.9.6 XY_TEXT_BLT                                                |    |
| 1.9.7 XY_TEXT_IMMEDIATE_BLT                                      | 40 |
| 1.9.8 XY_COLOR_BLT                                               | 41 |
| 1.9.9 XY_PAT_BLT                                                 |    |
| 1.9.10 XY_PAT_CHROMA_BLT                                         |    |
| 1.9.11 XY_PAT_BLT_IMMEDIATE                                      |    |
| 1.9.12 XY_PAT_CHROMA_BLT_IMMEDIATE                               | 46 |
| 1.9.13 XY_MONO_PAT_BLT                                           |    |
| 1.9.14 XY_MONO_PAT_FIXED_BLT                                     | 49 |
| 1.9.15 XY_SRC_COPY_BLT                                           |    |
| 1.9.16 XY_SRC_COPY_CHROMA_BLT                                    | 58 |
| 1.9.17 XY_MONO_SRC_COPY_BLT                                      | 60 |
| 1.9.18 XY_MONO_SRC_COPY_ IMMEDIATE_BLT                           | 61 |
| 1.9.19 XY_FULL_BLT                                               | 62 |
| 1.9.20 XY_FULL_IMMEDIATE_PATTERN_BLT                             |    |
| 1.9.21 XY_FULL_MONO_SRC_BLT                                      |    |
| 1.9.22 XY_FULL_MONO_SRC_IMMEDIATE_PATTERN_BLTBLT                 | 67 |
| 1.9.23 XY_FULL_MONO_PATTERN_BLT                                  | 69 |
| 1.9.24 XY_FULL_MONO_PATTERN_MONO_SRC_BLT                         |    |
| 1.10 BLT Engine Instruction Field Definitions                    | 73 |
| 1.10.1 BR00—BLT Opcode & Control                                 |    |
| 1.10.2 BR01—Setup BLT Raster OP, Control, and Destination Offset | 76 |
| 1.10.3 BR05—Setup Expansion Background Color                     |    |
| 1.10.4 BR06—Setup Expansion Foreground Color                     |    |
| 1.10.5 BR07—Setup Color Pattern Address                          |    |
| 1.10.6 BR09—Destination Address                                  |    |
| 1.10.7 BR11—BLT Source Pitch (Offset)                            |    |
| 1.10.8 BR12—Source Address                                       |    |
| 1.10.9 BR13—BLT Raster OP, Control, and Destination Pitch        | 82 |



| 1.10.10   | BR14—Destination Width and Height                           |  |
|-----------|-------------------------------------------------------------|--|
| 1.10.11   | BR15—Color Pattern Address                                  |  |
| 1.10.12   | 2 BR16—Pattern Expansion Background and Solid Pattern Color |  |
| 1.10.13   | BR17—Pattern Expansion Foreground Color                     |  |
| 1.10.14   | BR18—Source Expansion Background, and Destination Color     |  |
| 1.10.15   | BR19—Source Expansion Foreground Color                      |  |
| 2. Blitte | er (Blt) Engine Command Streamer                            |  |
| 2.1 Re    | gisters for Blitter Engine                                  |  |
| 2.1.1     | Introduction                                                |  |
| 2.1.2     | GAB PWR CTX STORAGE REGISTERS                               |  |
| 2.1.3     | Virtual Memory Control                                      |  |
| 2.1.4     | Mode and Misc Ctrl Registers                                |  |
| 2.1.5     | BCS_RINGBUF—Ring Buffer Registers                           |  |
| 2.1.6     | Interrupt Control Registers                                 |  |
| 2.1.7     | Logical Context Support                                     |  |
| 2.1.8     | Software Control Bit Definitions                            |  |
| 2.2 Me    | mory Interface Commands for Blitter Engine                  |  |
| 2.2.1     | Introduction                                                |  |
| 2.2.2     | MI_ARB_CHECK                                                |  |
| 2.2.3     | MI_BATCH_BUFFER_END                                         |  |
| 2.2.4     | MI_BATCH_BUFFER_START                                       |  |
| 2.2.5     | MI_FLUSH_DW                                                 |  |
| 2.2.6     | MI_LOAD_REGISTER_IMM                                        |  |
| 2.2.7     | MI_NOOP                                                     |  |
| 2.2.8     | MI_REPORT_HEAD                                              |  |
| 2.2.9     | MI_SEMAPHORE_MBOX                                           |  |
| 2.2.10    | MI_STORE_REGISTER_MEM                                       |  |
| 2.2.11    | MI_STORE_DATA_IMM                                           |  |
| 2.2.12    | MI_STORE_DATA_INDEX                                         |  |
| 2.2.13    | MI_SUSPEND_FLUSH                                            |  |
| 2.2.14    |                                                             |  |
| 2.2.15    | MI_USER_INTERRUPT                                           |  |
| 2.2.16    | MI_WAIT_FOR_EVENT [DevSNB]                                  |  |
| 2.2.17    | MSG_LOAD_SL – Load Scan Lines Message                       |  |



# 1. BLT Engine

# 1.1 Introduction

2D Rendering can be divided into 2 categories: classical BLTs, described here, and 3D BLTs.

3D BLTs are operations which can take advantage of the 3D drawing engine's functionality and access patterns. Functions such as Alpha BLTs, arithmetic (bilinear) stretch BLTs, rotations, transposing pixel maps, color space conversion, and DIBs are all considered 3D BLTs and are covered in the 3D rendering section. DIBs can be thought of as an indexed texture which uses the texture palette for performing the data translation. All drawing engines have swappable context. The same hardware can be used by multiple driver threads where the current state of the hardware is saved to memory and the appropriate state is loaded from memory on thread switches.

All operands for both 3D and classical BLTs can be in graphics aperture or cacheable system memory. Some operands can be immediates which are sent through the command stream. Immediate operands are: patterns, monochrome sources, DIB palettes, and DIB source operands. All non-monochrome operands which are not tiled have a stride granularity of a double-word (4 bytes).

The classical BLT commands support both linear addressing and X, Y coordinates with and without clipping. All X1 and Y1 destination and clipping coordinates are inclusive, while X2 and Y2 are exclusive. Currently, only destination coordinates can be negative. The source and clipping coordinates must be positive. If clipping is disabled, but a negative destination coordinate is specified, the negative coordinate is clipped to 0. Linear address BLT commands must supply a non-zero height and width. If either height or width = 0, then no accesses occur.

# **1.2 Classical BLT Engine Functional Description**

The graphics controller provides a hardware-based BLT engine to off load the work of moving blocks of graphics data from the host CPU. Although the BLT engine is often used simply to copy a block of graphics data from the source to the destination, it also has the ability to perform more complex functions. The BLT engine is capable of receiving three different blocks of graphics data as input as shown in the figure below. The source data may exist in the frame buffer or the Graphics aperture. The pattern data always represents an 8x8 block of pixels that can be located in the frame buffer, Graphics aperture, or passed through a command packet. The pattern data must be located in linear memory. The data already residing at the destination may also be used as an input. The destination data can also be located in the frame buffer or graphics aperture.



#### Figure 1-1. Block Diagram and Data Paths of the BLT Engine



The BLT engine may use any combination of these three different blocks of graphics data as operands, in both bit-wise logical operations to generate the actual data to be written to the destination, and in perpixel write-masking to control the writing of data to the destination. It is intended that the BLT engine will perform these bit-wise and per-pixel operations on color graphics data that is at the same color depth that the rest of the graphics system has been set. However, if either the source or pattern data is monochrome, the BLT engine has the ability to put either block of graphics data through a process called "color expansion" that converts monochrome graphics data to color. Since the destination is often a location in the on-screen portion of the frame buffer, it is assumed that any data already at the destination will be of the appropriate color depth.



# **1.2.1 Basic BLT Functional Considerations**

### 1.2.1.1 Color Depth Configuration and Color Expansion

The graphics system and BLT engine can be configured for color depths of 8, 16, and 32 bits per pixel.

The configuration of the BLT engine for a given color depth dictates the number of bytes of graphics data that the BLT engine will read and write for each pixel while performing a BLT operation. It is assumed that any graphics data already residing at the destination which is used as an input is already at the color depth to which the BLT engine is configured. Similarly, it is assumed that any source or pattern data used as an input has this same color depth, unless one or both is monochrome. If either the source or pattern data is monochrome, the BLT engine performs a process called "color expansion" to convert such monochrome data to color at the color depth to which the BLT engine has been set.

During "color expansion" the individual bits of monochrome source or pattern data that correspond to individual pixels are converted into 1, 2, or 4 bytes (which ever is appropriate for the color depth to which the BLT engine has been set). If a given bit of monochrome source or pattern data carries a value of 1, then the byte(s) of color data resulting from the conversion process are set to carry the value of a specified foreground color. If a given bit of monochrome source or pattern data carries a value of 0, the resulting byte(s) are set to the value of a specified background color or not written if transparency is selected.

The BLT engine is set to a default configuration color depth of 8, 16, or 32 bits per pixel through BLT command packets. Whether the source and pattern data are color or monochrome must be specified using command packets. Foreground and background colors for the color expansion of both monochrome source and pattern data are also specified through the command packets. The source foreground and background colors used in the color expansion of monochrome source data are specified independently of those used for the color expansion of monochrome pattern data.

### 1.2.1.2 Graphics Data Size Limitations

The BLT engine is capable of transferring very large quantities of graphics data. Any graphics data read from and written to the destination is permitted to represent a number of pixels that occupies up to 65,536 scan lines and up to 32,768 bytes per scan line at the destination. The maximum number of pixels that may be represented per scan line's worth of graphics data depends on the color depth.

Any source data used as an input must represent the same number of pixels as is represented by any data read from or written to the destination, and it must be organized so as to occupy the same number of scan lines and pixels per scan line.

The actual number of scan lines and bytes per scan line required to accommodate data read from or written to the destination are set in the destination width & height registers or using X and Y coordinates within the command packets. These two values are essential in the programming of the BLT engine, because the engine uses these two values to determine when a given BLT operation has been completed.

### 1.2.1.3 Bit-Wise Operations

The BLT engine can perform any one of 256 possible bit-wise operations using various combinations of the three previously described blocks of graphics data that the BLT engine can receive as input. These



256 possible bit-wise operations are designed to be compatible with the manner in which raster operations are specified in the standard BLT parameter block, without translation.

The choice of bit-wise operation selects which of the three inputs will be used, as well as the particular logical operation to be performed on corresponding bits from each of the selected inputs. The BLT engine automatically foregoes reading any form of graphics data that has not been specified as an input by the choice of bit-wise operation. An 8-bit code written to the raster operation field of the command packets chooses the bit-wise operation. The following table lists the available bit-wise operations and their corresponding 8-bit codes.

| Code | Value Written to Bits at Destination      |
|------|-------------------------------------------|
| 00   | writes all 0's                            |
| 01   | not( D or ( P or S )))                    |
| 02   | D and ( not( P or S ))                    |
| 03   | not( P or S )                             |
| 04   | S and ( not( D or P ))                    |
| 05   | not( D or P )                             |
| 06   | not( P or ( not( D xor S )))              |
| 07   | not( P or ( D and S ))                    |
| 08   | S and ( D and ( notP ))                   |
| 09   | not( P or ( D xor S ))                    |
| 0A   | D and ( notP )                            |
| 0B   | not( P or ( S and ( notD )))              |
| 0C   | S and ( notP )                            |
| 0D   | not( P or ( D and ( notS )))              |
| 0E   | not( P or ( not( D or S )))               |
| 0F   | notP                                      |
| 10   | P and ( not( D or S ))                    |
| 11   | not( D or S )                             |
| 12   | not( S or ( not( D xor P )))              |
| 13   | not( S or ( D and P ))                    |
| 14   | not( D or ( not( P xor S )))              |
| 15   | not( D or ( P and S ))                    |
| 16   | P xor ( S xor (D and ( not( P and S ))))  |
| 17   | not( S xor (( S xor P ) and ( D xor S ))) |
| 18   | (S xor P) and (P xor D)                   |
| 19   | not( S xor ( D and ( not( P and S ))))    |
| 1A   | P xor ( D or ( S and P ))                 |
| 1B   | not( S xor ( D and ( P xor S )))          |
| 1C   | P xor ( S or ( D and P ))                 |
| 1D   | not( D xor ( S and ( P xor D )))          |
| 1E   | P xor ( D or S )                          |
| 1F   | not( P and ( D or S ))                    |

#### Table 1-1. Bit-Wise Operations and 8-Bit Codes (00-3F)

| CodeValue Written to Bits at Destination20D and (P and (notS))21not(S or(D xor P))22D and (notS)23not(S or (P and (notD)))24(S xor P) and (D xor S)25not(P xor (D and (not(S and P))))26S xor (D or (P and S))27S xor (D or (not(P xor S)))28D and (P xor S)29not(S xor (C or (D or (P and S)))28D and (not(P and S))29not(S xor ((S xor P) and (P xor D)))20S xor (C or (notD))21P xor (S or (notD))22P xor (S or (notD))23not(S xor (D or (notD)))24D and (notS xor (NotP))25not(S or (D and (notP)))30P and (notS)31not(S or (D and (notP)))32S xor (D or (P or S))33notS34S xor (P or (not(D xor S)))35S xor (P or (not(D xor S)))36S xor (D or P)37not(S and (D or P))38P xor (S and (D or P))39S xor (P or (notD))34S xor (P or (notD))35S xor (P or (notD))36N or (P or (notD))37not(S and (P or (notD)))38not(S and (P or (notD)))39S xor (P or (notD))34S xor (P or (notD))35S xor (P or (notD))36N or (P or (notD))37not(S and (P or (notD)))38not(S and (P or (notD)))39 </th <th></th> <th></th>                                                                                                                                                                                                                      |      |                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------------------------------------|
| 21         not(S or(D xor P))           22         D and (notS)           23         not(S or (P and (notD)))           24         (S xor P) and (D xor S)           25         not(P xor (D and (not(S and P))))           26         S xor (D or (P and S))           27         S xor (D or (not(P xor S)))           28         D and (P xor S)           29         not(S xor (C or (D or (P and S))))           24         D and (not(P and S))           28         D and (not(P and S))           29         not(S xor (C xor P) and (P xor D))))           20         P xor (S xor (notD or S))           21         P xor (S or (notD))           22         S xor (P and (D or S))           20         P xor (S or (notD))           21         P xor (S or (D xor P))           22         P xor (S or (D and (notP)))           30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (P or (D and S))           33         notS           34         S xor (P or (not(D xor S)))           35         S xor (P or (notD xor S)))           36         S xor (P or (notD))           37         not(S and (D or P))                                                      | Code | Value Written to Bits at Destination      |
| 22       D and ( notS )         23       not(S or (P and ( notD )))         24       (S xor P) and (D xor S)         25       not(P xor (D and ( not(S and P ))))         26       S xor (D or ( P and S ))         27       S xor (D or ( not(P xor S )))         28       D and (P xor S)         29       not(P xor (S xor (D or (P and S )))         28       D and ( not(P and S ))         29       not(S xor (( S xor P ) and ( P xor D ))))         20       P xor (S xor (notD or S ))         21       P xor (S or ( notD ))         22       S xor (P and ( D or S ))         20       P xor (S or ( notD ))         21       P xor (S or ( notD ))         22       P xor (S or ( notD ))         24       P and ( notS )         31       not(S or ( D and ( notP )))         32       S xor ( P or ( D and S ))         33       notS         34       S xor ( P or ( not(D xor S )))         35       S xor ( P or ( notD x) S )))         36       S xor ( P or ( notD ))         38       P xor (S and ( D or P ))         39       S xor ( P or ( notD ))         34       S xor ( P or ( notD ))         35       S x                                                                                          | 20   | D and ( P and ( notS ))                   |
| 23         not(S or (P and (notD)))           24         (S xor P) and (D xor S)           25         not(P xor (D and (not(S and P))))           26         S xor (D or (P and S))           27         S xor (D or (not(P xor S)))           28         D and (P xor S)           29         not(S xor (D or (P and S)))           2A         D and (not(P and S))           2B         not(S xor ((S xor P) and (P xor D))))           2C         S xor (P and (D or S))           2D         P xor (S or (notD))           2E         P xor (S or (D xor P))           2F         not(P and (S or (notD)))           30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (P or (P or S))           33         notS           34         S xor (P or (not(D xor S)))           35         S xor (P or (not(D xor S)))           36         S xor (P or (notD P))           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           34         S xor (P or (notD))           35         S xor (P or (notD))           36         P xor (S and (P or (notD))) </td <td>21</td> <td>not( S or( D xor P ))</td> | 21   | not( S or( D xor P ))                     |
| 24         (S xor P) and (D xor S)           25         not(P xor (D and (not(S and P))))           26         S xor (D or (P and S))           27         S xor (D or (not(P xor S)))           28         D and (P xor S)           29         not(P xor (S xor (D or (P and S)))           2A         D and (not(P and S))           2B         not(S xor ((S xor P) and (P xor D)))           2C         S xor (P and (D or S))           2D         P xor (S or (notD))           2E         P xor (S or (D xor P))           2F         not(P and (S or (notD)))           30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (P or (P or S))           33         notS           34         S xor (P or (not(D xor S)))           35         S xor (P or (not(D xor S)))           36         S xor (P or (notD P))           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           34         S xor (P or (notD))           35         S xor (P or (notD))           36         P xor (S and (D or P))           37         not(S and (P or (notD)))<                                               | 22   | D and ( notS )                            |
| 25         not(P xor (D and (not(S and P))))           26         S xor (D or (P and S))           27         S xor (D or (not(P xor S)))           28         D and (P xor S)           29         not(P xor (S xor (D or (P and S))))           2A         D and (not(P and S))           2B         not(S xor ((S xor P) and (P xor D)))           2C         S xor (P and (D or S))           2D         P xor (S or (notD))           2E         P xor (S or (D xor P))           2F         not(P and (S or (notD)))           2F         not(P and (S or (notD)))           30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (D or (P or S))           33         notS           34         S xor (P or (not(D xor S)))           35         S xor (P or (not(D xor S)))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           34         S xor (P or (notD))           35         S xor (P or (notD))           36         P xor (S and (D or P))           37         not(S and (P or (notD)))                                                     | 23   | not( S or ( P and ( notD )))              |
| 26       S xor ( D or ( P and S ))         27       S xor ( D or ( not( P xor S ))))         28       D and ( P xor S )         29       not( P xor ( S xor ( D or ( P and S )))))         2A       D and ( not( P and S ))         2B       not( S xor (( S xor P ) and ( P xor D ))))         2C       S xor ( P and ( D or S ))         2D       P xor ( S or ( notD ))         2E       P xor ( S or ( D xor P ))         2F       not( P and ( S or ( notD )))         30       P and ( notS )         31       not( S or ( D and ( notP )))         32       S xor ( D or ( P or S ))         33       notS         34       S xor ( P or ( not( D xor S )))         35       S xor ( P or ( not( D xor S )))         36       S xor ( D or P )         37       not( S and ( D or P ))         38       P xor ( S and ( D or P ))         39       S xor ( P or ( notD ))         34       S xor ( P or ( notD ))         35       S xor ( P or ( notD ))         36       P xor ( S and ( D or P ))         39       S xor ( P or ( notD ))         34       S xor ( P or ( notD ))         35       S xor ( P or ( notD ))         36 <td>24</td> <td>(S xor P) and (D xor S)</td>                                       | 24   | (S xor P) and (D xor S)                   |
| 27         S xor (D or (not(P xor S)))           28         D and (P xor S)           29         not(P xor (S xor (D or (P and S))))           2A         D and (not(P and S))           2B         not(S xor ((S xor P) and (P xor D)))           2C         S xor (P and (D or S))           2D         P xor (S or (notD))           2E         P xor (S or (D xor P))           2F         not(P and (S or (notD)))           30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (D or (P or S))           33         notS           34         S xor (P or (not(D xor S)))           35         S xor (P or (not(D xor S)))           36         S xor (P or (not(D xor S)))           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           34         S xor (P or (notD))           35         S xor (P or (notD))           38         P xor (S and (D or P))           39         S xor (P or (notD))           34         S xor (P or (notD))           35         S xor (P or (notD))           36         S xor (P or (notD)) <td>25</td> <td>not( P xor ( D and ( not( S and P ))))</td>       | 25   | not( P xor ( D and ( not( S and P ))))    |
| 28         D and (P xor S)           29         not(P xor (S xor (D or (P and S))))           2A         D and (not(P and S))           2B         not(S xor ((S xor P) and (P xor D)))           2C         S xor (P and (D or S))           2D         P xor (S or (notD))           2E         P xor (S or (D xor P))           2F         not(P and (S or (notD)))           30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (D or (P or S))           33         notS           34         S xor (P or (not(D xor S)))           35         S xor (P or (not(D xor S)))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           34         S xor (P or (notD))           35         S xor (P or (notD))           36         P xor (S and (D or P))           37         not(S and (P or (notD)))           38         P xor (S and (P or (notD)))           38         Not (P or (D xor S))           39         S xor (P or (notD)))           38         not(S and (P or (notD)))      <                                                             | 26   | S xor ( D or ( P and S ))                 |
| 29         not(P xor (S xor (D or (P and S))))           2A         D and (not(P and S))           2B         not(S xor ((S xor P) and (P xor D))))           2C         S xor (P and (D or S))           2D         P xor (S or (notD))           2E         P xor (S or (D xor P)))           2F         not(P and (S or (notD)))           30         P and (notS)           31         not(S or (D and (notP))))           32         S xor (D or (P or S))           33         notS           34         S xor (P or (not(D xor S))))           35         S xor (P or (not(D xor S))))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           34         S xor (P or (notD))           35         S xor (P or (notD))           36         P xor (S and (D or P))           37         not(S and (P or (notD)))           38         P xor (S and (P or (notD)))           38         Not (P or (D xor S))           39         S xor (P or (notD)))           30         P xor S                                                                                                                     | 27   | S xor ( D or ( not( P xor S )))           |
| 2A       D and (not(P and S))         2B       not(S xor ((S xor P) and (P xor D)))         2C       S xor (P and (D or S))         2D       P xor (S or (notD))         2E       P xor (S or (D xor P))         2F       not(P and (S or (notD)))         30       P and (notS)         31       not(S or (D and (notP)))         32       S xor (D or (P or S))         33       notS         34       S xor (P or (D and S))         35       S xor (P or (not(D xor S)))         36       S xor (D or P)         37       not(S and (D or P))         38       P xor (S and (D or P))         39       S xor (P or (notD))         34       S xor (P or (notD))         35       S xor (P or (notD))         36       S xor (D or P)         37       not(S and (D or P))         38       P xor (S and (D or P))         39       S xor (P or (notD))         34       S xor (P or (notD))         35       S xor (P or (D xor S))         36       P xor S                                                                                                                                                                                                                                                                  | 28   | D and ( P xor S )                         |
| 2B         not(S xor ((S xor P) and (P xor D)))           2C         S xor (P and (D or S))           2D         P xor (S or (notD))           2E         P xor (S or (D xor P))           2F         not(P and (S or (notD)))           30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (D or (P or S))           33         notS           34         S xor (P or (not(D xor S)))           35         S xor (P or (not(D xor S))))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 29   | not( P xor ( S xor ( D or ( P and S ))))  |
| 2C       S xor (P and (D or S))         2D       P xor (S or (notD))         2E       P xor (S or (D xor P))         2F       not(P and (S or (notD)))         30       P and (notS)         31       not(S or (D and (notP)))         32       S xor (D or (P or S))         33       notS         34       S xor (P or (D and S))         35       S xor (P or (not(D xor S)))         36       S xor (D or P)         37       not(S and (D or P))         38       P xor (S and (D or P))         39       S xor (P or (notD))         3A       S xor (P or (notD))         3B       not(S and (P or (notD)))         3C       P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2A   | D and ( not( P and S ))                   |
| 2D         P xor (S or (notD))           2E         P xor (S or (D xor P))           2F         not(P and (S or (notD)))           30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (D or (P or S))           33         notS           34         S xor (P or (D and S))           35         S xor (P or (not(D xor S)))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2B   | not( S xor (( S xor P ) and ( P xor D ))) |
| 2E         P xor (S or (D xor P))           2F         not(P and (S or (notD)))           30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (D or (P or S))           33         notS           34         S xor (P or (D and S))           35         S xor (P or (not(D xor S)))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 2C   | S xor ( P and ( D or S ))                 |
| 2F         not(P and (S or (notD)))           30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (D or (P or S))           33         notS           34         S xor (P or (D and S))           35         S xor (P or (not(D xor S)))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2D   | P xor ( S or ( notD ))                    |
| 30         P and (notS)           31         not(S or (D and (notP)))           32         S xor (D or (P or S))           33         notS           34         S xor (P or (D and S))           35         S xor (P or (not(D xor S)))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 2E   | P xor ( S or ( D xor P ))                 |
| 31         not(S or (D and (notP)))           32         S xor (D or (P or S))           33         notS           34         S xor (P or (D and S))           35         S xor (P or (not(D xor S)))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2F   | not( P and ( S or ( notD )))              |
| 32       S xor (D or (P or S))         33       notS         34       S xor (P or (D and S))         35       S xor (P or (not(D xor S)))         36       S xor (D or P)         37       not(S and (D or P))         38       P xor (S and (D or P))         39       S xor (P or (notD))         3A       S xor (P or (notD))         3B       not(S and (P or (notD)))         3C       P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 30   | , , ,                                     |
| 33         notS           34         S xor (P or (D and S))           35         S xor (P or (not(D xor S)))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 31   | not( S or ( D and ( notP )))              |
| 34         S xor (P or (D and S))           35         S xor (P or (not(D xor S)))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 32   | S xor ( D or ( P or S ))                  |
| 35         S xor (P or (not(D xor S)))           36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD xor S))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 33   | notS                                      |
| 36         S xor (D or P)           37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 34   | S xor ( P or ( D and S ))                 |
| 37         not(S and (D or P))           38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (notD))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 35   | S xor ( P or ( not( D xor S )))           |
| 38         P xor (S and (D or P))           39         S xor (P or (notD))           3A         S xor (P or (D xor S))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 36   | S xor ( D or P )                          |
| 39         S xor (P or (notD))           3A         S xor (P or (D xor S))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 37   | not( S and ( D or P ))                    |
| 3A         S xor (P or (D xor S))           3B         not(S and (P or (notD)))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 38   |                                           |
| 3B         not( S and ( P or ( notD )))           3C         P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 39   | S xor ( P or ( notD ))                    |
| 3C P xor S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 3A   | S xor ( P or ( D xor S ))                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 3B   | not( S and ( P or ( notD )))              |
| 3D S xor ( P or ( not( D or S )))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3C   |                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 3D   | S xor ( P or ( not( D or S )))            |
| 3E S xor ( P or ( D and ( notS )))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3E   | S xor ( P or ( D and ( notS )))           |
| 3F not( P and S )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3F   | not( P and S )                            |

Notes: S = Source Data

P = Pattern Data

D = Data Already Existing at the Destination



| Code | Value Written to Bits at Destination     |
|------|------------------------------------------|
| 40   | P and ( S and ( notD ))                  |
| 41   | not( D or ( P xor S ))                   |
| 42   | (S xor D) and (P xor D)                  |
| 43   | not( S xor ( P and ( not( D and S ))))   |
| 44   | S and ( notD )                           |
| 45   | not( D or ( P and ( notS )))             |
| 46   | D xor ( S or ( P and D ))                |
| 47   | not( P xor ( S and ( D xor P )))         |
| 48   | S and ( D xor P )                        |
| 49   | not( P xor ( D xor ( S or ( P and D )))) |
| 4A   | D xor ( P and ( S or D ))                |
| 4B   | P xor ( D or ( notS ))                   |
| 4C   | S and ( not( D and P ))                  |
| 4D   | not( S xor (( S xor P ) or ( D xor S ))) |
| 4E   | P xor ( D or ( S xor P ))                |
| 4F   | not( P and ( D or ( notS )))             |
| 50   | P and ( notD )                           |
| 51   | not( D or ( S and ( notP )))             |
| 52   | D xor (P or ( S and D ))                 |
| 53   | not( S xor ( P and ( D xor S )))         |
| 54   | not( D or ( not( P or S )))              |
| 55   | notD                                     |
| 56   | D xor ( P or S )                         |
| 57   | not( D and ( P or S ))                   |
| 58   | P xor ( D and ( S or P ))                |
| 59   | D xor ( P or ( notS ))                   |
| 5A   | D xor P                                  |
| 5B   | D xor ( P or ( not( S or D )))           |
| 5C   | D xor ( P or ( S xor D ))                |
| 5D   | not( D and ( P or ( notS )))             |
| 5E   | D xor ( P or ( S and ( notD )))          |
| 5F   | not( D and P )                           |

### Table 1-2. Bit-Wise Operations and 8-bit Codes (40 - 7F)

| Code | Value Written to Bits at Destination             |
|------|--------------------------------------------------|
| 60   | P and (D xor S)                                  |
| 61   | not( D xor ( S xor ( P or ( D and S ))))         |
| 62   | D xor ( S and ( P or D ))                        |
| 63   | S xor ( D or ( notP ))                           |
| 64   | S xor ( D and ( P or S ))                        |
| 65   | D xor ( S or ( notP ))                           |
| 66   | D xor S                                          |
| 67   | S xor ( D or ( not( P or S )))                   |
| 68   | not( D xor ( S xor ( P or ( not( D or S<br>))))) |
| 69   | not( P xor ( D xor S ))                          |
| 6A   | D xor ( P and S )                                |
| 6B   | not( P xor ( S xor ( D and ( P or S ))))         |
| 6C   | S xor ( D and P )                                |
| 6D   | not( P xor ( D xor ( S and ( P or D ))))         |
| 6E   | S xor ( D and ( P or ( notS )))                  |
| 6F   | not( P and ( not( D xor S )))                    |
| 70   | P and ( not( D and S ))                          |
| 71   | not( S xor (( S xor D ) and ( P xor D )))        |
| 72   | S xor ( D or ( P xor S ))                        |
| 73   | not( S and ( D or ( notP )))                     |
| 74   | D xor ( S or ( P xor D ))                        |
| 75   | not( D and ( S or ( notP )))                     |
| 76   | S xor ( D or ( P and ( notS )))                  |
| 77   | not( D and S )                                   |
| 78   | P xor ( D and S )                                |
| 79   | not( D xor ( S xor ( P and ( D or S ))))         |
| 7A   | D xor ( P and ( S or ( notD )))                  |
| 7B   | not( S and ( not( D xor P )))                    |
| 7C   | S xor ( P and ( D or ( notS )))                  |
| 7D   | not( D and ( not( P xor S )))                    |
| 7E   | (S xor P) or (D xor S)                           |
| 7F   | not( D and ( P and S ))                          |

Notes: S = Source Data P = Pattern Data D = Data Already Existing at the Destination



### Table 1-3. Bit-Wise Operations and 8-bit Codes (80 - BF)

| Code | Value Written to Bits at Destination    |
|------|-----------------------------------------|
| 80   | D and ( P and S )                       |
| 81   | not(( S xor P ) or ( D xor S ))         |
| 82   | D and ( not( P xor S ))                 |
| 83   | not( S xor ( P and ( D or ( notS ))))   |
| 84   | S and ( not( D xor P ))                 |
| 85   | not( P xor ( D and ( S or ( notP ))))   |
| 86   | D xor ( S xor ( P and ( D or S )))      |
| 87   | not( P xor ( D and S ))                 |
| 88   | D and S                                 |
| 89   | not( S xor ( D or ( P and ( notS ))))   |
| 8A   | D and ( S or ( notP ))                  |
| 8B   | not( D xor ( S or ( P xor D )))         |
| 8C   | S and ( D or ( notP ))                  |
| 8D   | not( S xor ( D or ( P xor S )))         |
| 8E   | S xor (( S xor D ) and ( P xor D ))     |
| 8F   | not( P and ( not( D and S )))           |
| 90   | P and ( not( D xor S ))                 |
| 91   | not( S xor ( D and ( P or ( notS ))))   |
| 92   | D xor ( P xor ( S and ( D or P )))      |
| 93   | not( S xor ( P and D ))                 |
| 94   | P xor ( S xor ( D and ( P or S )))      |
| 95   | not( D xor ( P and S ))                 |
| 96   | D xor ( P xor S )                       |
| 97   | P xor ( S xor ( D or ( not( P or S )))) |
| 98   | not( S xor ( D or ( not( P or S ))))    |
| 99   | not( D xor S )                          |
| 9A   | D xor ( P and ( notS ))                 |
| 9B   | not( S xor ( D and ( P or S )))         |
| 9C   | S xor ( P and ( notD ))                 |
| 9D   | not( D xor ( S and ( P or D )))         |
| 9E   | D xor ( S xor ( P or ( D and S )))      |
| 9F   | not( P and ( D xor S ))                 |

| Code | Value Written to Bits at Destination  |
|------|---------------------------------------|
| A0   | D and P                               |
| A1   | not( P xor ( D or ( S and ( notP )))) |
| A2   | D and ( P or ( notS ))                |
| A3   | not( D xor ( P or ( S xor D )))       |
| A4   | not( P xor ( D or ( not( S or P ))))  |
| A5   | not( P xor D )                        |
| A6   | D xor ( S and ( notP ))               |
| A7   | not( P xor ( D and ( S or P )))       |
| A8   | D and ( P or S )                      |
| A9   | not( D xor ( P or S ))                |
| AA   | D                                     |
| AB   | D or ( not( P or S))                  |
| AC   | S xor (P and ( D xor S ))             |
| AD   | not( D xor ( P or ( S and D )))       |
| AE   | D or ( S and ( notP ))                |
| AF   | D or ( notP )                         |
| B0   | P and ( D or ( notS ))                |
| B1   | not( P xor ( D or ( S xor P )))       |
| B2   | S xor (( S xor P ) or ( D xor S ))    |
| B3   | not( S and ( not( D and P )))         |
| B4   | P xor ( S and ( notD ))               |
| B5   | not( D xor ( P and ( S or D )))       |
| B6   | D xor ( P xor ( S or ( D and P )))    |
| B7   | not( S and ( D xor P ))               |
| B8   | P xor ( S and ( D xor P ))            |
| B9   | not( D xor ( S or ( P and D )))       |
| BA   | D or ( P and ( notS ))                |
| BB   | D or ( notS )                         |
| BC   | S xor ( P and ( not( D and S )))      |
| BD   | not(( S xor D ) and ( P xor D ))      |
| BE   | D or ( P xor S )                      |
| BF   | D or ( not( P and S ))                |

**Notes:** S = Source Data

P = Pattern Data D = Data Already Existing at the Destination



| Code | Value Written to Bits at Destination  |
|------|---------------------------------------|
| C0   | P and S                               |
| C1   | not( S xor ( P or ( D and ( notS )))) |
| C2   | not( S xor ( P or ( not( D or S ))))  |
| C3   | not( P xor S )                        |
| C4   | S and ( P or ( notD ))                |
| C5   | not( S xor ( P or ( D xor S )))       |
| C6   | S xor ( D and ( notP ))               |
| C7   | not( P xor ( S and ( D or P )))       |
| C8   | S and ( D or P )                      |
| C9   | not( S xor ( P or D ))                |
| CA   | D xor ( P and ( S xor D ))            |
| СВ   | not( S xor ( P or ( D and S )))       |
| CC   | S                                     |
| CD   | S or ( not( D or P ))                 |
| CE   | S or ( D and ( notP ))                |
| CF   | S or ( notP )                         |
| D0   | P and ( S or ( notD ))                |
| D1   | not( P xor ( S or ( D xor P )))       |
| D2   | P xor ( D and ( notS ))               |
| D3   | not( S xor ( P and ( D or S )))       |
| D4   | S xor (( S xor P ) and ( P xor D ))   |
| D5   | not( D and ( not( P and S )))         |
| D6   | P xor ( S xor ( D or ( P and S )))    |
| D7   | not( D and ( P xor S ))               |
| D8   | P xor ( D and ( S xor P ))            |
| D9   | not( S xor ( D or ( P and S )))       |
| DA   | D xor ( P and ( not( S and D )))      |
| DB   | not(( S xor P ) and ( D xor S ))      |
| DC   | S or ( P and ( notD ))                |
| DD   | S or ( notD )                         |
| DE   | S or ( D xor P )                      |
| DF   | S or ( not( D and P ))                |

### Table 1-4. Bit-Wise Operations and 8-bit Codes (C0 - FF)

| Code | Value Written to Bits at Destination            |
|------|-------------------------------------------------|
| E0   | P and ( D or S )                                |
| E1   | not( P xor ( D or S ))                          |
| E2   | D xor ( S and ( P xor D ))                      |
| E3   | not( P xor ( S or ( D and P )))                 |
| E4   | S xor ( D and ( P xor S ))                      |
| E5   | not( P xor ( D or ( S and P )))                 |
| E6   | S xor ( D and ( not( P and S )))                |
| E7   | not(( S xor P ) and ( P xor D ))                |
| E8   | S xor (( S xor P ) and ( D xor S ))             |
| E9   | not( D xor ( S xor ( P and ( not( D and S ))))) |
| EA   | D or ( P and S )                                |
| EB   | D or ( not( P xor S ))                          |
| EC   | S or ( D and P )                                |
| ED   | S or ( not( D xor P ))                          |
| EE   | D or S                                          |
| EF   | S or ( D or ( notP ))                           |
| F0   | Р                                               |
| F1   | P or ( not( D or S ))                           |
| F2   | P or ( D and ( notS ))                          |
| F3   | P or ( notS )                                   |
| F4   | P or ( S and ( notD ))                          |
| F5   | P or ( notD )                                   |
| F6   | P or ( D xor S )                                |
| F7   | P or ( not( D and S ))                          |
| F8   | P or ( D and S )                                |
| F9   | P or ( not( D xor S ))                          |
| FA   | D or P                                          |
| FB   | D or ( P or ( notS ))                           |
| FC   | P or S                                          |
| FD   | P or ( S or ( notD ))                           |
| FE   | D or ( P or S )                                 |
| FF   | writes all 1's                                  |
|      |                                                 |

Notes: S = Source Data

P = Pattern Data D = Data Already Existing at the Destination



### 1.2.1.4 Per-Pixel Write-Masking Operations

The BLT engine is able to perform per-pixel write-masking with various data sources used as pixel masks to constrain which pixels at the destination are to be written to by the BLT engine. As shown in the figure below, either monochrome source or monochrome pattern data may be used as pixel masks. Color pattern data cannot be used. Another available pixel mask is derived by comparing a particular color range per color channel to either the color already specified for a given pixel at the destination or source.





The command packets can specify the monochrome source or the monochrome pattern data as a pixel mask. When this feature is used, the bits that carry a value of 0 cause the bytes of the corresponding pixel at the destination to not be written to by the BLT engine, thereby preserving whatever data was originally carried within those bytes. This feature can be used in writing characters to the display, while also preserving the pre-existing backgrounds behind those characters. When both operands are in the transparent mode, the logical AND of the 2 operands are used for the write enables per pixel.

The 3-bit field, destination transparency mode, within the command packets can select per-pixel writemasking with a mask based on the results of color comparisons. The monochrome source background and foreground are range compared with either the bytes for the pixels at the destination or the source operand. This operation is described in the BLT command packet and register descriptions.



### 1.2.1.5 When the Source and Destination Locations Overlap

It is possible to have BLT operations in which the locations of the source and destination data overlap. This frequently occurs in BLT operations where a user is shifting the position of a graphical item on the display by only a few pixels. In these situations, the BLT engine must be programmed so that destination data is not written into destination locations that overlap with source locations before the source data at those locations has been read. Otherwise, the source data will become corrupted. The XY commands determine whether there is an overlap and perform the accesses in the proper direction to avoid data corruption.

The following figure shows how the source data can be corrupted when a rectangular block is copied from a source location to an overlapping destination location. The BLT engine typically reads from the source location and writes to the destination location starting with the left-most pixel in the top-most line of both, as shown in step (a). As shown in step (b), corruption of the source data has already started with the copying of the top-most line in step (a) — part of the source that originally contained lighter-colored pixels has now been overwritten with darker-colored pixels. More source data corruption occurs as steps (b) through (d) are performed. At step (e), another line of the source data is read, but the two right-most pixels of this line are in the region where the source and destination locations overlap, and where the source has already been overwritten as a result of the copying of the top-most line in step (a). Starting in step (f), darker-colored pixels can be seen in the destination where lighter-colored pixels should be. This errant effect occurs repeatedly throughout the remaining steps in this BLT operation. As more lines are copied from the source location to the destination location, it becomes clear that the end result is not what was originally intended.









The BLT engine can alter the order in which source data is read and destination data is written when necessary to avoid source data corruption problems when the source and destination locations overlap. The command packets provide the ability to change the point at which the BLT engine begins reading and writing data from the upper left-hand corner (the usual starting point) to one of the other three corners. The BLT engine may be set to read data from the source and write it to the destination starting at any of the four corners of the panel.

The XY command packets perform the necessary comparisons and start at the proper corner of each operand which avoids data corruption.





#### Figure 1-4. Correctly Performed BLT with Overlapping Source and Destination Locations



The following figure illustrates how this feature of the BLT engine can be used to perform the same BLT operation as was illustrated in the figure above, while avoiding the corruption of source data. As shown in the figure below, the BLT engine reads the source data and writes the data to the destination starting with the right-most pixel of the bottom-most line. By doing this, no pixel existing where the source and destination locations overlap will ever be written to before it is read from by the BLT engine. By the time the BLT operation has reached step (e) where two pixels existing where the source and destination locations overlap are about to be over written, the source data for those two pixels has already been read.



#### Figure 1-5. Suggested Starting Points for Possible Source and Destination Overlap Situations

The figure above shows the recommended lines and pixels to be used as starting points in each of 8 possible ways in which the source and destination locations may overlap. In general, the starting point should be within the area in which the source and destination overlap.



# **1.2.2 Basic Graphics Data Considerations**

### 1.2.2.1 Contiguous vs. Discontinuous Graphics Data

Graphics data stored in memory, particularly in the frame buffer of a graphics system, has organizational characteristics that often distinguish it from other varieties of data. The main distinctive feature is the tendency for graphics data to be organized in a discontinuous block of graphics data made up of multiple sub-blocks of bytes, instead of a single contiguous block of bytes.

#### Figure 1-6. Representation of On-Screen Single 6-Pixel Line in the Frame Buffer



The figure above shows an example of contiguous graphics data — a horizontal line made up of six adjacent pixels within a single scan line on a display with a resolution of 640x480. Presuming that the graphics system driving this display has been set to 8 bits per pixel and that the frame buffer's starting address of 0h corresponds to the upper left-most pixel of this display, then the six pixels that make this horizontal line starting at coordinates (256, 256) occupies the six bytes starting at frame buffer address 28100h, and ending at address 28105h.

In this case, there is only one scan line's worth of graphics data in this single horizontal line, so the block of graphics data for all six of these pixels exists as a single, contiguous block comprised of only these six bytes. The starting address and the number of bytes are the only pieces of information that a BLT engine would require to read this block of data.



The simplicity of the above example of a single horizontal line contrasts sharply to the example of discontinuous graphics data depicted in the figure below. The simple six-pixel line of the figure above is now accompanied by three more six-pixel lines placed on subsequent scan lines, resulting in the 6x4 block of pixels shown.



#### Figure 1-7. Representation of On-Screen 6x4 Array of Pixels in the Frame Buffer

Since there are other pixels on each of the scan lines on which this 6x4 block exists that are not part of this 6x4 block, what appears to be a single 6x4 block of pixels on the display must be represented by a discontinuous block of graphics data made up of 4 separate sub-blocks of six bytes apiece in the frame buffer at addresses 28100h, 28380h, 28600h, and 28880h. This situation makes the task of reading what appears to be a simple 6x4 block of pixels more complex. However, there are two characteristics of this 6x4 block of pixels that help simplify the task of specifying the locations of all 24 bytes of this discontinuous block of graphics data: all four of the sub-blocks are of the same length, and the four sub-blocks are separated from each other at equal intervals.

The BLT engine is designed to make use of these characteristics of graphics data to simplify the programming required to handle discontinuous blocks of graphics data. For such a situation, the BLT engine requires only four pieces of information: the starting address of the first sub-block, the length of a sub-block, the offset (in bytes), pitch, of the starting address of each subsequent sub-block, and the quantity of sub-blocks.



### 1.2.2.2 Source Data

The source data may exist in the frame buffer or elsewhere in the graphics aperture where the BLT engine may read it directly, or it may be provided to the BLT engine by the host CPU through the command packets. The block of source graphics data may be either contiguous or discontinuous, and may be either in color (with a color depth that matches that to which the BLT engine has been set) or monochrome.

The source select bit in the command packets specifies whether the source data exists in the frame buffer or is provided through the command packets. Monochrome source data is always specified as being supplied through an immediate command packet.

If the color source data resides within the frame buffer or elsewhere in the graphics aperture, then the Source Address Register, specified in the command packets is used to specify the address of the source.

In cases where the host CPU provides the source data, it does so by writing the source data to ring buffer directly after the BLT command that requires the data or uses an IMMEDIATE\_INDIRECT\_BLT command packet which has a size and pointer to the operand in Graphics aperture.

The block of bytes sent by the host CPU through the command packets must be quadword-aligned and the source data contained within the block of bytes must also be aligned.

To accommodate discontinuous source data, the source and destination pitch registers can be used to specify the offset in bytes from the beginning of one scan line's worth source data to the next. Otherwise, if the source data is contiguous, then an offset equal to the length of a scan line's worth of source data should be specified.

### 1.2.2.3 Monochrome Source Data

The opcode of the command packet specifies whether the source data is color or monochrome. Since monochrome graphics data only uses one bit per pixel, each byte of monochrome source data typically carries data for 8 pixels which hinders the use of byte-oriented parameters when specifying the location and size of valid source data. Some additional parameters must be specified to ensure the proper reading and use of monochrome source data by the BLT engine. The BLT engine also provides additional options for the manipulation of monochrome source data versus color source data.

The various bit-wise logical operations and per-pixel write-masking operations were designed to work with color data. In order to use monochrome data, the BLT engine converts it into color through a process called color expansion, which takes place as a BLT operation is performed. In color expansion the single bits of monochrome source data are converted into one, two, or four bytes (depending on the color depth) of color data that are set to carry value corresponding to either the foreground or background color that have been specified for use in this conversion process. If a given bit of monochrome source data carries a value of 1, then the byte(s) of color data resulting from the conversion process will be set to carry the value of the foreground color. If a given bit of monochrome source data carries a value of 0, then the resulting byte(s) will be set to the value of the background color. The foreground and background colors used in the color expansion of monochrome source data can be set in the source expansion foreground color register and the source expansion background color register.

The BLT Engine requires that the bit alignment of each scan line's worth of monochrome source data be specified. Each scan line's worth of monochrome source data is word aligned but can actually start on any bit boundary of the first byte. Monochrome text is special cased and it is bit or byte packed, where in bit packed there are no invalid pixels (bits) between scan lines. There is a 3 bit field which indicates the starting pixel position within the first byte for each scan line, Mono Source Start.



The BLT engine also provides various clipping options for use with specific BLT commands (BLT\_TEXT) with a monochrome source. Clipping is supported through: Clip rectangle Y addresses or coordinates and X coordinates along with scan line starting and ending addresses (with Y addresses) along with X starting and ending coordinates.

The maximum immediate source size is 128 bytes.

### 1.2.2.4 Pattern Data

The color pattern data must exist within the frame buffer or Graphics aperture where the BLT engine may read it directly or it can be sent through the command stream. The pattern data must be located in linear memory. Monochrome pattern data is supplied by the command packet when it is to be used. As shown in figure below, the block of pattern graphics data always represents a block of 8x8 pixels. The bits or bytes of a block of pattern data may be organized in the frame buffer memory in only one of three ways, depending upon its color depth which may be 8, 16, or 32 bits per pixel (whichever matches the color depth to which the BLT engine has been set), or monochrome.

The maximum color pattern size is 256 bytes.

#### Figure 1-8. Pattern Data -- Always an 8x8 Array of Pixels



The Pattern Address Register is used to specify the address of the color pattern data at which the block of pattern data begins. The three least significant bits of the address written to this register are ignored, because the address must be in terms of quadwords. This is because the pattern must always be located on an address boundary equal to its size. Monochrome patterns take up 8 bytes, or a single quadword of space, and are loaded through the command packet that uses it. Similarly, color patterns with color depths of 8, 16, and 32 bits per pixel must start on 64-byte, 128-byte and 256-byte boundaries, respectively. The next 3 figures show how monochrome, 8bpp, 16bpp, and 32bpp pattern data , respectively, is organized in memory.



| 63 5         | 7 56 | 48 | 47 | 40 | 39 | 32 | 31 | 24 | 23 | 16 | 15 | 8 | 7       | 0     |         |
|--------------|------|----|----|----|----|----|----|----|----|----|----|---|---------|-------|---------|
| Pixel (0, 7) | )    |    |    |    |    |    |    |    |    |    |    |   | Pixel ( | 0, 0) | 00h     |
|              |      |    |    |    |    |    |    |    |    |    |    |   |         |       | 08h     |
|              |      |    |    |    |    |    |    |    |    |    |    |   |         |       | 10h     |
|              |      |    |    |    |    |    |    |    |    |    |    |   |         |       | 18h     |
|              |      |    |    |    |    |    |    |    |    |    |    |   |         |       | 20h     |
|              |      |    |    |    |    |    |    |    |    |    |    |   |         |       | 28h     |
|              |      |    |    |    |    |    |    |    |    |    |    |   |         |       | 30h     |
| Pixel (7, 7) | )    |    |    |    |    |    |    |    |    |    |    |   | Pixel ( | 7, 0) | 38h     |
|              |      |    |    |    |    |    |    |    |    |    |    |   |         | B     | 6764-01 |

#### Figure 1-9. 8bpp Pattern Data -- Occupies 64 Bytes (8 quadwords)

#### Figure 1-10. 16bpp Pattern Data -- Occupies 128 Bytes (16 quadwords)

| 63      | 48     | 47 | 32 | 31 | 16 1 | 5            | 0            |
|---------|--------|----|----|----|------|--------------|--------------|
|         |        |    |    |    |      | Pixel (0, 0) | 00h          |
| Pixel ( | (7, 0) |    |    |    |      |              | 08h          |
|         |        |    |    |    |      |              | 7            |
|         |        |    |    |    |      |              |              |
|         |        |    |    |    |      |              | 68h          |
|         |        |    |    |    |      |              | 70h          |
| Pixel ( | (7,7)  |    |    |    |      | Pixel (0, 7) | 78h          |
|         |        |    |    |    | •    |              | <br>P4745_01 |
|         |        |    |    |    |      |              | B6765-01     |

#### Figure 1-11. 32bpp Pattern Data -- Occupies 256 Bytes (32 quadwords)





The opcode of the command packet specifies whether the pattern data is color or monochrome. The various bit-wise logical operations and per-pixel write-masking operations were designed to work with color data. In order to use monochrome pattern data, the BLT engine is designed to convert it into color



through a process called "color expansion" which takes place as a BLT operation is performed. In color expansion, the single bits of monochrome pattern data are converted into one, two, or four bytes (depending on the color depth) of color data that are set to carry values corresponding to either the foreground or background color that have been specified for use in this process. The foreground color is used for pixels corresponding to a bit of monochrome pattern data that carry the value of 1, while the background color is used where the corresponding bit of monochrome pattern data carries the value of 0. The foreground and background colors used in the color expansion of monochrome pattern data can be set in the Pattern Expansion Foreground Color Register and Pattern Expansion Background Color Register.

### 1.2.2.5 Destination Data

There are actually two different types of "destination data": the graphics data already residing at the location that is designated as the destination, and the data that is to be written into that very same location as a result of a BLT operation.

The location designated as the destination must be within the frame buffer or Graphics aperture where the BLT engine can read from it and write to it directly. The blocks of destination data to be read from and written to the destination may be either contiguous or discontinuous. All data written to the destination will have the color depth to which the BLT engine has been set. It is presumed that any data already existing at the destination which will be read by the BLT engine will also be of this same color depth — the BLT engine neither reads nor writes monochrome destination data.

The Destination Address Register is used to specify the address of the destination.

To accommodate discontinuous destination data, the Source and Destination Pitch Registers can be used to specify the offset in bytes from the beginning of one scan line's worth of destination data to the next. Otherwise, if the destination data is contiguous, then an offset equal to the length of a scan line's worth of destination data should be specified.

# **1.2.3 BLT Programming Examples**

### 1.2.3.1 Pattern Fill — A Very Simple BLT

In this example, a rectangular area on the screen is to be filled with a color pattern stored as pattern data in off-screen memory. The screen has a resolution of 1024x768 and the graphics system has been set to a color depth of 8 bits per pixel.

(intel)



#### Figure 1-12. On-Screen Destination for Example Pattern Fill BLT

As shown in the figure above, the rectangular area to be filled has its upper left-hand corner at coordinates (128, 128) and its lower right-hand corner at coordinates (191, 191). These coordinates define a rectangle covering 64 scan lines, each scan line's worth of which is 64 pixels in length — in other words, an array of 64x64 pixels. Presuming that the pixel at coordinates (0, 0) corresponds to the byte at address 00h in the frame buffer memory, the pixel at (128, 128) corresponds to the byte at address 20080h.





#### Figure 1-13. Pattern Data for Example Pattern Fill BLT

As shown in figure above, the pattern data occupies 64 bytes starting at address 100000h. As always, the pattern data represents an 8x8 array of pixels.

The BLT command packet is used to select the features to be used in this BLT operation, and must be programmed carefully. The vertical alignment field should be set to 0 to select the top-most horizontal row of the pattern as the starting row used in drawing the pattern starting with the top-most scan line covered by the destination. The pattern data is in color with a color depth of 8 bits per pixel, so the dynamic color enable should be asserted with the dynamic color depth field should be set to 0. Since this BLT operation does not use per-pixel write-masking (destination transparency mode), this field should be set to 0. Finally, the raster operation field should be programmed with the 8-bit value of F0h to select the bit-wise logical operation in which a simple copy of the pattern data to the destination takes place. Selecting this bit-wise operation in which no source data is used as an input causes the BLT engine to automatically forego either reading source data from the frame buffer.

The Destination Pitch Register must be programmed with number of bytes in the interval from the start of one scan line's worth of destination data to the next. Since the color depth is 8 bits per pixel and the horizontal resolution of the display is 1024, the value to be programmed into these bits is 400h, which is equal to the decimal value of 1024.

Bits [31:3] of the Pattern Address Register must be programmed with the address of the pattern data.

Similarly, bits [31:0] of the Destination Address Register must be programmed with the byte address at the destination that will be written to first. In this case, the address is 20080h, which corresponds to the byte representing the pixel at coordinates (128, 128).

This BLT operation does not use the values in the Source Address Register or the Source Expansion Background or Foreground Color Registers.

The Destination Width and Height Registers (or the Destination X and Y Coordinates) must be programmed with values that describe to the BLT engine the 64x64 pixel size of the destination location. The height should be set to carry the value of 40h, indicating that the destination location covers 64 scan lines. The width should be set to carry the value of 40h, indicating that each scan line's worth of destination data occupies 64 bytes. All of this information is written to the ring buffer using the PAT\_BLT (or XY\_PAT\_BLT) command packet.

(intel)





The figure above shows the end result of performing this BLT operation. The 8x8 pattern has been repeatedly copied ("tiled") into the entire 64x64 area at the destination.

### **1.2.3.2** Drawing Characters Using a Font Stored in System Memory

In this example BLT operation, a lowercase letter "f" is to be drawn in black on a display with a gray background. The resolution of the display is 1024x768, and the graphics system has been set to a color depth of 8 bits per pixel.





#### Figure 1-15. On-Screen Destination for Example Character Drawing BLT

The figure above shows the display on which this letter "f" is to be drawn. As shown in this figure, the entire display has been filled with a gray color. The letter "f" is to be drawn into an 8x8 region on the display with the upper left-hand corner at the coordinates (128, 128).



#### Figure 1-16. Source Data in System Memory for Example Character Drawing BLT

The figure above shows both the 8x8 pattern making up the letter "f" and how it is represented somewhere in the host's system memory — the actual address in system memory is not important. The letter "f" is represented in system memory by a block of monochrome graphics data that occupies 8 bytes. Each byte carries the 8 bits needed to represent the 8 pixels in each scan line's worth of this graphics data. This type of pattern is often used to store character fonts in system memory.

During this BLT operation, the host CPU will read this representation of the letter "f" from system memory, and write it to the BLT engine by performing memory writes to the ring buffer as an immediate monochrome BLT operand following the BLT\_TEXT command. The BLT engine will receive this data through the command stream and use it as the source data for this BLT operation. The BLT engine will be set to the same color depth as the graphics system — 8 bits per pixel, in this case. Since the source data



in this BLT operation is monochrome, color expansion must be used to convert it to an 8 bpp color depth. To ensure that the gray background behind this letter "f" is preserved, per-pixel write masking will be performed, using the monochrome source data as the pixel mask.

The BLT Setup and Text\_immediate command packets are used to select the features to be used in this BLT operation. Only the fields required by these two command packets must be programmed carefully. The BLT engine ignores all other registers and fields. The source select field in the Text\_immediate command must be set to 1, to indicate that the source data is provided by the host CPU through the command packet. Finally, the raster operation field should be programmed with the 8-bit value CCh to select the bit-wise logical operation that simply copies the source data to the destination. Selecting this bit-wise operation in which no pattern data is used as an input, causes the BLT engine to automatically forego reading pattern data from the frame buffer.

The Setup Pattern/Source Expansion Foreground Color Register to specify the color with which the letter "f" will be drawn. There is no Source address. All scan lines of the glyph are bit packed and the clipping is controlled by the ClipRect registers from the SETUP\_BLT command and the Destination Y1, Y2, X1, and X2 registers in the TEXT\_BLT command. Only the pixels that are within (inclusive comparisons) the clip rectangle are written to the destination surface.

The Destination Pitch Register must be programmed with a value equal to the number of bytes in the interval between the first bytes of each adjacent scan line's worth of destination data. Since the color depth is 8 bits per pixel and the horizontal resolution of the display is 1024 pixels, the value to be programmed into these bits is 400h, which is equal to the decimal value of 1024. Since the source data used in this BLT operation is monochrome, the BLT engine will not use a byte-oriented pitch value for the source data.

Since the source data is monochrome, color expansion is required to convert it to color with a color depth of 8 bits per pixel. Since the Setup Pattern/Source Expansion Foreground Color Register is selected to specify the foreground color of black to be used in drawing the letter "f", this register must be programmed with the value for that color. With the graphics system set for a color depth of 8 bits per pixel, the actual colors are specified in the RAMDAC palette, and the 8 bits stored in the frame buffer for each pixel actually specify the index used to select a color from that palette. This example assumes that the color specified at index 00h in the palette is black, and therefore bits [7:0] of this register should be set to 00h to select black as the foreground color. The BLT engine ignores bits [31:8] of this register because the selected color depth is 8 bits per pixel. Even though the color expansion being performed on the source data normally requires that both the foreground and background colors be specified, the value used to specify the background color is not important in this example. Per-pixel write-masking is being performed with the monochrome source data as the pixel mask, which means that none of the pixels in the source data that will be converted to the background color will ever be written to the destination. Since these pixels will never be seen, the value programmed into the Pattern/Source Expansion Background Color Register to specify a background color is not important.

The Destination Width and Height Registers are not used. The Y1, Y2, X1, and X2 are used to describe to the BLT engine the 8x8 pixel size of the destination location. The Destination Y1 and Y2 address (or coordinate) registers must be programmed with the starting and ending scan line address (or Y coordinates) of the destination data. This address is specified as an offset from the start of the frame buffer of the scan line at the destination that will be written to first. The destination X1 and X2 registers must be programmed with the starting pixel offsets from the beginning of the scan line.

This BLT operation does not use the values in the Pattern Address Register, the Source Expansion Background Color Register, or the Source Expansion Foreground Color Register.





#### Figure 1-17. Results of Example Character Drawing BLT

The preceding shows the end result of performing this BLT operation. Only the pixels that form part of the actual letter "f" have been drawn into the 8x8 destination location on the display, leaving the other pixels within the destination with their original gray color.

# **1.3 BLT Instruction Overview**

This chapter defines the instructions used to control the 2D (BLT) rendering function.

The instructions detailed in this chapter are used across devices. However, slight changes may be present in some instructions (i.e., for features added or removed), or some instructions may be removed entirely. Refer to the *Device Dependencies* chapter for summary information regarding device-specific behaviors/interfaces/features.

The XY instructions offload the drivers by providing X and Y coordinates and taking care of the access directions for overlapping BLTs without fields specified by the driver.

Color pixel sizes supported are 8, 16, and 32 bits per pixel (bpp). All pixels are naturally aligned.

# 1.4 BLT Engine State

Most of the BLT instructions are state-free, which means that all states required to execute the command is within the instruction. If clipping is not used, then there is no shared state for many of the BLT instructions. This allows the BLT Engine to be shared by many drivers with minimal synchronization between the drivers.



Instructions which share state are:

All instructions that are X,Y commands and use the Clipping Rectangle by asserting the Clip Enable field

All XY\_Setup Commands (XY\_SETUP\_BLT and XY\_SETUP\_MONO\_PATTERN\_SL\_BLT, XY\_SETUP\_CLIP\_BLT) load the shared state for the following commands:

| XY_PIXEL_BLT          | (Negative Stride (=Pitch) Not Allowed) |
|-----------------------|----------------------------------------|
| XY_SCANLINES_BLT      |                                        |
| XY_TEXT_BLT           | (Negative Stride (=Pitch) Not Allowed) |
| XY_TEXT_IMMEDIATE_BLT | (Negative Stride (=Pitch) Not Allowed) |

State registers that are saved and restored in the Logical Context:

- BR1+ Setup Control (Solid Pattern Select, Clipping Enable, Mono Source Transparency Mode, Mono Pattern Transparency Mode, Color Depth[1:0], Raster Operation[7:0], & Destination Pitch[15:0]) + 32bpp Channel Mask[1:0], Mono / Color Pattern
- BR05 Setup Background Color
- BR06 Setup Foreground Color
- BR07 Setup Pattern Base Address
- BR09 Setup Destination Base Address
- BR20 DW0 for a Monochrome Pattern
- BR21 DW1 for a Monochrome Pattern
- BR24 ClipRectY1'X1
- BR25 ClipRectY2'X2

# **1.5 Cacheable Memory Support**

The BLT Engine can be used to transfer data <u>between</u> cacheable ("system") memory and uncached ("main", or "UC") graphics memory using the BLT instructions. The GTT must be properly programmed to map memory pages as cacheable or UC. Only linear-mapped (not tiled) surfaces can be mapped as cacheable.

Transfers between cacheable sources and cacheable destinations are <u>not</u> supported. Patterns and monochrome sources can not be located in cacheable memory.

Cacheable write operands <u>do not snoop</u> the processor's cache nor update memory until evicted from the render cache. Cacheable read or write operands are not snooped (nor invalidated) from either internal cache by external (processor, hublink,...) accesses.



# **1.6 Device Cache Coherency: Render & Texture Caches**

Software must initiate cache flushes to enforce coherency between the render and texture caches, i.e., both the render and texture caches must be flushed before a BLT destination surface can be reused as a texture source. Color sources and destinations use the render cache, while patterns and monochrome sources use the texture cache.

# **1.7 BLT Engine Instructions**

The Instruction Target field is used as an opcode by the BLT Engine state machine to qualify the control bits that are relevant for executing the instruction. The descriptions for each DWord and bit field are contained in the *BLT Engine Instruction Field Definition* section. Each DWord field is described as a register, but none of these registers can be written of read through a memory mapped location – they are internal state only.

### 1.7.1 Blt Programming Restrictions

Overlapping Source/Destination BLTs: The following condition must be avoided when programming the Blt engine: Linear surfaces with a cache line in scan line Y for the source stream overlapping with a cache line in scan line Y-1 for the dest stream (=> non-aligned surface pitches). The cache coherency rules combined with the Blitter data consumption rules result in UNDEFINED operation. (Note that this restriction will likely follow forward to future products due to architectural complexities.) There are two suggested software workarounds:

In order to perform coherent overlapping Blts, (a) the Source and Destination Base Address registers must hold the same value (without alignment restriction), and (b) the Source and Destination Pitch registers (BR11,BR13) must both be a multiple of 64 bytes.

If (a) isn't possible, do overlapping source copy BLTs as two blits, using a separate intermediate surface.

All reserved fields must be programmed to 0s.

When using monosource or text data (bit/byte/word aligned): do not program pixel widths greater than 32,745 pixels.

**Ring Buffer Programming [Dev ILK only:WA]:** Driver should make sure the first 3D command after the engine switch from BLT is not to be

- 1. DrawCall
- 2. Curbe
- 3. Media Object

The other way to do this is driver should always program a dummy 3D

NON-PIPELINE state following the BLT commands.

**Immediate Commands [DevSNB]** There must be at least 1 command after any immediate blitter commands before head == tail. This can be a simple MI\_NOOP.



# **1.8 Fill/Move Instructions**

These instructions use linear addresses with width and height. BLT clipping is not supported.

# 1.8.1 COLOR\_BLT (Fill)

COLOR\_BLT is the simplest BLT operation. It performs a color fill to the destination (with a possible ROP). The only operand is the destination operand which is written dependent on the raster operation. The solid pattern color is stored in the pattern background register.

This instruction is optimized to run at the maximum memory write bandwidth.

The typical Raster operation code = F0 which performs a copy of the pattern background register to the destination.

| DWord    | Bit   | Description                                                                                                        |
|----------|-------|--------------------------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                                                         |
|          | 28:22 | Instruction Target (Opcode): 40h                                                                                   |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)                                    |
|          | 19:05 | <b>Reserved.</b> Note no tiling specification allowed for this non-XY blit command. Only linear blits are allowed. |
|          | 04:00 | DWord Length: 03h                                                                                                  |
| 1 = BR13 | 31:26 | Reserved.                                                                                                          |
|          | 25:24 | Color Depth:                                                                                                       |
|          |       | 00 = 8 bit color.                                                                                                  |
|          |       | 01 = 16 bit color (656).                                                                                           |
|          |       | 10 = 16 bit color (1555).                                                                                          |
|          |       | 11 = 32 bit color                                                                                                  |
|          | 23:16 | Raster Operation:                                                                                                  |
|          | 15:00 | Destination Pitch (signed): Destination pitch in bytes (Same as before).                                           |
| 2 = BR14 | 31:16 | Destination Height (in scan lines):                                                                                |
|          | 15:00 | Destination Width (in bytes):                                                                                      |
| 3 = BR09 | 31:00 | Destination Address: Address of the first byte to be written                                                       |
| 4 = BR16 | 31:00 | Solid Pattern Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                               |

# 1.8.2 SRC\_COPY\_BLT (Move)

This BLT instruction performs a color source copy where the only operands involved is a color source and destination of the same bit width.

The source and destination operands may overlap. The command must indicate the horizontal and vertical directions: either forward or backwards to avoid data corruption. The X direction (horizontal) field applies to both the destination and source operands. The source and destination pitches (stride) are signed.



| DWord    | Bit   | Description                                                                                                        |
|----------|-------|--------------------------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h – 2D Processor                                                                                         |
|          | 28:22 | Instruction Target (Opcode) : 43h                                                                                  |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)                                    |
|          | 19:05 | <b>Reserved.</b> Note no tiling specification allowed for this non-XY blit command. Only linear blits are allowed. |
|          | 04:00 | Dword Length: 04h                                                                                                  |
| 1 = BR13 | 31    | Reserved.                                                                                                          |
|          | 30    | <b>X Direction</b> (1 = written from right to left (decrementing = backwards); 0 = incrementing)                   |
|          | 29:26 | Reserved.                                                                                                          |
|          | 25:24 | Color Depth:                                                                                                       |
|          |       | 00 = 8 bit color                                                                                                   |
|          |       | 01 = 16 bit color (565)                                                                                            |
|          |       | 10 = 16 bit color (1555)                                                                                           |
|          |       | 11 = 32 bit color                                                                                                  |
|          | 23:16 | Raster Operation:                                                                                                  |
|          | 15:00 | Destination Pitch (signed): Destination pitch in bytes (Same as before).                                           |
| 2 = BR14 | 31:16 | Destination Height (in scan lines):                                                                                |
|          | 15:00 | Destination Width (in bytes):                                                                                      |
| 3 = BR09 | 31:00 | Destination Address: Address of the first byte to be written                                                       |
|          | 31:14 | Reserved.                                                                                                          |
| 4 = BR11 | 15:00 | Source Pitch: (double word aligned and signed)                                                                     |
| 5 = BR12 | 31:00 | Source Address: Address of the first byte to be read.                                                              |

# 1.9 2D (X,Y) BLT Instructions

Most BLT instructions (prefixed with "XY\_") use 2D X,Y coordinate specifications vs. lower-level linear addresses. These instructions also support simple 2D clipping against a clip rectangle.

The top and left Clipping coordinates are inclusive. The bottom and right coordinates are exclusive. The BLT Engine performs a trivial reject for all CLIP BLT instructions before performing any accesses.

Negative destination and source coordinates are supported. In the case of negative source coordinates, the destination X1 and Y1 are modified by the absolute value of the negative source coordinate before the destination clip checking and final drawing coordinates are calculated. The absolute value of the source negative coordinate is added to the corresponding destination coordinate. The BLT engine clipping also checks for (DX2 [ or = DX1) or (DY2 [ or = DY1) after this calculation and if true, then the BLT is totally rejected.





DX1, DY1, CX1, and CY1 are inclusive, while DX2, DY2, CX2, and CY2 are exclusive.

Destination pixel address = (Destination Base Address + (Destination Y coordinate \* Destination pitch) + (Destination X coordinate \* bytes per pixel)).

Source pixel address = (Source Base Address + (Source Y coordinate \* Source pitch) + (Source X coordinate \* bytes per pixel)).

Since there is 1 set of Clip Rectangle registers, the Interrupt Ring BLT commands either MUST NEVER enable clipping with these command and never use the XY\_Pixel\_BLT, XY\_Scanline\_BLT, nor XY\_Text\_BLT commands or it must use context switching. The Interrupt rings can also use the non-clipped, linear address commands specified before this section.

The base addresses plus the X and Y coordinates determine if there is an overlap between the source and destination operands. If the base addresses of the source and destination are the same and the Source X1 is **less than** Destination X1, then the BLT Engine performs the accesses in the X-backwards access pattern. There is no need to look for an actual overlap. If the base addresses are the same and





Source Y1 is less than Destination Y1, then the scan line accesses are performed backwards.

# 1.9.1 XY\_SETUP\_BLT

This setup instruction supplies common setup information including clipping coordinates used by the XY commands: XY\_PIXEL\_BLT, XY\_SCANLINE\_BLT, XY\_TEXT\_BLT, and XY\_TEXT\_BLT\_IMMEDIATE.

These are the only instructions that require that state be saved between instructions other than the Clipping parameters. There are 5 dedicated registers to contain the state for the 3 setup BLT instructions (XY\_SETUP\_BLT, XY\_SETUP\_MONO\_PATTERN\_SL\_BLT, and XY\_SETUP\_CLIP\_BLT. All other BLTs use a temporary version of these. The 5 double word registers are: DW1 (Setup Control), DW6 (Setup



Foreground color), DW5 (Setup Background color), DW7 (Setup Pattern address), and DW4 (Setup Destination Base Address).

| DWord    | Bit    | Description                                                                                                                                                |
|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29  | Client: 02h - 2D Processor                                                                                                                                 |
|          | 28:22  | Instruction Target (Opcode): 01h                                                                                                                           |
|          | 21:20  | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)                                                                            |
|          | 19:12  | Reserved.                                                                                                                                                  |
|          | 11     | Tiling Enable:                                                                                                                                             |
|          |        | 0 = Tiling Disabled (Linear blit)<br>1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                              |
|          | 10: 08 | Reserved                                                                                                                                                   |
|          | 07:00  | Dword Length: 06h                                                                                                                                          |
| 1 = BR01 | 31     | Reserved.                                                                                                                                                  |
|          | 30     | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                               |
|          | 29     | Mono Source Transparency Mode: (1 = transparency enabled; 0 = use background)                                                                              |
|          | 28:26  | Reserved.                                                                                                                                                  |
|          | 25:24  | Color Depth: All                                                                                                                                           |
|          |        | 00 = 8 bit color<br>01 = 16 bit color (565)<br>10 = 16 bit color (1555)<br>11 = 32 bit color                                                               |
|          | 23:16  | Raster Operation:                                                                                                                                          |
|          | 15:00  | <b>Destination Pitch in DWords:</b> [15:00] 2's complement (Negative Pitch Not allowed for Pixel nor Text)                                                 |
|          |        | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |
| 2 = BR24 | 31:16  | ClipRect Y1 Coordinate (Top): (30:16 = 15 bit positive number)                                                                                             |
|          | 15:00  | ClipRect X1 Coordinate (Left): (14:00 = 15 bit positive number)                                                                                            |
| 3 = BR25 | 31:16  | ClipRect Y2 Coordinate (Bottom): (30:16 = 15 bit positive number)                                                                                          |
|          | 15:00  | ClipRect X2 Coordinate (Right): (14:00 = 15 bit positive number)                                                                                           |
| 4 = BR09 | 31:00  | Setup Destination Base Address: (base address of the destination surface: X=0, Y=0)                                                                        |
|          |        | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                               |
| 5 = BR05 | 31:00  | Setup Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0] All                                                                                |
| 6 = BR06 | 31:00  | Setup Foreground Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0] (SLB & TB only)                                                                    |
| 7 = BR07 | 31:00  | Setup Pattern Base Address for Color Pattern: (26:06 are implemented) (SLB only)                                                                           |
|          |        | (Note no NPO2 change here). The pattern data must be located in linear memory.                                                                             |



### 1.9.2 XY\_SETUP\_MONO\_PATTERN\_SL\_BLT

This setup instruction supplies common setup information including clipping coordinates used exclusively with the following instruction: XY\_SCANLINE\_BLT (SLB) - 1 scan line of monochrome pattern and destination are the only operands allowed.

| DWord    | Bit    | Description                                                                                                                                                     |
|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29  | Client: 02h - 2D Processor                                                                                                                                      |
|          | 28:22  | Instruction Target (Opcode): 11h                                                                                                                                |
|          | 21:20  | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)                                                                                 |
|          | 19:12  | Reserved.                                                                                                                                                       |
|          | 11     | Tiling Enable:                                                                                                                                                  |
|          |        | 0 = Tiling Disabled (Linear blit)                                                                                                                               |
|          |        | 1 = Tiling enabled ( <u>pre-DevSNB</u> : Tile-X only. <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                       |
|          | 10: 08 | Reserved                                                                                                                                                        |
|          | 07:00  | Dword Length: 07h                                                                                                                                               |
| 1 = BR01 | 31     | Solid Pattern Select: (1 = solid pattern; 0 = no solid pattern) - (SLB & Pixel only)                                                                            |
|          | 30     | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                                    |
|          | 29     | Reserved.                                                                                                                                                       |
|          | 28     | Mono Pattern Transparency Mode: (1 = transparency enabled; 0 = use background)                                                                                  |
|          | 27:26  | Reserved.                                                                                                                                                       |
|          | 25:24  | Color Depth:                                                                                                                                                    |
|          |        | 00 = 8 bit color<br>01 = 16 bit color (565)<br>10 = 16 bit color (1555)<br>11 = 32 bit color                                                                    |
|          | 23:16  | Raster Operation:                                                                                                                                               |
|          | 15:00  | <b>Destination Pitch in DWords:</b> [15:00] 2's complement (Negative Pitch Not allowed for Pixel nor Text)                                                      |
|          |        | For Tiled surfaces (bit_11 enabled) this this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |
| 2 = BR24 | 31:16  | ClipRect Y1 Coordinate (Top): (30:16 = 15 bit positive number)                                                                                                  |
|          | 15:00  | ClipRect X1 Coordinate (Left): (14:00 = 15 bit positive number)                                                                                                 |
| 3 = BR25 | 31:16  | ClipRect Y2 Coordinate (Bottom): (30:16 = 15 bit positive number)                                                                                               |
|          | 15:00  | ClipRect X2 Coordinate (Right): (14:00 = 15 bit positive number)                                                                                                |
| 4 = BR09 | 31:00  | Setup Destination Base Address: (base address of the destination surface: X=0, Y=0)                                                                             |
|          |        | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                                    |
| 5 = BR05 | 31:00  | Setup Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                         |



| DWord    | Bit   | Description                                                             |
|----------|-------|-------------------------------------------------------------------------|
| 6 = BR06 | 31:00 | Setup Foreground Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0] |
| 7 = BR20 | 31:00 | DW0 (least significant) for a Monochrome Pattern:                       |
| 8 = BR21 | 31:00 | DW1 (most significant) for a Monochrome Pattern:                        |

# 1.9.3 XY\_SETUP\_CLIP\_ BLT

This command is used to only change the clip coordinate registers. These are the same clipping registers as the Setup clipping registers above.

| DWord    | Bit    | Description                                                       |
|----------|--------|-------------------------------------------------------------------|
| 0 = BR00 | 31:29  | Client: 02h - 2D Processor                                        |
|          | 28:22  | Instruction Target (Opcode): 03h                                  |
|          | 21:12  | Reserved.                                                         |
|          | 11     | Tiling Enable:                                                    |
|          |        | 0 = Tiling Disabled (Linear blit)                                 |
|          |        | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)          |
|          | 10: 08 | Reserved                                                          |
|          | 07:00  | Dword Length: 01h                                                 |
| 1 = BR24 | 31:16  | ClipRect Y1 Coordinate (Top): (30:16 = 15 bit positive number)    |
|          | 15:00  | ClipRect X1 Coordinate (Left): (14:00 = 15 bit positive number)   |
| 2 = BR25 | 31:16  | ClipRect Y2 Coordinate (Bottom): (30:16 = 15 bit positive number) |
|          | 15:00  | ClipRect X2 Coordinate (Right): (14:00 = 15 bit positive number)  |

### 1.9.4 XY\_PIXEL\_BLT

The Destination X coordinate and Destination Y coordinate is compared with the ClipRect registers. If it is within all 4 comparisons, then the pixel supplied in the XY\_SETUP\_BLT instruction is written with the raster operation to (Destination Y Address + (Destination Y coordinate \* Destination pitch) + (Destination X coordinate \* bytes per pixel)).

ROP field must specify pattern or fill with 0's or 1's. There is no source operand.

Negative Stride (= Pitch) specified in the Setup command is Not Allowed

| DWord    | Bit   | Description                      |
|----------|-------|----------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor       |
|          | 28:22 | Instruction Target (Opcode): 24h |
|          | 21:12 | Reserved.                        |
|          | 11    | Tiling Enable:                   |



| DWord    | Bit    | Description                                                      |
|----------|--------|------------------------------------------------------------------|
|          |        | 0 = Tiling Disabled (Linear blit)                                |
|          |        | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)         |
|          | 10: 08 | Reserved                                                         |
|          | 07:00  | Dword Length : 00h                                               |
| 1 = BR22 | 31:16  | Destination Y1 Coordinate (Top): (31:16 = 16 bit signed number)  |
|          | 15:00  | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number) |

### 1.9.5 XY\_SCANLINES\_BLT

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

The Pattern Seeds correspond to Destination X = 0 (horizontal) and Y = 0 (vertical). The alignment is relative to the destination coordinates. The pixel of the pattern used / scan line is the (destination X coordinate + horizontal seed) modulo 8. The scan line of the pattern used is the (destination Y coordinate + vertical seed) modulo 8.

Solid pattern should use the XY\_SETUP\_MONO\_PATTERN\_SL\_BLT instruction.

| DWord    | Bit   | Description                                                                                |
|----------|-------|--------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                                 |
|          | 28:22 | Instruction Target (Opcode): 25h                                                           |
|          | 21:15 | Reserved.                                                                                  |
|          | 14:12 | Pattern Horizontal Seed: (pixel of the scan line to start on corresponding to DST X=0)     |
|          | 11    | Tiling Enable:                                                                             |
|          |       | 0 = Tiling Disabled (Linear blit)                                                          |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                   |
|          | 10:08 | Pattern Vertical Seed: (scan line of the 8x8 pattern to start on corresponding to DST Y=0) |
|          | 07:00 | Dword Length: 01h                                                                          |
| 1 = BR22 | 31:16 | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)                     |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                           |
| 2 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                         |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                          |

ROP field must specify pattern or fill with 0's or 1's. There is no source operand.



# 1.9.6 XY\_TEXT\_BLT

All source scan lines and pixels that fall within the ClipRect Y and X coordinates are written. The source address corresponds to Destination X1 and Y1 coordinate.

Text is either bit or byte packed. Bit packed means that the next scan line starts 1 pixel after the end of the current scan line with no bit padding. Byte packed means that the next scan line starts on the first bit of the next byte boundary after the last bit of the current line.

Source expansion color registers are always in the SETUP\_BLT.

Negative Stride (= Pitch) is NOT ALLOWED.

| DWord    | Bit    | Description                                                                         |
|----------|--------|-------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29  | Client: 02h - 2D Processor                                                          |
|          | 28:22  | Instruction Target (Opcode): 26h                                                    |
|          | 21:17  | Reserved.                                                                           |
|          | 16     | Bit (0) / Byte (1) packed: Byte packed is for the NT driver                         |
|          | 15:12  | Reserved.                                                                           |
|          | 11     | Tiling Enable:                                                                      |
|          |        | 0 = Tiling Disabled (Linear blit)                                                   |
|          |        | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                            |
|          | 10: 08 | Reserved                                                                            |
|          | 07:00  | Dword Length: 02h                                                                   |
| 1 = BR22 | 31:16  | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)              |
|          | 15:00  | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                    |
| 2 = BR23 | 31:16  | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                  |
|          | 15:00  | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                   |
| 3 = BR12 | 31:00  | Source Address: (address of the first byte on scan line corresponding to Dst X1,Y1) |
|          |        | (Note no NPO2 change here)                                                          |

### 1.9.7 XY\_TEXT\_IMMEDIATE\_BLT

This instruction allows the Driver to send data through the instruction stream that eliminates the read latency of reading a source from memory. If an operand is in system cacheable memory and either small or only accessed once, it can be copied directly to the instruction stream versus to graphics accessible memory.

The IMMEDIATE\_BLT data MUST transfer an even number of doublewords. The BLT engine will hang if it does not get an even number of doublewords.

All source scan lines and pixels that fall within the ClipRect X and Y coordinates are written. The source data corresponds to Destination X1 and Y1 coordinate.



Source expansion color registers are always in the SETUP\_BLT.

| DWord           | Bit    | Description                                                         |
|-----------------|--------|---------------------------------------------------------------------|
| 0 = BR00        | 31:29  | Client: 02h – 2D Processor                                          |
|                 | 28:22  | Instruction Target (Opcode): 31h                                    |
|                 | 21:17  | Reserved.                                                           |
|                 | 16     | Bit (0) / Byte (1) packed: Byte packed is for the NT driver         |
|                 | 15:12  | Reserved.                                                           |
|                 | 11     | Tiling Enable:                                                      |
|                 |        | 0 = Tiling Disabled (Linear blit)                                   |
|                 |        | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)            |
|                 | 10: 08 | Reserved                                                            |
|                 | 07:00  | <b>Dword Length</b> : 01+ DWL = (Number of Immediate double words)h |
| 1 = BR22        | 31:16  | Destination Y1 Coordinate (Top): (31:16 = 16 bit signed number)     |
|                 | 15:00  | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)    |
| 2 = BR23        | 31:16  | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)  |
|                 | 15:00  | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)   |
| 3               | 31:00  | Immediate Data DW 0:                                                |
| 4               | 31:00  | Immediate Data DW 1:                                                |
| 5 thru<br>DWL+3 | S      | Immediate Data DWs 2 through DWORD_LENGTH (DWL):                    |

Negative Stride (= Pitch) is NOT ALLOWED.

### 1.9.8 XY\_COLOR\_BLT

COLOR\_BLT is the simplest BLT operation. It performs a color fill to the destination (with a possible ROP). The only operand is the destination operand which is written dependent on the raster operation. The solid pattern color is stored in the pattern background register.

This instruction is optimized to run at the maximum memory write bandwidth.



The typical (and fastest) Raster operation code = F0 which performs a copy of the pattern background register to the destination.

| DWord    | Bit    | Description                                                                                                                                                |
|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29  | Client: 02h - 2D Processor                                                                                                                                 |
|          | 28:22  | Instruction Target (Opcode): 50h                                                                                                                           |
|          | 21:20  | 32 bpp byte mask: (21 =1= write alpha channel; 20=1= write RGB channels)                                                                                   |
|          | 19:12  | Reserved.                                                                                                                                                  |
|          | 11     | Tiling Enable:                                                                                                                                             |
|          |        | 0 = Tiling Disabled (Linear blit)                                                                                                                          |
|          |        | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                                   |
|          | 10: 08 | Reserved                                                                                                                                                   |
|          | 07:00  | Dword Length: 04h                                                                                                                                          |
| 1 = BR13 | 31     | Reserved.                                                                                                                                                  |
|          | 30     | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                               |
|          | 29:26  | Reserved.                                                                                                                                                  |
|          | 25:24  | Color Depth:                                                                                                                                               |
|          |        | 00 = 8 bit color                                                                                                                                           |
|          |        | 01 = 16 bit color (565)                                                                                                                                    |
|          |        | 10 = 16 bit color (1555)                                                                                                                                   |
|          |        | 11 = 32 bit color                                                                                                                                          |
|          | 23:16  | Raster Operation:                                                                                                                                          |
|          | 15:00  | Destination Pitch in DWords: [15:00] 2's complement                                                                                                        |
|          |        | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |
| 2 = BR22 | 31:16  | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)                                                                                     |
|          | 15:00  | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                           |
| 3 = BR23 | 31:16  | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                         |
|          | 15:00  | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                          |
| 4 = BR09 | 31:00  | <b>Destination Base Address:</b> (base address of the destination surface: X=0, Y=0)                                                                       |
|          |        | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                               |
| 5 = BR16 | 31:00  | <b>Solid Pattern Color:</b> 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                |

### 1.9.9 XY\_PAT\_BLT

PAT\_BLT is used when there is no source and the color pattern is not trivial (is not a solid color only).

If clipping is enabled, all scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.



| DWord    | Bit   | Description                                                                                                                                                |
|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                                                                                                 |
|          | 28:22 | Instruction Target (Opcode): 51h                                                                                                                           |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)                                                                            |
|          | 19:15 | Reserved.                                                                                                                                                  |
|          | 14:12 | Pattern Horizontal Seed (pixel of the scan line to start on corresponding to DST X=0)                                                                      |
|          | 11    | Tiling Enable:                                                                                                                                             |
|          |       | 0 = Tiling Disabled (Linear blit)                                                                                                                          |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                                   |
|          | 10:08 | Pattern Vertical Seed: (Starting Scan line of the 8x8 pattern corresponding to DST Y=0)                                                                    |
|          | 07:00 | Dword Length: 04h                                                                                                                                          |
| 1 = BR13 | 31    | Reserved.                                                                                                                                                  |
|          | 30    | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                               |
|          | 29:26 | Reserved.                                                                                                                                                  |
|          | 25:24 | Color Depth:                                                                                                                                               |
|          |       | 00 = 8 bit color                                                                                                                                           |
|          |       | 01 = 16 bit color (565)                                                                                                                                    |
|          |       | 10 = 16 bit color (1555)                                                                                                                                   |
|          |       | 11 = 32 bit color                                                                                                                                          |
|          | 23:16 | Raster Operation:                                                                                                                                          |
|          | 15:00 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                        |
|          |       | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |
| 2 = BR22 | 31:16 | Destination Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                            |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                           |
| 3 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                         |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                          |
| 4 = BR09 | 31:00 | <b>Destination Base Address:</b> (base address of the destination surface: X=0, Y=0)                                                                       |
|          |       | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                               |
| 5 = BR15 | 31:00 | Pattern Base Address: (28:06 are implemented) (Note no NPO2 change here) . The pattern data must be located in linear memory.                              |



# 1.9.10 XY\_PAT\_CHROMA\_BLT

PAT\_BLT is used when there is no source and the color pattern is not trivial (is not a solid color only).

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

| DWord    | Bit   | Description                                                                                                                                               |
|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                                                                                                |
|          | 28:22 | Instruction Target (Opcode): 76h                                                                                                                          |
|          | 21:20 | 32 bpp byte mask: (21 =1= write alpha channel; 20=1= write RGB channels)                                                                                  |
|          | 19:17 | Transparency Range Mode: (chroma-key) – Dst Chroma-key modes ONLY (SRC ILLEGAL)                                                                           |
|          | 16:15 | Reserved.                                                                                                                                                 |
|          | 14:12 | Pattern Horizontal Seed (pixel of the scan line to start on corresponding to DST X=0)                                                                     |
|          | 11    | Tiling Enable:                                                                                                                                            |
|          |       | 0 = Tiling Disabled (Linear blit)                                                                                                                         |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                                  |
|          | 10:08 | Pattern Vertical Seed: (Starting Scan line of the 8x8 pattern corresponding to DST Y=0)                                                                   |
|          | 07:00 | Dword Length: 06h                                                                                                                                         |
| 1 = BR13 | 31    | Reserved.                                                                                                                                                 |
|          | 30    | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                              |
|          | 29:26 | Reserved.                                                                                                                                                 |
|          | 25:24 | Color Depth:                                                                                                                                              |
|          |       | 00 = 8 bit color                                                                                                                                          |
|          |       | 01 = 16 bit color (565)                                                                                                                                   |
|          |       | 10 = 16 bit color (1555)                                                                                                                                  |
|          |       | 11 = 32 bit color                                                                                                                                         |
|          | 23:16 | Raster Operation:                                                                                                                                         |
|          | 15:00 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                       |
|          |       | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Yand can be upto 128Kbytes (or 32KDwords). |
| 2 = BR22 | 31:16 | Destination Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                           |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                          |
| 3 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                        |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                         |



| DWord    | Bit   | Description                                                                                                                                   |
|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 4 = BR09 | 31:00 | Destination Base Address: (base address of the destination surface: X=0, Y=0)                                                                 |
|          |       | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                  |
| 5 = BR15 | 31:00 | Pattern Base Address: (26:06 are used, other bits are ignored) (Note no NPO2 change here). The pattern data must be located in linear memory. |
| 6 = BR18 | 31:00 | Transparency Color Low: (Chroma-key Low = Pixel Greater or Equal)                                                                             |
| 7 = BR19 | 31:00 | Transparency Color High: (Chroma-key High = Pixel Less or Equal)                                                                              |

### 1.9.11 XY\_PAT\_BLT\_IMMEDIATE

PAT\_BLT\_IMMEDIATE is used when there is no source and the color pattern is not trivial (is not a solid color only) and the pattern is pulled through the command stream. The immediate data sizes are 64 bytes (16 DWs), 128 bytes (32 DWs), or 256 (64DWs) for 8, 16, and 32 bpp color patterns.

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

| DWord    | Bit   | Description                                                                             |
|----------|-------|-----------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                              |
|          | 28:22 | Instruction Target (Opcode): 72h                                                        |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)         |
|          | 19:15 | Reserved.                                                                               |
|          | 14:12 | Pattern Horizontal Seed (pixel of the scan line to start on corresponding to DST X=0)   |
|          | 11    | Tiling Enable:                                                                          |
|          |       | 0 = Tiling Disabled (Linear blit)                                                       |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                |
|          | 10:08 | Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0) |
|          | 07:00 | Dword Length: 03+ DWL = (Number of Immediate double)h                                   |
| 1 = BR13 | 31    | Reserved                                                                                |
|          | 30    | Clipping Enable: (1 = enabled; 0 = disabled)                                            |
|          | 29:26 | Reserved.                                                                               |
|          | 25:24 | Color Depth:                                                                            |
|          |       | 00 = 8 bit color                                                                        |
|          |       | 01 = 16 bit color (565)                                                                 |
|          |       | 10 = 16 bit color (1555)                                                                |
|          |       | 11 = 32 bit color                                                                       |



| DWord           | Bit   | Description                                                                                                                                                |  |  |  |  |  |
|-----------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                 | 23:16 | Raster Operation:                                                                                                                                          |  |  |  |  |  |
|                 | 15:00 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                        |  |  |  |  |  |
|                 |       | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |  |  |  |  |  |
| 2 = BR22        | 31:16 | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)                                                                                     |  |  |  |  |  |
|                 | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                           |  |  |  |  |  |
| 3 = BR23        | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                         |  |  |  |  |  |
|                 | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                          |  |  |  |  |  |
| 4 = BR09        | 31:00 | Destination Base Address: (base address of the destination surface: X=0, Y=0)                                                                              |  |  |  |  |  |
|                 |       | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                               |  |  |  |  |  |
| 5               | 31:00 | Immediate Data DW 0:                                                                                                                                       |  |  |  |  |  |
| 6               | 31:00 | Immediate Data DW 1:                                                                                                                                       |  |  |  |  |  |
| 7 thru<br>DWL+3 | S     | Immediate Data DWs 2 through DWORD_LENGTH (DWL):                                                                                                           |  |  |  |  |  |

# 1.9.12 XY\_PAT\_CHROMA\_BLT\_IMMEDIATE

PAT\_BLT\_IMMEDIATE is used when there is no source and the color pattern is not trivial (is not a solid color only) and the pattern is pulled through the command stream. The immediate data sizes are 64 bytes (16 DWs), 128 bytes (32 DWs), or 256 (64DWs) for 8, 16, and 32 bpp color patterns.

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

| DWord    | Bit                                                                                   | Description                                                                                   |  |  |  |  |  |
|----------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0 = BR00 | 31:29                                                                                 | Client: 02h - 2D Processor                                                                    |  |  |  |  |  |
|          | 28:22 Instruction Target (Opcode): 77h                                                |                                                                                               |  |  |  |  |  |
|          | 21:20 <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels) |                                                                                               |  |  |  |  |  |
|          | 19:17                                                                                 | Transparency Range Mode: (chroma-key) – Dst Chroma-key modes ONLY (SRC ILLEGAL)               |  |  |  |  |  |
|          | 16:15                                                                                 | Reserved.                                                                                     |  |  |  |  |  |
|          | 14:12                                                                                 | Pattern Horizontal Seed (pixel of the scan line to start on corresponding to DST X=0)         |  |  |  |  |  |
|          | 11                                                                                    | Tiling Enable:                                                                                |  |  |  |  |  |
|          |                                                                                       | 0 = Tiling Disabled (Linear blit)<br>1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y) |  |  |  |  |  |
|          | 10:08                                                                                 | Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0)       |  |  |  |  |  |



| DWord           | Bit   | Description                                                                                                                                                |
|-----------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 07:00 | Dword Length: 05+ DWL = (Number of Immediate double)h                                                                                                      |
| 1 = BR13        | 31    | Reserved.                                                                                                                                                  |
|                 | 30    | Clipping Enable (1 = enabled; 0 = disabled)                                                                                                                |
|                 | 29:26 | Reserved.                                                                                                                                                  |
|                 | 25:24 | Color Depth:                                                                                                                                               |
|                 |       | 00 = 8 bit color                                                                                                                                           |
|                 |       | 01 = 16 bit color (565)                                                                                                                                    |
|                 |       | 10 = 16 bit color (1555)                                                                                                                                   |
|                 |       | 11 = 32 bit color                                                                                                                                          |
|                 | 23:16 | Raster Operation                                                                                                                                           |
| 15:00           |       | Destination Pitch in DWords: [15:00] 2's complement                                                                                                        |
|                 |       | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |
| 2 = BR22        | 31:16 | Destination Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                            |
|                 | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                           |
| 3 = BR23        | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                         |
|                 | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                          |
| 4 = BR09        | 31:00 | Destination Base Address: (base address of the destination surface: X=0, Y=0)                                                                              |
|                 |       | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                               |
| 5 = BR18        | 31:00 | Transparency Color Low: (Chroma-key Low = Pixel Greater or Equal)                                                                                          |
| 6 = BR19        | 31:00 | Transparency Color High: (Chroma-key High = Pixel Less or Equal)                                                                                           |
| 7               | 31:00 | Immediate Data DW 0:                                                                                                                                       |
| 8               | 31:00 | Immediate Data DW 1:                                                                                                                                       |
| 9 thru<br>DWL+3 | S     | Immediate Data DWs 2 through DWORD_LENGTH (DWL):                                                                                                           |



## 1.9.13 XY\_MONO\_PAT\_BLT

MONO\_PAT\_BLT is used when we have no source and the monochrome pattern is not trivial (is not a solid color only). The monochrome pattern is loaded from the instruction stream.

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

The Pattern Seeds correspond to Destination X = 0 (horizontal) and Y = 0 (vertical). The alignment is relative to the destination coordinates. The pixel of the pattern used / scan line is the (destination X coordinate + horizontal seed) modulo 8. The scan line of the pattern used is the (destination Y coordinate + vertical seed) modulo 8.

The monochrome pattern transparency mode indicates whether to use the pattern background color or de-assert the write enables when the bit in the pattern is 0. When the pattern bit is 1, then the pattern foreground color is used in the ROP operation.

| DWord    | Bit   | Description                                                                             |
|----------|-------|-----------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                              |
|          | 28:22 | Instruction Target (Opcode) : 52h                                                       |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)         |
|          | 19:15 | Reserved.                                                                               |
|          | 14:12 | Pattern Horizontal Seed: (pixel of the scan line to start on corresponding to DST X=0)  |
|          | 11    | Tiling Enable:                                                                          |
|          |       | 0 = Tiling Disabled (Linear blit)                                                       |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                |
|          | 10:08 | Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0) |
|          | 07:00 | Dword Length: 07h                                                                       |
| 1 = BR13 | 31    | Reserved.                                                                               |
|          | 30    | Clipping Enable (1 = enabled; 0 = disabled)                                             |
|          | 29    | Reserved.                                                                               |
|          | 28    | Mono Pattern Transparency Mode: (1 = transparency enabled; 0 = use background)          |
|          | 27:26 | Reserved.                                                                               |
|          | 25:24 | Color Depth:                                                                            |
|          |       | 00 = 8 bit color                                                                        |
|          |       | 01 = 16 bit color (565)                                                                 |
|          |       | 10 = 16 bit color (1555)                                                                |
|          |       | 11 = 32 bit color                                                                       |
|          | 23:16 | Raster Operation:                                                                       |



| DWord    | Bit                                                                         | Description                                                                                                                                               |  |  |  |  |  |
|----------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|          | 15:00                                                                       | Destination Pitch in DWords: [15:00] 2's complement                                                                                                       |  |  |  |  |  |
|          |                                                                             | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Yand can be upto 128Kbytes (or 32KDwords). |  |  |  |  |  |
| 2 = BR22 | 31:16                                                                       | Destination Y1 Coordinate (Top): 31:16 = 16 bit signed number)                                                                                            |  |  |  |  |  |
|          | 15:00                                                                       | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                          |  |  |  |  |  |
| 3 = BR23 | 23 31:16 Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number) |                                                                                                                                                           |  |  |  |  |  |
|          | 15:00                                                                       | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                         |  |  |  |  |  |
| 4 = BR09 | 31:00                                                                       | Destination Base Address: (base address of the destination surface: X=0, Y=0)                                                                             |  |  |  |  |  |
|          |                                                                             | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                              |  |  |  |  |  |
| 5 = BR16 | 31:00                                                                       | Pattern Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                 |  |  |  |  |  |
| 6 = BR17 | 31:00                                                                       | Pattern Foreground Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                 |  |  |  |  |  |
| 7 = BR20 | 31:00                                                                       | Pattern Data 0: (least significant DW)                                                                                                                    |  |  |  |  |  |
| 8 = BR21 | 31:00                                                                       | Pattern Data 1: (most significant DW)                                                                                                                     |  |  |  |  |  |

# 1.9.14 XY\_MONO\_PAT\_FIXED\_BLT

MONO\_PAT\_FIXED\_BLT is used when we have no source and the monochrome pattern is not trivial (is not a solid color only). The monochrome pattern is one of 10 fixed patterns described below. The pattern seeds can still be used with the fixed patterns, creating even more fixed patterns. This eliminates 2 doublewords compared to the XY\_MONO\_PAT\_BLT command packet.

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

The Pattern Seeds correspond to Destination X = 0 (horizontal) and Y = 0 (vertical). The alignment is relative to the destination coordinates. The pixel of the pattern used / scan line is the (destination X coordinate + horizontal seed) modulo 8. The scan line of the pattern used is the (destination Y coordinate + vertical seed) modulo 8.

The monochrome pattern transparency mode indicates whether to use the pattern background color or de-assert the write enables when the bit in the pattern is 0. When the pattern bit is 1, then the pattern foreground color is used in the ROP operation.

| DWord    | Bit   | Description                                                                     |  |  |  |  |  |  |
|----------|-------|---------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                      |  |  |  |  |  |  |
|          | 28:22 | struction Target (Opcode): 59h                                                  |  |  |  |  |  |  |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels) |  |  |  |  |  |  |
|          | 19    | Reserved.                                                                       |  |  |  |  |  |  |
|          | 18:15 | Fixed Pattern:                                                                  |  |  |  |  |  |  |
|          |       | 0000 HS_HORIZONTAL                                                              |  |  |  |  |  |  |
|          |       | 0001 HS_VERTICAL                                                                |  |  |  |  |  |  |



| DWord    | Bit   | Description                                                                                                                                                |  |  |  |  |  |  |
|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|          |       | 0010 HS_FDIAGONAL                                                                                                                                          |  |  |  |  |  |  |
|          |       | 0011 HS_BDIAGONAL                                                                                                                                          |  |  |  |  |  |  |
|          |       | 0100 HS_CROSS                                                                                                                                              |  |  |  |  |  |  |
|          |       | 0101 HS_DIAGCROSS                                                                                                                                          |  |  |  |  |  |  |
|          |       | 0110 Reserved                                                                                                                                              |  |  |  |  |  |  |
|          |       | 0111 Reserved                                                                                                                                              |  |  |  |  |  |  |
|          |       | 1000 Screen Door                                                                                                                                           |  |  |  |  |  |  |
|          |       | 1001 SD Wide                                                                                                                                               |  |  |  |  |  |  |
|          |       | 1010 Walking Bit (one)                                                                                                                                     |  |  |  |  |  |  |
|          |       | 1011 Walking Zero                                                                                                                                          |  |  |  |  |  |  |
|          |       | 1100 Reserved                                                                                                                                              |  |  |  |  |  |  |
|          |       | 1101 Reserved                                                                                                                                              |  |  |  |  |  |  |
|          |       | 1110 Reserved                                                                                                                                              |  |  |  |  |  |  |
|          | 14:12 | Pattern Horizontal Seed: (pixel of the scan line to start on corresponding to DST X=0)                                                                     |  |  |  |  |  |  |
|          | 11    | Tiling Enable:                                                                                                                                             |  |  |  |  |  |  |
|          |       | 0 = Tiling Disabled (Linear blit)                                                                                                                          |  |  |  |  |  |  |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                                   |  |  |  |  |  |  |
|          | 10:08 | Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0)                                                                    |  |  |  |  |  |  |
|          | 07:00 | Dword Length: 05h                                                                                                                                          |  |  |  |  |  |  |
| 1 = BR13 | 31    | Reserved.                                                                                                                                                  |  |  |  |  |  |  |
|          | 30    | Clipping Enable (1 = enabled; 0 = disabled)                                                                                                                |  |  |  |  |  |  |
|          | 29    | Reserved.                                                                                                                                                  |  |  |  |  |  |  |
|          | 28    | Mono Pattern Transparency Mode: (1 = transparency enabled; 0 = use background)                                                                             |  |  |  |  |  |  |
|          | 27    | Bit Mask Enable: (1 = use bit mask register for bit writes; 0 = disabled)                                                                                  |  |  |  |  |  |  |
|          | 27:26 | Reserved.                                                                                                                                                  |  |  |  |  |  |  |
|          | 25:24 | Color Depth:                                                                                                                                               |  |  |  |  |  |  |
|          |       | 00 = 8 bit color                                                                                                                                           |  |  |  |  |  |  |
|          |       | 01 = 16 bit color (565)                                                                                                                                    |  |  |  |  |  |  |
|          |       | 10 = 16 bit color (1555)                                                                                                                                   |  |  |  |  |  |  |
|          |       | 11 = 32 bit color                                                                                                                                          |  |  |  |  |  |  |
|          | 23:16 | Raster Operation:                                                                                                                                          |  |  |  |  |  |  |
|          | 15:00 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                        |  |  |  |  |  |  |
|          |       | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |  |  |  |  |  |  |
| 2 = BR22 | 31:16 | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)                                                                                     |  |  |  |  |  |  |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                           |  |  |  |  |  |  |



| DWord    | Bit   | Description                                                                          |  |  |  |  |  |
|----------|-------|--------------------------------------------------------------------------------------|--|--|--|--|--|
| 3 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                   |  |  |  |  |  |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                    |  |  |  |  |  |
| 4 = BR09 | 31:00 | <b>Destination Base Address:</b> (base address of the destination surface: X=0, Y=0) |  |  |  |  |  |
|          |       | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.         |  |  |  |  |  |
| 5 = BR16 | 31:00 | Pattern Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]            |  |  |  |  |  |
| 6 = BR17 | 31:00 | Pattern Foreground Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]            |  |  |  |  |  |

#### 1.9.14.1 Monochrome Pattern Memory Format

The monochrome pattern is made of 8 bytes that correspond to the 8 pixels per scan line and 8 scan lines. Byte 0 corresponds to scan line 0, byte 1 corresponds to scan line 1,..., and byte 7 corresponds to scan line 7. The bits within each byte are transposed. Pixel 0 is bit 7, pixel 1 is bit 6,..., pixel 7 is bit 0. The diagram below illustrates the byte and bit relationship to the pixels of the pattern.





#### 1.9.14.2 HS\_HORIZONTAL 0

### Bit 7 0,0

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### 1.9.14.3 HS\_VERTICAL 1

| Bit 7 |  |
|-------|--|
|-------|--|

0,0

7,0

0

0

7,0

| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |



### 1.9.14.4 HS\_FDIAGONAL 2

Bit 7

0,0

7,0

0

| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |

#### 1.9.14.5 HS\_BDIAGONAL 3

Bit 7

0,0

1

0 0 0 0 1 0 0 0

0 0 0 1 0 0 0

0 0 1 0 0 0 0 0

0 1 0 0 0 0 0

0 0 0 0 0 0

 0
 0
 0
 0
 0
 0
 1

 0
 0
 0
 0
 0
 0
 1
 0

 0
 0
 0
 0
 0
 1
 0
 0

 0
 0
 0
 0
 0
 1
 0
 0

0

7,0

0



#### 1.9.14.6 HS\_CROSS 4

| Bit | Bit 7 0 |   |   |   |   |   |   |  |  |  |
|-----|---------|---|---|---|---|---|---|--|--|--|
| 0,0 | 0,0 7,0 |   |   |   |   |   |   |  |  |  |
| 0   | 0       | 0 | 0 | 1 | 0 | 0 | 0 |  |  |  |
| 0   | 0       | 0 | 0 | 1 | 0 | 0 | 0 |  |  |  |
| 0   | 0       | 0 | 0 | 1 | 0 | 0 | 0 |  |  |  |
| 1   | 1       | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |
| 0   | 0       | 0 | 0 | 1 | 0 | 0 | 0 |  |  |  |
| 0   | 0       | 0 | 0 | 1 | 0 | 0 | 0 |  |  |  |
| 0   | 0       | 0 | 0 | 1 | 0 | 0 | 0 |  |  |  |
| 0   | 0       | 0 | 0 | 1 | 0 | 0 | 0 |  |  |  |
|     |         |   |   |   |   |   |   |  |  |  |

#### 1.9.14.7 HS\_DIAGCROSS 5

Bit 7 0,0

0

7,0

| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
|---|---|---|---|---|---|---|---|
| 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 |
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 |
| 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |



### 1.9.14.8 Screen Door 8

Bit 7

0,0

7,0

0

| 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
|---|---|---|---|---|---|---|---|
| 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |

#### 1.9.14.9 SD Wide 9

Bit 7

0,0

0

7,0

| 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |



# 1.9.14.10 Walking Bit (One) A

Bit 7

0,0

7,0

0

| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 |
| 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 |
| 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |

### 1.9.14.11 Walking Zero B

| Bit 7 0 |   |   |   |   |   |   |   |  |  |
|---------|---|---|---|---|---|---|---|--|--|
| 0,0 7,  |   |   |   |   |   |   |   |  |  |
| 0       | 1 | 1 | 1 | 0 | 1 | 1 | 1 |  |  |
| 1       | 0 | 1 | 1 | 1 | 0 | 1 | 1 |  |  |
| 1       | 1 | 0 | 1 | 1 | 1 | 0 | 1 |  |  |
| 1       | 1 | 1 | 0 | 1 | 1 | 1 | 0 |  |  |
| 0       | 1 | 1 | 1 | 0 | 1 | 1 | 1 |  |  |
| 1       | 0 | 1 | 1 | 1 | 0 | 1 | 1 |  |  |
| 1       | 1 | 0 | 1 | 1 | 1 | 0 | 1 |  |  |
| 1       | 1 | 1 | 0 | 1 | 1 | 1 | 0 |  |  |



# 1.9.15 XY\_SRC\_COPY\_BLT

This BLT instruction performs a color source copy where the only operands involved is a color source and destination of the same bit width.

The source and destination operands may overlap, which means that the X and Y directions can be either forward or backwards. The BLT Engine takes care of all situations. The base addresses plus the X and Y coordinates determine if there is an overlap between the source and destination operands. If the base addresses of the source and destination are the same and the Source X1 is **less than** Destination X1, then the BLT Engine performs the accesses in the X-backwards access pattern. There is no need to look for an actual overlap. If the base addresses are the same and Source Y1 is **less than** Destination Y1, then the scan line accesses start at Destination Y2 with the corresponding source scan line and the strides are subtracted for every scan line access.

| DWord    | Bit   | Description                                                                     |
|----------|-------|---------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                      |
|          | 28:22 | Instruction Target (Opcode): 53h                                                |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels) |
|          | 19:16 | Reserved.                                                                       |
|          | 15    | Src Tiling Enable:                                                              |
|          |       | 0 = Tiling Disabled (Linear)                                                    |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                        |
|          | 14:12 | Reserved                                                                        |
|          | 11    | Dest Tiling Enable:                                                             |
|          |       | 0 = Tiling Disabled (Linear)                                                    |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                        |
|          | 10: 8 | Reserved                                                                        |
|          | 7:0   | Dword Length: 06h                                                               |
| 1 = BR13 | 31    | Reserved.                                                                       |
|          | 30    | Clipping Enable: (1 = enabled; 0 = disabled)                                    |
|          | 29:26 | Reserved.                                                                       |
|          | 25:24 | Color Depth:                                                                    |
|          |       | 00 = 8 bit color                                                                |
|          |       | 01 = 16 bit color (565)                                                         |
|          |       | 10 = 16 bit color (1555)                                                        |
|          |       | 11 = 32 bit color                                                               |
|          | 23:16 | Raster Operation                                                                |

The ROP value chosen must involve source and no pattern data in the ROP operation.



| DWord    | Bit   | Description                                                                                                                                            |
|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 15:00 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                    |
|          |       | For Tiled Dest (bit 11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Yand can be up to 128Kbytes (or 32KDwords). |
| 2 = BR22 | 31:16 | Destination Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                        |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                       |
| 3 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                     |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                      |
| 4 = BR09 | 31:00 | Destination Base Address: (base address of the destination surface: X=0, Y=0)                                                                          |
|          |       | When Dest Tiling is enabled (Bit 11 enabled), this address is limited to 4Kbytes.                                                                      |
| 5 = BR26 | 31:16 | Source Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                             |
|          | 15:00 | Source X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                            |
|          | 31:16 | Reserved                                                                                                                                               |
| 6 = BR11 | 15:00 | Source Pitch (double word aligned) and in DWords: [15:00] 2's complement.                                                                              |
|          |       | For Tiled Src (bit 15 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Yand can be upto 128Kbytes (or 32KDwords).   |
| 7 = BR12 | 31:00 | Source Base Address: (base address of the source surface: X=0, Y=0)                                                                                    |
|          |       | When Src Tiling is enabled (Bit 15 enabled), this address is limited to 4Kbytes.                                                                       |

# 1.9.16 XY\_SRC\_COPY\_CHROMA\_BLT

This BLT instruction performs a color source copy with chroma-keying where the only operands involved is a color source and destination of the same bit width.

The source and destination operands may overlap, which means that the X and Y directions can be either forward or backwards. The BLT Engine takes care of all situations. The base addresses plus the X and Y coordinates determine if there is an overlap between the source and destination operands. If the base addresses of the source and destination are the same and the Source X1 is **less than** Destination X1, then the BLT Engine performs the accesses in the X-backwards access pattern. There is no need to look for an actual overlap. If the base addresses are the same and Source Y1 is **less than** Destination Y1, then the scan line accesses start at Destination Y2 with the corresponding source scan line and the strides are subtracted for every scan line access.

The ROP value chosen must involve source and no pattern data in the ROP operation.

| DWord    | Bit   | Description                                                                     |
|----------|-------|---------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                      |
|          | 28:22 | Instruction Target (Opcode): 73h                                                |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels) |
|          | 19:17 | Transparency Range Mode: (chroma-key)                                           |
|          | 16    | Reserved                                                                        |



| DWord    | Bit    | Description                                                                                                                                           |
|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 15     | Src Tiling Enable:                                                                                                                                    |
|          |        | 0 = Tiling Disabled (Linear)                                                                                                                          |
|          |        | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                              |
|          | 14:12  | Reserved                                                                                                                                              |
|          | 11     | Dest Tiling Enable:                                                                                                                                   |
|          |        | 0 = Tiling Disabled (Linear)                                                                                                                          |
|          |        | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                              |
|          | 10: 08 | Reserved                                                                                                                                              |
|          | 07:00  | Dword Length: 08h                                                                                                                                     |
| 1 = BR13 | 31     | Reserved.                                                                                                                                             |
|          | 30     | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                          |
|          | 29:26  | Reserved.                                                                                                                                             |
|          | 25:24  | Color Depth:                                                                                                                                          |
|          |        | 00 = 8 bit color                                                                                                                                      |
|          |        | 01 = 16 bit color (565)                                                                                                                               |
|          |        | 10 = 16 bit color (1555)                                                                                                                              |
|          |        | 11 = 32 bit color                                                                                                                                     |
|          | 23:16  | Raster Operation:                                                                                                                                     |
|          | 15:00  | Destination Pitch in DWords: [15:00] 2's complement                                                                                                   |
|          |        | For Tiled Dest (bit 11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Yand can be upto 128Kbytes (or 32KDwords). |
| 2 = BR22 | 31:16  | Destination Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                       |
|          | 15:00  | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                      |
| 3 = BR23 | 31:16  | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                    |
|          | 15:00  | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                     |
| 4 = BR09 | 31:00  | <b>Destination Base Address:</b> (base address of the destination surface: X=0, Y=0)                                                                  |
|          |        | When Dest Tiling is enabled (Bit 11 enabled), this address is limited to 4Kbytes.                                                                     |
| 5 = BR26 | 31:16  | Source Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                            |
|          | 15:00  | Source X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                           |
|          | 31:16  | Reserved.                                                                                                                                             |
| 6 = BR11 | 15:00  | Source Pitch (double word aligned) and in DWords: [15:00] 2's complement.                                                                             |
|          |        | For Tiled Src (bit 15 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Yand can be upto 128Kbytes (or 32KDwords).  |
| 7 = BR12 | 31:00  | Source Base Address: (base address of the source surface: X=0, Y=0)                                                                                   |
|          |        | When Src Tiling is enabled (Bit 15 enabled), this address is limited to 4Kbytes.                                                                      |
| 8 = BR18 | 31:00  | Transparency Color Low: (Chroma-key Low = Pixel Greater or Equal)                                                                                     |
| 9 = BR19 | 31:00  | Transparency Color High: (Chroma-key High = Pixel Less or Equal)                                                                                      |
|          |        |                                                                                                                                                       |



# 1.9.17 XY\_MONO\_SRC\_COPY\_BLT

This BLT instruction performs a monochrome source copy where the only operands involved is a monochrome source and destination. The source and destination operands cannot overlap therefore the X and Y directions are always forward.

All non-text monochrome sources are word aligned. At the end of a scan line of monochrome source, all bits until the next word boundary are ignored. The monochrome source data bit position field [2:0] indicates the bit position within the first byte of the scan line that should be used as the first source pixel which corresponds to the destination X1 coordinate.

The monochrome source transparency mode indicates whether to use the source background color or de-assert the write enables when the bit in the source is 0. When the source bit is 1, then the source foreground color is used in the ROP operation. The ROP value chosen must involve source and no pattern data in the ROP operation.

| DWord    | Bit    | Description                                                                                                                                               |
|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29  | Client: 02h - 2D Processor                                                                                                                                |
|          | 28:22  | Instruction Target (Opcode): 54h                                                                                                                          |
|          | 21:20  | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)                                                                           |
|          | 19:17  | Monochrome source data bit position of the first pixel within a byte per scan line.                                                                       |
|          | 16:12  | Reserved.                                                                                                                                                 |
|          | 11     | Tiling Enable:                                                                                                                                            |
|          |        | 0 = Tiling Disabled (Linear blit)                                                                                                                         |
|          |        | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                                  |
|          | 10: 08 | Reserved                                                                                                                                                  |
|          | 07:00  | Doubleword Length: 06h                                                                                                                                    |
| 1 = BR13 | 31     | Reserved.                                                                                                                                                 |
|          | 30     | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                              |
|          | 29     | Mono Source Transparency Mode: (1 = transparency enabled; 0 = use background)                                                                             |
|          | 28:26  | Reserved.                                                                                                                                                 |
|          | 25:24  | Color Depth:                                                                                                                                              |
|          |        | 00 = 8 bit color                                                                                                                                          |
|          |        | 01 = 16 bit color (565)                                                                                                                                   |
|          |        | 10 = 16 bit color (1555)                                                                                                                                  |
|          |        | 11 = 32 bit color                                                                                                                                         |
|          | 23:16  | Raster Operation:                                                                                                                                         |
|          | 15:00  | Destination Pitch in DWords: [15:00] 2's complement                                                                                                       |
|          |        | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Yand can be upto 128Kbytes (or 32KDwords). |

Negative Stride (= Pitch) is NOT ALLOWED.



| DWord    | Bit   | Description                                                                     |
|----------|-------|---------------------------------------------------------------------------------|
| 2 = BR22 | 31:16 | Destination Y1 Coordinate (Top): (31:16 = 16 bit signed number)                 |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                |
| 3 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)              |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)               |
| 4 = BR09 | 31:00 | Destination Base Address: (base address of the destination surface: X=0, Y=0)   |
|          |       | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.    |
| 5 = BR12 | 31:00 | Source Address: (address corresponding to DST X1,Y1) (Note no NPO2 change here) |
| 6 = BR18 | 31:00 | Source Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]        |
| 7 = BR19 | 31:00 | Source Foreground Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]        |

### 1.9.18 XY\_MONO\_SRC\_COPY\_ IMMEDIATE\_BLT

This instruction allows the Driver to send monochrome data through the instruction stream, eliminating the read latency of the source during command execution.

The IMMEDIATE\_BLT data MUST transfer an even number of doublewords and the exact number of quadwords.

All non-text monochrome sources are word aligned. At the end of a scan line of monochrome source, all bits until the next word boundary are ignored. The Monochrome source data bit position field [2:0] indicates the bit position within the first byte of the scan line that should be used as the first source pixel which corresponds to the destination X1 coordinate.

The monochrome source transparency mode indicates whether to use the source background color or de-assert the write enables when the bit in the source is 0. When the source bit is 1, then the source foreground color is used in the ROP operation. The ROP value chosen must involve source and no pattern data in the ROP operation.

The monochrome source data supplied corresponds to the Destination X1 and Y1 coordinates.

| DWord    | Bit   | Description                                                                         |
|----------|-------|-------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                          |
|          | 28:22 | Instruction Target (Opcode): 71h                                                    |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)     |
|          | 19:17 | Monochrome source data bit position of the first pixel within a byte per scan line. |
|          | 16:12 | Reserved.                                                                           |
|          | 11    | Tiling Enable:                                                                      |
|          |       | 0 = Tiling Disabled (Linear blit)                                                   |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                            |

Negative Stride (= Pitch) is NOT ALLOWED.



| DWord           | Bit    | Description                                                                                                                                                |
|-----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 10: 08 | Reserved                                                                                                                                                   |
|                 | 07:00  | Dword Length: 05+ DWL = (Number of Immediate double words)h                                                                                                |
| 1 = BR13        | 31     | Reserved.                                                                                                                                                  |
|                 | 30     | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                               |
|                 | 29     | Mono Source Transparency Mode: (1 = transparency enabled; 0 = use background)                                                                              |
|                 | 28:26  | Reserved.                                                                                                                                                  |
|                 | 25:24  | Color Depth:                                                                                                                                               |
|                 |        | 00 = 8 bit color                                                                                                                                           |
|                 |        | 01 = 16 bit color (565)                                                                                                                                    |
|                 |        | 10 = 16 bit color (1555)                                                                                                                                   |
|                 |        | 11 = 32 bit color                                                                                                                                          |
|                 | 23:16  | Raster Operation:                                                                                                                                          |
|                 | 15:00  | Destination Pitch in DWords: [15:00] 2's complement                                                                                                        |
|                 |        | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |
| 2 = BR22        | 31:16  | Destination Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                            |
|                 | 15:00  | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                           |
| 3 = BR23        | 31:16  | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                         |
|                 | 15:00  | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                          |
| 4 = BR09        | 31:00  | Destination Base Address: (base address of the destination surface: X=0, Y=0)                                                                              |
|                 |        | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                               |
| 5 = BR18        | 31:00  | Source Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                   |
| 6 = BR19        | 31:00  | Source Foreground Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                   |
| 7               | 31:00  | Immediate Data DW 0:                                                                                                                                       |
| 8               | 31:00  | Immediate Data DW 1:                                                                                                                                       |
| 9 thru<br>DWL+4 | S      | Immediate Data DWs 2 through DWORD_LENGTH (DWL):                                                                                                           |

# 1.9.19 XY\_FULL\_BLT

The full BLT is the most comprehensive BLT instruction. It provides the ability to specify all 3 operands: destination, source, and pattern. The source and pattern operands are the same bit width as the destination operand.

The source and destination operands may overlap, which means that the X and Y directions can be either forward or backwards. The BLT Engine takes care of all situations. The base addresses plus the X and Y coordinates determine if there is an overlap between the source and destination operands. If the base addresses of the source and destination are the same and the Source X1 is **less than** Destination X1, then the BLT Engine performs the accesses in the X-backwards access pattern. There is no need to look for an actual overlap. If the base addresses are the same and Source Y1 is **less than** Destination Y1,



then the scan line accesses start at Destination Y2 with the corresponding source scan line and the strides are subtracted for every scan line access.

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

| DWord    | Bit   | Description                                                                                                                                           |
|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                                                                                            |
|          | 28:22 | Instruction Target (Opcode): 55h                                                                                                                      |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)                                                                       |
|          | 19:16 | Reserved.                                                                                                                                             |
|          | 15    | Src Tiling Enable:                                                                                                                                    |
|          |       | 0 = Tiling Disabled (Linear)                                                                                                                          |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                              |
|          | 14:12 | Pattern Horizontal Seed (pixel of the scan line to start on corresponding to DST X=0)                                                                 |
|          | 11    | Dest Tiling Enable:                                                                                                                                   |
|          |       | 0 = Tiling Disabled (Linear blit)                                                                                                                     |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                              |
|          | 10:08 | Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0)                                                               |
|          | 07:00 | Doubleword Length: 07h                                                                                                                                |
| 1 = BR13 | 31    | Reserved.                                                                                                                                             |
|          | 30    | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                          |
|          | 29:26 | Reserved.                                                                                                                                             |
|          | 25:24 | Color Depth:                                                                                                                                          |
|          |       | 00 = 8 bit color                                                                                                                                      |
|          |       | 01 = 16 bit color (565)                                                                                                                               |
|          |       | 10 = 16 bit color (1555)                                                                                                                              |
|          |       | 11 = 32 bit color                                                                                                                                     |
|          | 23:16 | Raster Operation:                                                                                                                                     |
|          | 15:00 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                   |
|          |       | For Tiled Dest (bit 11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Yand can be upto 128Kbytes (or 32KDwords). |
| 2 = BR22 | 31:16 | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)                                                                                |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                      |
| 3 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                    |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                     |



| DWord    | Bit   | Description                                                                                                                                           |
|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4 = BR09 | 31:00 | Destination Base Address: (base address of the destination surface: X=0, Y=0)                                                                         |
|          |       | When Dest Tiling is enabled (Bit 11 enabled), this address is limited to 4Kbytes.                                                                     |
| 5 = BR11 | 31:16 | Reserved.                                                                                                                                             |
|          | 15:00 | Source Pitch (double word aligned and signed) and in DWords: [15:00] 2's complement.                                                                  |
|          |       | For Tiled Src (bit 15 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |
| 6 = BR26 | 31:16 | Source Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                            |
|          | 15:00 | Source X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                           |
| 7 = BR12 | 31:00 | Source Base Address: (base address of the source surface: X=0, Y=0)                                                                                   |
|          |       | When Src Tiling is enabled (Bit 15 enabled), this address is limited to 4Kbytes.                                                                      |
| 8 = BR15 | 31:00 | Pattern Base Address: (28:06 are implemented ) (Note no NPO2 change here). The pattern data must be located in linear memory.                         |

# 1.9.20 XY\_FULL\_IMMEDIATE\_PATTERN\_BLT

The full BLT is the most comprehensive BLT instruction. It provides the ability to specify all 3 operands: destination, source, and pattern. The source and immediate pattern operands are the same bit width as the destination operand. The immediate data sizes are 64 bytes (16 DWs), 128 bytes (32 DWs), or 256 (64 DWs) for 8, 16, and 32 bpp color patterns.

The source and destination operands may overlap, which means that the X and Y directions can be either forward or backwards. The BLT Engine takes care of all situations. The base addresses plus the X and Y coordinates determine if there is an overlap between the source and destination operands. If the base addresses of the source and destination are the same and the Source X1 is **less than** Destination X1, then the BLT Engine performs the accesses in the X-backwards access pattern. There is no need to look for an actual overlap. If the base addresses are the same and Source Y1 is **less than** Destination Y1, then the scan line accesses start at Destination Y2 with the corresponding source scan line and the strides are subtracted for every scan line access.

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

| DWord    | Bit   | Description                                                                     |
|----------|-------|---------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                      |
|          | 28:22 | Instruction Target (Opcode): 74h                                                |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels) |
|          | 19:16 | Reserved.                                                                       |



| 1 = BR13 | 15<br>14:12<br>11<br>10:8<br>7:0<br>31<br>30<br>29:26 | Src Tiling Enable:         0 = Tiling Disabled (Linear)         1 = Tiling enabled (DevSNB+ : Tile-X or Tile-Y)         Pattern Horizontal Seed: (pixel of the scan line to start on corresponding to DST X=0)         Dest Tiling Enable:         0 = Tiling Disabled (Linear)         1 = Tiling enabled (DevSNB+ : Tile-X or Tile-Y)         Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0)         Doubleword Length: 06+ DWL = (Number of Immediate double words)h         Reserved. |
|----------|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 = BR13 | 11<br>10:8<br>7:0<br>31<br>30<br>29:26                | 1 = Tiling enabled (DevSNB+ : Tile-X or Tile-Y)         Pattern Horizontal Seed: (pixel of the scan line to start on corresponding to DST X=0)         Dest Tiling Enable:         0 = Tiling Disabled (Linear)         1 = Tiling enabled (DevSNB+ : Tile-X or Tile-Y)         Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0)         Doubleword Length: 06+ DWL = (Number of Immediate double words)h         Reserved.                                                                 |
| 1 = BR13 | 11<br>10:8<br>7:0<br>31<br>30<br>29:26                | Pattern Horizontal Seed: (pixel of the scan line to start on corresponding to DST X=0)         Dest Tiling Enable:         0 = Tiling Disabled (Linear)         1 = Tiling enabled (DevSNB+ : Tile-X or Tile-Y)         Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0)         Doubleword Length: 06+ DWL = (Number of Immediate double words)h         Reserved.                                                                                                                         |
| 1 = BR13 | 11<br>10:8<br>7:0<br>31<br>30<br>29:26                | Dest Tiling Enable:<br>0 = Tiling Disabled (Linear)<br>1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)<br>Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0)<br>Doubleword Length: 06+ DWL = (Number of Immediate double words)h<br>Reserved.                                                                                                                                                                                                                                        |
| 1 = BR13 | 10:8<br>7:0<br>31<br>30<br>29:26                      | 0 = Tiling Disabled (Linear)<br>1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)<br>Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0)<br>Doubleword Length: 06+ DWL = (Number of Immediate double words)h<br>Reserved.                                                                                                                                                                                                                                                               |
| 1 = BR13 | 7:0<br>31<br>30<br>29:26                              | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)<br>Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0)<br>Doubleword Length: 06+ DWL = (Number of Immediate double words)h<br>Reserved.                                                                                                                                                                                                                                                                                               |
| 1 = BR13 | 7:0<br>31<br>30<br>29:26                              | Pattern Vertical Seed:       (starting scan line of the 8x8 pattern corresponding to DST Y=0)         Doubleword Length:       06+ DWL = (Number of Immediate double words)h         Reserved.                                                                                                                                                                                                                                                                                                                                     |
| 1 = BR13 | 7:0<br>31<br>30<br>29:26                              | Doubleword Length: 06+ DWL = (Number of Immediate double words)h<br>Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1 = BR13 | 31<br>30<br>29:26                                     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1 = BR13 | 30<br>29:26                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -        | 29:26                                                 | Climping England (1. angladd 0. diaghlad)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| -        |                                                       | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| -        |                                                       | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|          | 25:24                                                 | Color Depth:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|          |                                                       | 00 = 8 bit color                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|          |                                                       | 01 = 16 bit color (565)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|          |                                                       | 10 = 16 bit color (1555)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          |                                                       | 11 = 32 bit color                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|          | 23:16                                                 | Raster Operation:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|          | 15:00                                                 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          |                                                       | For Tiled Dest (bit 11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords).                                                                                                                                                                                                                                                                                                                                                                             |
| 2 = BR22 | 31:16                                                 | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|          | 15:00                                                 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3 = BR23 | 31:16                                                 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|          | 15:00                                                 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4 = BR09 | 31:00                                                 | <b>Destination Base Address:</b> (base address of the destination surface: X=0, Y=0)                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|          |                                                       | When Dest Tiling is enabled (Bit 11 enabled), this address is limited to 4Kbytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|          | 31:16                                                 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5 = BR11 | 15:00                                                 | Source Pitch (double word aligned and signed) and in DWords: [15:00] 2's complement.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|          |                                                       | For Tiled Src (bit 15 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords).                                                                                                                                                                                                                                                                                                                                                                              |
| 6 = BR26 | 31:16                                                 | Source Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|          | 15:00                                                 | Source X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7 = BR12 | 31:00                                                 | Source Base Address: (base address of the source surface: X=0, Y=0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          |                                                       | When Src Tiling is enabled (Bit 15 enabled), this address is limited to 4Kbytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8        |                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9        | 31:00                                                 | Immediate Data DW 0:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |



| DWord           | Bit | Description                                      |
|-----------------|-----|--------------------------------------------------|
| A thru<br>DWL+4 | S   | Immediate Data DWs 2 through DWORD_LENGTH (DWL): |

## 1.9.21 XY\_FULL\_MONO\_SRC\_BLT

The full BLT is the most comprehensive BLT instruction. It provides the ability to specify all 3 operands: destination, source, and pattern. The source operand is monochrome and the pattern operand is the same bit width as the destination.

The monochrome source transparency mode indicates whether to use the source background color or de-assert the write enables when the bit in the source is 0. When the source bit is 1, then the source foreground color is used in the ROP operation.

All non-text and non-immediate monochrome sources are word aligned. At the end of a scan line the monochrome source, the remaining bits until the next word boundary are ignored. The Monochrome source data bit position field [2:0] indicates which bit position within the first byte should be used as the first source pixel which corresponds to the Destination X1 coordinate.

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

The Pattern Seeds correspond to Destination X = 0 (horizontal) and Y = 0 (vertical). The alignment is relative to the destination coordinates. The pixel of the pattern used / scan line is the (destination X coordinate + horizontal seed) modulo 8. The scan line of the pattern used is the (destination Y coordinate + vertical seed) modulo 8.

| DWord    | Bit   | Description                                                                            |
|----------|-------|----------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                             |
|          | 28:22 | Instruction Target (Opcode): 56h                                                       |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)        |
|          | 19:17 | Monochrome source data bit position of the first pixel within a byte per scan line.    |
|          | 16:15 | Reserved.                                                                              |
|          | 14:12 | Pattern Horizontal Seed: (pixel of the scan line to start on corresponding to DST X=0) |
|          | 11    | Tiling Enable:                                                                         |
|          |       | 0 = Tiling Disabled (Linear blit)                                                      |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                               |
|          | 10:08 | Pattern Vertical Seed: (starting address of the 8x8 pattern corresponding to DST Y=0)  |
|          | 07:00 | Doubleword Length : 07h                                                                |
| 1 = BR13 | 31    | Reserved.                                                                              |
|          | 30    | Clipping Enable: (1 = enabled; 0 = disabled)                                           |
|          | 29    | <b>Mono Source Transparency Mode:</b> (1 = transparency enabled; 0 = use background)   |

Negative Stride (= Pitch) is NOT ALLOWED



| DWord    | Bit   | Description                                                                                                                                                |
|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 28:27 | Reserved.                                                                                                                                                  |
|          | 26    | Reserved.                                                                                                                                                  |
|          | 25:24 | Color Depth:                                                                                                                                               |
|          |       | 00 = 8 bit color                                                                                                                                           |
|          |       | 01 = 16 bit color (565)                                                                                                                                    |
|          |       | 10 = 16 bit color (1555)                                                                                                                                   |
|          |       | 11 = 32 bit color                                                                                                                                          |
|          | 23:16 | Raster operation:                                                                                                                                          |
|          | 15:00 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                        |
|          |       | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |
| 2 = BR22 | 31:16 | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)                                                                                     |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                           |
| 3 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                         |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                          |
| 4 = BR09 | 31:00 | <b>Destination Base Address:</b> (base address of the destination surface: X=0, Y=0)                                                                       |
|          |       | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                               |
| 5 = BR12 | 31:00 | Mono Source Address: (address corresponds to DST X1, Y1) (Note no NPO2 change here)                                                                        |
| 6 = BR18 | 31:00 | Source Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                   |
| 7 = BR19 | 31:00 | Source Foreground Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                   |
| 8 = BR15 | 31:00 | <b>Pattern Base Address:</b> (28:06 are implemented ) (Note no NPO2 change here). The pattern data must be located in linear memory.                       |

### 1.9.22 XY\_FULL\_MONO\_SRC\_IMMEDIATE\_PATTERN\_BLT

The full BLT is the most comprehensive BLT instruction. It provides the ability to specify all 3 operands: destination, source, and pattern. The source operand is a monochrome and the immediate pattern operand is the same bit width as the destination. The immediate data sizes are 64 bytes (16 DWs), 128 bytes (32 DWs), or 256 (64DWs) for 8, 16, and 32 bpp color patterns.

The monochrome source transparency mode indicates whether to use the source background color or de-assert the write enables when the bit in the source is 0. When the source bit is 1, then the source foreground color is used in the ROP operation.

All non-text monochrome sources are word aligned. At the end of a scan line the monochrome source, the remaining bits until the next word boundary are ignored. The Monochrome source data bit position field [2:0] indicates which bit position within the first byte should be used as the first source pixel which corresponds to the destination X1 coordinate.

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.



The Pattern Seeds correspond to Destination X = 0 (horizontal) and Y = 0 (vertical). The alignment is relative to the destination coordinates. The pixel of the pattern used / scan line is the (destination X coordinate + horizontal seed) modulo 8. The scan line of the pattern used is the (destination Y coordinate + vertical seed) modulo 8.

Negative Stride (= Pitch) is NOT ALLOWED.

| DWord    | Bit   | Description                                                                                                                                                          |
|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                                                                                                           |
|          | 28:22 | Instruction Target (Opcode): 75h                                                                                                                                     |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels)                                                                                      |
|          | 19:17 | Monochrome source data bit position of the first pixel within a byte per scan line.                                                                                  |
|          | 16:15 | Reserved.                                                                                                                                                            |
|          | 14:12 | Pattern Horizontal Seed: (pixel of the scan line to start on corresponding to DST X=0)                                                                               |
|          | 11    | Tiling Enable:                                                                                                                                                       |
|          |       | 0 = Tiling Disabled (Linear blit)                                                                                                                                    |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                                             |
|          | 10:08 | Pattern Vertical Seed: (starting address of the 8x8 pattern corresponding to DST Y=0)                                                                                |
|          | 07:00 | Doubleword Length : 06+ DWL = (Number of Immediate double words)h                                                                                                    |
| 1 = BR13 | 31    | Reserved.                                                                                                                                                            |
|          | 30    | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                                         |
|          | 29    | Mono Source Transparency Mode: (1 = transparency enabled; 0 = use background)                                                                                        |
|          | 28:26 | Reserved.                                                                                                                                                            |
|          | 25:24 | Color Depth:                                                                                                                                                         |
|          |       | 00 = 8 bit color                                                                                                                                                     |
|          |       | 01 = 16 bit color (565)                                                                                                                                              |
|          |       | 10 = 16 bit color (1555)                                                                                                                                             |
|          |       | 11 = 32 bit color                                                                                                                                                    |
|          | 23:16 | Raster operation:                                                                                                                                                    |
|          | 15:00 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                                  |
|          |       | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords).           |
| 2 = BR22 | 31:16 | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)                                                                                               |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                                     |
| 3 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                                   |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                                    |
| 4 = BR09 | 31:00 | <b>Destination Base Address:</b> (base address of the destination surface: X=0, Y=0)<br>When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes. |



| DWord           | Bit   | Description                                                                         |
|-----------------|-------|-------------------------------------------------------------------------------------|
| 5 = BR12        | 31:00 | Mono Source Address: (address corresponds to DST X1, Y1) (Note no NPO2 change here) |
| 6 = BR18        | 31:00 | Source Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]            |
| 7 = BR19        | 31:00 | Source Foreground Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]            |
| 8               | 31:00 | Immediate Data DW 0:                                                                |
| 9               | 31:00 | Immediate Data DW 1:                                                                |
| A thru<br>DWL+4 | S     | Immediate Data DWs 2 through DWORD_LENGTH (DWL):                                    |

# 1.9.23 XY\_FULL\_MONO\_PATTERN\_BLT

The full BLT is the most comprehensive BLT instruction. It provides the ability to specify all 3 operands: destination, source, and pattern. The pattern operand is monochrome and the source operand is the same bit width as the destination operand.

The source and destination operands may overlap, which means that the X and Y directions can be either forward or backwards. The BLT Engine takes care of all situations. The base addresses plus the X and Y coordinates determine if there is an overlap between the source and destination operands. If the base addresses of the source and destination are the same and the Source X1 is **less than** Destination X1, then the BLT Engine performs the accesses in the X-backwards access pattern. There is no need to look for an actual overlap. If the base addresses are the same and Source Y1 is **less than** Destination Y1, then the scan line accesses start at Destination Y2 with the corresponding source scan line and the strides are subtracted for every scan line access.

The monochrome pattern transparency mode indicates whether to use the pattern background color or de-assert the write enables when the bit in the source is 0. When the source bit is 1, then the pattern foreground color is used in the ROP operation.

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

The Pattern Seeds correspond to Destination X = 0 (horizontal) and Y = 0 (vertical). The alignment is relative to the destination coordinates. The pixel of the pattern used / scan line is the (destination X coordinate + horizontal seed) modulo 8. The scan line of the pattern used is the (destination Y coordinate + vertical seed) modulo 8.

Setting both Solid Pattern Select =1 & Mono Pattern Transparency = 1 is mutually exclusive. The device implementation results in NO PIXELs DRAWN.

| DWord    | Bit   | Description                                                                     |
|----------|-------|---------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                      |
|          | 28:22 | Instruction Target (Opcode): 57h                                                |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 =1= write alpha channel; 20=1= write RGB channels) |
|          | 19:16 | Reserved.                                                                       |



| DWord    | Bit   | Description                                                                                                                                            |
|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 15    | Src Tiling Enable:                                                                                                                                     |
|          |       | 0 = Tiling Disabled (Linear)                                                                                                                           |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                               |
|          | 14:12 | Pattern Horizontal Seed: (pixel of the scan line to start on corresponding to DST X=0)                                                                 |
|          | 11    | Dest Tiling Enable:                                                                                                                                    |
|          |       | 0 = Tiling Disabled (Linear)                                                                                                                           |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                               |
|          | 10:08 | Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y=0)                                                                |
|          | 07:00 | Dword Length : 0Ah                                                                                                                                     |
| 1 = BR13 | 31    | Solid Pattern Select: (1 = solid pattern; 0 = no solid pattern)                                                                                        |
|          | 30    | Clipping Enable: (1 = enabled; 0 = disabled)                                                                                                           |
|          | 29    | Reserved.                                                                                                                                              |
|          | 28:27 | Mono Pattern Transparency Mode: (1 = transparency enabled; 0 = use background)                                                                         |
|          | 26    | Reserved.                                                                                                                                              |
|          | 25:24 | Color Depth:                                                                                                                                           |
|          |       | 00 = 8 bit color                                                                                                                                       |
|          |       | 01 = 16 bit color                                                                                                                                      |
|          |       | 10 = 16 bit color (1555)                                                                                                                               |
|          |       | 11 = 32 bit color (565)                                                                                                                                |
|          | 23:16 | Raster Operation:                                                                                                                                      |
|          | 15:00 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                    |
|          |       | For Tiled Dest (bit 11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |
| 2 = BR22 | 31:16 | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)                                                                                 |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                       |
| 3 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                     |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                      |
| 4 = BR09 | 31:00 | <b>Destination Base Address:</b> (base address of the destination surface: X=0, Y=0)                                                                   |
|          |       | When Dest Tiling is enabled (Bit 11 enabled), this address is limited to 4Kbytes.                                                                      |
|          | 31:16 | Reserved.                                                                                                                                              |
| 5 = BR11 | 15:00 | Source Pitch (double word aligned and signed) and in DWords: [15:00] 2's complement.                                                                   |
|          |       | For Tiled Src (bit 15 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords).  |
| 6 = BR26 | 31:16 | Source Y1 Coordinate (Top): (31:16 = 16 bit signed number)                                                                                             |
|          | 15:00 | Source X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                            |
| 7 = BR12 | 31:00 | Source Base Address: (base address of the source surface: X=0, Y=0)                                                                                    |
|          |       | When Src Tiling is enabled (Bit 15 enabled), this address is limited to 4Kbytes.                                                                       |
|          |       | when die him gie chabled (bit to chabled), this address is innited to Hobyles.                                                                         |



| DWord    | Bit   | Description                                                               |
|----------|-------|---------------------------------------------------------------------------|
| 8 = BR16 | 31:00 | Pattern Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0] |
| 9 = BR17 | 31:00 | Pattern Foreground Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0] |
| A = BR20 | 31:00 | Pattern Data 0: (least significant DW)                                    |
| B = BR21 | 31:00 | Pattern Data 1: (most significant DW)                                     |

### 1.9.24 XY\_FULL\_MONO\_PATTERN\_MONO\_SRC\_BLT

The full BLT provides the ability to specify all 3 operands: destination, source, and pattern. The pattern and source operands are monochrome.

The monochrome source transparency mode indicates whether to use the source background color or de-assert the write enables when the bit in the source is 0. When the source bit is 1, then the source foreground color is used in the ROP operation.

All non-text monochrome sources are word aligned. At the end of a scan line the monochrome source, the remaining bits until the next word boundary are ignored. The Monochrome source data bit position field [2:0] indicates which bit position within the first byte should be used as the first source pixel which corresponds to the destination X1 coordinate.

The monochrome pattern transparency mode indicates whether to use the pattern background color or de-assert the write enables when the bit in the pattern is 0. When the source bit is 1, then the pattern foreground color is used in the ROP operation. The monochrome source transparency mode works identical to the pattern transparency mode.

All scan lines and pixels that fall within the ClipRect Y and X coordinates are written. Only pixels within the ClipRectX coordinates and the Destination X coordinates are written using the raster operation.

The Pattern Seeds correspond to Destination X = 0 (horizontal) and Y = 0 (vertical). The alignment is relative to the destination coordinates. The pixel of the pattern used / scan line is the (destination X coordinate + horizontal seed) modulo 8. The scan line of the pattern used is the (destination Y coordinate + vertical seed) modulo 8.

Setting both Solid Pattern Select =1 & Mono Pattern Transparency = 1 is mutually exclusive. The device implementation results in NO PIXELs DRAWN.

| DWord    | Bit   | Description                                                                                        |
|----------|-------|----------------------------------------------------------------------------------------------------|
| 0 = BR00 | 31:29 | Client: 02h - 2D Processor                                                                         |
|          | 28:22 | Instruction Target (Opcode): 58h                                                                   |
|          | 21:20 | <b>32 bpp byte mask:</b> (21 = 1 = write alpha channel; 20 = 1 = write RGB channels)               |
|          | 19:17 | Monochrome source data bit position of the first pixel within a byte per scan line.                |
|          | 16:15 | Reserved.                                                                                          |
|          | 14:12 | <b>Pattern Horizontal Seed:</b> (pixel of the scan line to start on corresponding to DST $X = 0$ ) |

Negative Stride (= Pitch) is NOT ALLOWED.



| DWord    | Bit   | Description                                                                                                                                                |
|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 11    | Tiling Enable:                                                                                                                                             |
|          |       | 0 = Tiling Disabled (Linear blit)                                                                                                                          |
|          |       | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                                   |
|          | 10:08 | Pattern Vertical Seed: (starting scan line of the 8x8 pattern corresponding to DST Y = 0)                                                                  |
|          | 07:00 | Doubleword Length : 0Ah                                                                                                                                    |
| 1 = BR13 | 31    | Solid Pattern Select: (1 = solid pattern; 0 = no solid pattern)                                                                                            |
|          | 30    | Clipping Enable (1 = enabled; 0 = disabled)                                                                                                                |
|          | 29    | Mono Source Transparency Mode: (1 = transparency enabled; 0 = use background)                                                                              |
|          | 28    | Mono Pattern Transparency Mode: (1 = transparency enabled; 0 = use background)                                                                             |
|          | 27:26 | Reserved.                                                                                                                                                  |
|          | 25:24 | Color Depth:                                                                                                                                               |
|          |       | 00 = 8 bit color                                                                                                                                           |
|          |       | 01 = 16 bit color (565)                                                                                                                                    |
|          |       | 10 = 16 bit color (1555)                                                                                                                                   |
|          |       | 11 = 32 bit color                                                                                                                                          |
|          | 23:16 | Raster Operation:                                                                                                                                          |
|          | 15:00 | Destination Pitch in DWords: [15:00] 2's complement                                                                                                        |
|          |       | For Tiled surfaces (bit_11 enabled) this pitch is of 512Byte granularity for Tile-X, 128B granularity for Tile-Y and can be upto 128Kbytes (or 32KDwords). |
| 2 = BR22 | 31:16 | <b>Destination Y1 Coordinate (Top):</b> (31:16 = 16 bit signed number)                                                                                     |
|          | 15:00 | Destination X1 Coordinate (Left): (15:00 = 16 bit signed number)                                                                                           |
| 3 = BR23 | 31:16 | Destination Y2 Coordinate (Bottom): (31:16 = 16 bit signed number)                                                                                         |
|          | 15:00 | Destination X2 Coordinate (Right): (15:00 = 16 bit signed number)                                                                                          |
| 4 = BR09 | 31:00 | <b>Destination Base Address:</b> (base address of the destination surface: X=0, Y=0)                                                                       |
|          |       | When Tiling is enabled (Bit_11 enabled), this address is limited to 4Kbytes.                                                                               |
| 5 = BR12 | 31:00 | Source Address: (address corresponding to Dst X1,Y1) (Note no NPO2 change here)                                                                            |
| 6 = BR18 | 31:00 | Source Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                   |
| 7 = BR19 | 31:00 | <b>Source Foreground Color:</b> 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                            |
| 8 = BR16 | 31:00 | Pattern Background Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                  |
| 9 = BR17 | 31:00 | Pattern Foreground Color: 8 bit = [7:0], 16 bit = [15:0], 32 bit = [31:0]                                                                                  |
| A =BR20  | 31:00 | Pattern Data 0: (least significant DW)                                                                                                                     |
| B =BR21  | 31:00 | Pattern Data 1: (most significant DW)                                                                                                                      |



## **1.10 BLT Engine Instruction Field Definitions**

This section describes the BLT Engine instruction fields. These descriptions are in the format of register descriptions. These registers are internal and are not readable. Some of these registers are state that is saved and restored for supporting separate software threads.

#### 1.10.1 BR00—BLT Opcode & Control

Memory Offset Address: none

Default: 0000 0000

Attributes: not accessible

BR00 is the last executed instruction DWord 0. Bits [22:5] are written by every DW0 of every instruction. Bits [31:30] and [4:0] are status bits. Bits [28:27] are written from the DW0 [15:14] of a Setup instruction and Bit 29 is written with a 1 when ever a Setup instruction is written. Bit 29 is a decode of the Setup instruction Opcode.

| 31                             | 30           | 29                       | 28        |            |                    | 24                    |
|--------------------------------|--------------|--------------------------|-----------|------------|--------------------|-----------------------|
| Rsvd                           | Clip<br>Inst | Setup<br>Mono<br>Pattern |           | Instructio | on Target (Opcode) |                       |
| 23                             | 22           | 21                       | 20        | 19         | 17                 | 16                    |
| Instruction Target<br>(Opcode) |              | 32 bpp b                 | oyte mask | Monoch     | rome Source Start  | Bit (0) /<br>Byte (1) |

| 15   | 14 | 12                      | 11               | 10 | 8                       |
|------|----|-------------------------|------------------|----|-------------------------|
| Rsvd |    | Pattern Horizontal Seed | Tiling<br>Enable |    | Transparency Range Mode |

| 7 | 5                    | 4          | 3               | 2              | 1                | 0               |
|---|----------------------|------------|-----------------|----------------|------------------|-----------------|
|   | PatternVertical Seed | DST<br>RMW | Color<br>Source | Mono<br>Source | Color<br>Pattern | Mono<br>Pattern |

Packed



| Bit       | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31        | <b>BLT Engine Busy.</b> This bit indicates whether the BLT Engine is busy (1) or idle (0). This bit is replicated in the SETUP BLT Opcode & Control register.                                                                                                                                                                                                                                                                                        |
|           | 1 = Busy                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           | 0 = Idle                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 30        | Setup Instruction Instruction. The current instruction performs clipping (1).                                                                                                                                                                                                                                                                                                                                                                        |
| 29        | <b>Setup Monochrome Pattern.</b> This bit is decoded from the Setup instruction opcode to identify whether a color (0) or monochrome (1) pattern is used with the SCANLINE_BLT instruction.                                                                                                                                                                                                                                                          |
|           | 1 = Monochrome                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|           | 0 = Color                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 28:2<br>2 | <b>Instruction Target (Opcode).</b> This is the contents of the Instruction Target field from the last BLT instruction. This field is used by the BLT Engine state machine to identify the BLT instruction it is to perform. The opcode specifies whether the source and pattern operands are color or monochrome.                                                                                                                                   |
| 21:2<br>0 | <b>32 bpp byte mask:</b> 21 = 1 = write alpha channel [31:24]; 20 = 1 = write RGB channels [23:00]. This field is only used for 32bpp.                                                                                                                                                                                                                                                                                                               |
| 19:1<br>7 | <b>Monochrome Source Start.</b> This field indicates the starting monochrome pixel bit position within a byte per scan line of the source operand. The monochrome source is word aligned which means that at the end of the scan line all bits should be discarded until the next word boundary.                                                                                                                                                     |
| 16        | Bit/Byte Packed . Byte packed is for the NT driver                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | 0 = Bit                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           | 1 = Byte                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15        | Src Tiling Enable:                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | 0 = Tiling Disabled (Linear)                                                                                                                                                                                                                                                                                                                                                                                                                         |
|           | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                                                                                                                                                                                                                                                                                                                             |
| 14:1<br>2 | <b>Horizontal Pattern Seed.</b> This field indicates the pattern pixel position which corresponds to X = 0.                                                                                                                                                                                                                                                                                                                                          |
| 11        | Dest Tiling Enable:                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | 0 = Tiling Disabled (Linear blit)                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | 1 = Tiling enabled ( <u>DevSNB</u> + : Tile-X or Tile-Y)                                                                                                                                                                                                                                                                                                                                                                                             |
|           | When set to '1', this means that Blitter is executing in Tiled mode. If '0' it means that Blitter is in Linear mode. Pre-Dev Blitter never executes in Tiled-Y mode, DevSNB+ Blitter supports both Tile-X and Tile-Y modes. On reset, this bit will be '0'. This definition applies to only X,Y Blits. Non-XY blits (COLOR_BLT, SRC_COPY_BLT), will support only linear mode and will not support tiling and for them this bit will remain reserved. |



| Bit  | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8 | <b>Transparency Range Mode.</b> These bits control whether or not the byte(s) at the destination corresponding to a given pixel will be conditionally written, and what those conditions are. This feature can make it possible to perform various masking functions in order to selectively write or preserve graphics data already at the destination.                                                                                                                                                                                                                                          |
|      | XX0 = No color transparency mode enabled. This causes normal operation with regard to writing data to the destination.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      | 001 = <b>[Source color transparency]</b> The <b>Transparency Color Low:</b> (Pixel Greater or Equal) (source background register) and the <b>Transparency Color High:</b> (Pixel Less or Equal) (source foreground register) are compared to the source pixels. The range comparisons are done on each component (R,G,B) and then logically ANDed. If the source pixel components are not within the range defined by the Transparency Color registers, then the byte(s) at the destination corresponding to the current pixel are written with the result of the bit-wise operation.             |
|      | 011 = <b>[Source and Alpha color transparency]</b> The <b>Transparency Color Low:</b> (Pixel Greater or Equal) (source background register) and the <b>Transparency Color High:</b> (Pixel Less or Equal) (source foreground register) are compared to the source pixels. The range comparisons are done on each component (A,R,G,B) and then logically ANDed. If the source pixel components are not within the range defined by the Transparency Color registers, then the byte(s) at the destination corresponding to the current pixel are written with the result of the bit-wise operation. |
|      | 101 = <b>[Destination and Alpha color transparency]</b> The <b>Transparency Color Low:</b> (Pixel Greater or Equal) (source background register) and the <b>Transparency Color High:</b> (Pixel Less or Equal) (source foreground register) are compared to the destination pixels. The range comparisons are done on each component (A,R,G,B) and then logically ANDed. If the destination pixels are within the range, then the byte(s) at the destination corresponding to the current pixel are written with the result of the bit-wise operation.                                            |
|      | 111 = <b>[Destination color transparency]</b> The <b>Transparency Color Low:</b> (Pixel Greater or Equal) (source background register) and the <b>Transparency Color High:</b> (Pixel Less or Equal) (source foreground register) are compared to the destination pixels. The range comparisons are done on each component (R,G,B) and then logically ANDed. If the destination pixels are within the range, then the byte(s) at the destination corresponding to the current pixel are written with the result of the bit-wise operation.                                                        |
| 7:5  | Pattern Vertical Seed. This field specifies the pattern scan line which corresponds to Y=0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 4    | <b>Destination Read Modify Write.</b> This bit is decoded from the last instruction's opcode field and Destination Transparency Mode to identify whether a Destination read is needed.                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3    | <b>Color Source.</b> This bit is decoded from the last instructions opcode field to identify whether a color (1) source is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2    | <b>Monochrome Source.</b> This bit is decoded from the last instructions opcode field to identify whether a monochrome (1) source is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1    | <b>Color Pattern.</b> This bit is decoded from the last instructions opcode field to identify whether a color (1) pattern is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0    | <b>Monochrome Pattern.</b> This bit is decoded from the last instructions opcode field to identify whether a monochrome (1) pattern is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



#### 1.10.2 BR01—Setup BLT Raster OP, Control, and Destination Offset

Memory Offset Address: none

Default: 0000 xxxx

Attributes:

State accessible

BR01 contains the contents of the last Setup instruction DWord 1. It is identical to the BLT Raster OP, Control, and Destination Offset definition, but it is used with the following instructions: PIXEL\_BLT, SCANLINE\_BLT, and TEXT\_BLT.





| Bit | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31  | <b>Solid Pattern Select.</b> This bit applies only when the pattern data is monochrome. This bit determines whether or not the BLT Engine actually performs read operations from the frame buffer in order to load the pattern data. Use of this feature to prevent these read operations can increase BLT Engine performance, if use of the pattern data is indeed not necessary. The BLT Engine is configured to accept either monochrome or color pattern data via the opcode field. |  |  |  |  |
|     | 0 = This causes normal operation with regard to the use of the pattern data. The BLT Engine proceeds with the process of reading the pattern data, and the pattern data is used as the pattern operand for all bit-wise operations.                                                                                                                                                                                                                                                     |  |  |  |  |
|     | 1 = The BLT Engine forgoes the process of reading the pattern data, the presumption is made that all of the bits of the pattern data are set to 0, and the pattern operand for all bit-wise operations is forced to the background color specified in the Color Expansion Background Color Register.                                                                                                                                                                                    |  |  |  |  |
| 30  | Clipping Enabled: 1 = Enabled; 0 = Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |



| Bit   | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 29    | <b>Monochrome Source Transparency Mode.</b> This bit applies only when the source data is in monochrome. This bit determines whether or not the byte(s) at the destination corresponding to the pixel to which a given bit of the source data also corresponds will actually be written if that source data bit has the value of 0. This feature can make it possible to use the source as a transparency mask. The BLT Engine is configured to accepted either monochrome or color source data via the opcode field.    |  |  |  |  |  |
|       | 0 = This causes normal operation with regard to the use of the source data. Wherever a bit in the source data has the value of 0, the color specified in the background color register is used as the source operand in the bit-wise operation for the pixel corresponding to the source data bit, and the bytes at the destination corresponding to that pixel are written with the result.                                                                                                                             |  |  |  |  |  |
|       | 1 = Wherever a bit in the source data has the value of 0, the byte(s) at the destination corresponding to the pixel to which the source data bit also corresponds are simply not written, and the data at those byte(s) at the destination are allowed to remain unchanged.                                                                                                                                                                                                                                              |  |  |  |  |  |
| 28    | <b>Monochrome Pattern Transparency Mode.</b> This bit applies only when the pattern data is monochrome. This bit determines whether or not the byte(s) at the destination corresponding to the pixel to which a given bit of the pattern data also corresponds will actually be written if that pattern data bit has the value of 1. This feature can make it possible to use the pattern as a transparency mask. The BLT Engine is configured to accepted either monochrome or color pattern data via the opcode field. |  |  |  |  |  |
|       | 0 = This causes normal operation with regard to the use of the pattern data. Wherever a bit in the pattern data has the value of 0, the color specified in the background color register is used as the pattern operand in the bit-wise operation for the pixel corresponding to the pattern data bit, and the bytes at the destination corresponding to that pixel are written with the result.                                                                                                                         |  |  |  |  |  |
|       | 1 = Wherever a bit in the pattern data has the value of 0, the byte(s) at the destination corresponding to the pixel to which the pattern data bit also corresponds are simply not written, and the data at those byte(s) at the destination are allowed to remain unchanged.                                                                                                                                                                                                                                            |  |  |  |  |  |
| 27:26 | <b>32 bpp byte mask.</b> 21 = 1 = write alpha channel [31:24]; 20 = 1 = write RGB channels [23:00]. This field is only used for 32bpp.                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| 25:24 | Color Depth.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|       | 00 = 8 Bit Color Depth                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|       | 01 = 16 Bit Color Depth                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|       | 10 = 16 Bit Color Depth                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|       | 11 = 32 Bit Color Depth                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| 23:16 | <b>Raster Operation Select.</b> These 8 bits are used to select which one of 256 possible raster operations is to be performed by the BLT Engine. The 8-bit values, and their corresponding raster operations, are intended to correspond to the 256 possible raster operations specified for graphics device drivers The opcode field must indicate a monochrome source if ROP = F0.                                                                                                                                    |  |  |  |  |  |



| Bit  | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 15:0 | Destination Pitch (Offset).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|      | For non-XY Blits, the signed 16bit field allows for specifying upto $\pm$ 32Kbytes signed pitches in bytes (same as before).                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|      | For X, Y Blits with tiled-X surfaces, the pitch for Destination will be 512Byte aligned and should be programmable upto $\pm$ 128Kbytes. For X, Y Blits with tiled-Y surfaces, the pitch for Destination will be 128Byte aligned and should be programmable upto $\pm$ 128Kbytes. In this case, this 16bit signed pitch fi is used to specify upto $\pm$ 32K <b>DWords</b> . For X, Y blits with nontiled surfaces (linear surfaces), this 16bit field can be programmed to byte specification of upto $\pm$ 32Kbytes (same as before).                        |  |  |  |  |
|      | These 16 bits store the signed memory address offset value by which the destination address originally specified in the Destination Address Register is incremented or decremented as each scan line's worth of destination data is written into the frame buffer by the BLT Engine, so that the destination address will point to the next memory address to which the next scan line's worth of destination data is to be written.                                                                                                                           |  |  |  |  |
|      | If the intended destination of a BLT operation is within on-screen frame buffer memory, this offset is normally set so that each subsequent scan line's worth of destination data lines up vertically with the destination data in the scan line, above. However, if the intended destination of a BLT operation is within off-screen memory, this offset can be set so that each subsequent scan line's worth of destination data for the last scan line ended, in order to create a single contiguous block of bytes of destination data at the destination. |  |  |  |  |

## 1.10.3 BR05—Setup Expansion Background Color

| Memory Offset Address: | none             |  |  |
|------------------------|------------------|--|--|
| Default:               | None             |  |  |
| Attributes:            | State accessible |  |  |

31 0 Setup Expansion Background Color Bits [31:0]

| Bit  | Descriptions                                                                                                                                                                                                                                                                                                                                         |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Setup Expansion Background Color Bits [31:0]. These bits provide the one, two, or four bytes worth of color data that select the background color to be used in the color expansion of monochrome pattern or source data for either the SCANLINE_BLT or TEXT_BLT instructions. BR05 is also used as the solid pattern for the PIXEL_BLT instruction. |
|      | Whether one, two, or three bytes worth of color data is needed depends upon the color depth to which the BLT Engine has been set. For a color depth of 32bpp, 16bpp and 8bpp, bits [31:0], [15:0] and [7:0], respectively, are used.                                                                                                                 |



## 1.10.4 BR06—Setup Expansion Foreground Color

none

None

Memory Offset Address:

Default:

Attributes:

State accessible

 31
 0

 Setup Expansion Foreground Color Bits [31:0]

| Bit   | Descriptions                                                                                                                                                                                                                                                                   |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved.                                                                                                                                                                                                                                                                      |
| 31:0  | Setup Expansion Foreground Color Bits [31:0]. These bits provide the one, two, or four bytes worth of color data that select the foreground color to be used in the color expansion of monochrome pattern or source data for either the SCANLINE_BLT or TEXT_BLT instructions. |
|       | Whether one, two, or three bytes worth of color data is needed depends upon the color depth to which the BLT Engine has been set. For a color depth of 32bpp, 16bpp and 8bpp, bits [31:0], [15:0] and [7:0], respectively, are used.                                           |

## 1.10.5 BR07—Setup Color Pattern Address

Memory Offset Address: none

Default:

None

State accessible

Attributes:

 31
 29
 28
 16

 Reserved
 Setup Color Pattern Address Bits [28:16]

| 15 |                                         | 6 | 5 | 0        |
|----|-----------------------------------------|---|---|----------|
|    | Setup Color Pattern Address Bits [15:6] |   |   | Reserved |



| Bit                                                                                                                                                                                                                                                                                                                  | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:2<br>9                                                                                                                                                                                                                                                                                                            | Reserved. The maximum GC graphics address is 512 MBs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| 28:6 <b>Pattern Address.</b> These 23 bits specify the starting address of the color pattern from the SETUP_BI instruction. This register works identically to the Pattern Address register, but this version is only use the SCANLINE_BLT instruction execution. The pattern data must be located in linear memory. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                      | The pattern data must be located on a pattern-size boundary. The pattern is always of 8x8 pixels, and therefore, its size is dependent upon its pixel depth. The pixel depth may be 8, 16, or 32 bits per pixel if the pattern is in color (the pixel depth of a color pattern must match the pixel depth to which the graphics system has been set). Monochrome patterns require 8 bytes and is supplied through the instruction. Color patterns of 8, 16, and 32 bits per pixel color depth must start on 64-byte, 128-byte and 256-byte boundaries, respectively. |  |  |  |  |
| 5:0                                                                                                                                                                                                                                                                                                                  | Reserved. These bits always return 0 when read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |

## 1.10.6 BR09—Destination Address

| Memory Offset Address: | None             |
|------------------------|------------------|
| Default:               | None             |
| Attributes:            | State accessible |

| 31 29    | 28                                                       | 0 |
|----------|----------------------------------------------------------|---|
| Reserved | Destination and Destination Y1 and Y Address Bits [28:0] |   |

| Bit       | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:2<br>9 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| 28:0      | <b>Destination Address Bits.</b> When tiling is enabled for XY-blits, this base address should be limited to 4KB. Otherwise for XY blits, there is no restriction and it is same as before.                                                                                                                                                                                                                             |  |  |  |
|           | These 29 bits specify the starting pixel address of the destination data. This register is also the working destination address register and changes as the BLT Engine performs the accesses.                                                                                                                                                                                                                           |  |  |  |
|           | Used as the scan line address (Destination Y Address & Destination Y1 Address) for BLT instructions:<br>PIXEL_BLT, SCANLINE_BLT, and TEXT_BLT. In this case the address points to the first pixel in a scan<br>line and is compared with the ClipRect Y1 & Y2 address registers to determine whether the scan line<br>should be written or not. The Destination Y1 address is the top scan line to be written for text. |  |  |  |
|           | Note that for non-XY blits (COLOR_BLT, SRC_COPY_BLT), this address points to the first byte to be written.                                                                                                                                                                                                                                                                                                              |  |  |  |
|           | This register is always the last register written for a BLT drawing instruction. Writing BR09 starts the BLT engine execution.                                                                                                                                                                                                                                                                                          |  |  |  |
|           | <i>Note:</i><br>Some instructions affect only one scan line (requiring only one coordinate); other instructions affect multiple scan lines and need both coordinates.                                                                                                                                                                                                                                                   |  |  |  |



## 1.10.7 BR11—BLT Source Pitch (Offset)

Memory Offset Address:

None None

Default:

Attributes:

Not accessible

| 31                    | 16 | 15 |                       | 0 |
|-----------------------|----|----|-----------------------|---|
| BLT Engine Status - T | BS |    | Source Pitch (Offset) |   |

| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:1<br>6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 15:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Source Pitch (Offset)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | For non-XY Blits with color source operand (SRC_COPY_BLT), the signed 16bit field allows for specifying upto <u>+</u> 32Kbytes signed pitch in bytes (same as before).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| For X, Y Blits with tiled-X surfaces, the pitch for Color Source will be 512Byte aligned and sho<br>programmable upto <u>+</u> 128Kbytes. For X, Y Blits with tiled-Y surfaces, the pitch for Color Sour<br>128Byte aligned and should be programmable upto <u>+</u> 128Kbytes. In this case, this 16bit signed<br>used to specify upto <u>+</u> 32K <b>DWords</b> . For X, Y blits with nontiled color source surfaces (linear<br>16bit field can be programmed to byte specification of upto <u>+</u> 32Kbytes (same as before). |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | When the color source data is located within the frame buffer or AGP aperture, these signed 16 bits store the memory address offset (pitch) value by which the source address originally specified in the Source Address Register is incremented or decremented as each scan line's worth of source data is read from the frame buffer by the BLT Engine, so that the source address will point to the next memory address from which the next scan line's worth of source data is to be read.                                                                                                                                                        |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Note that if the intended source of a BLT operation is within on-screen frame buffer memory, this offset is normally set to accommodate the fact that each subsequent scan line's worth of source data lines up vertically with the source data in the scan line, above. However, if the intended source of a BLT operation is within off-screen memory, this offset can be set to accommodate a situation in which the source data exists as a single contiguous block of bytes where in each subsequent scan line's worth of source data is stored at a location immediately after the location where the source data for the last scan line ended. |  |



#### 1.10.8 BR12—Source Address

| Memory Offset Address: | None           |
|------------------------|----------------|
| Default:               | None           |
| Attributes:            | Not accessible |

| 31 | 29       | 28 |                            | 0 |
|----|----------|----|----------------------------|---|
|    | Reserved |    | Source Address Bits [28:0] |   |

| Bit                                                                                                                                                                                                                                                   | Descriptions                                                                                                                                                                                                    |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:2<br>9                                                                                                                                                                                                                                             | Reserved. The maximum GC Graphics address is 512 MBs.                                                                                                                                                           |  |  |  |  |
| 28:0 <b>Source Address Bits [28:0].</b> When tiling is enabled for XY-blits with Color source surfaces, the address should be limited to 4KB. Otherwise for XY blits, there is no restriction and it is same including for monosource and text blits. |                                                                                                                                                                                                                 |  |  |  |  |
|                                                                                                                                                                                                                                                       | Note that for non-XY blit with Color Source (SRC_COPY_BLT), this address points to the first byte to be read.                                                                                                   |  |  |  |  |
|                                                                                                                                                                                                                                                       | These 29 bits are used to specify the starting pixel address of the color source data. The lower 3 bits are used to indicate the position of the first valid byte within the first Quadword of the source data. |  |  |  |  |

## 1.10.9 BR13—BLT Raster OP, Control, and Destination Pitch

| Memory Offset Address: | None           |
|------------------------|----------------|
| Default:               | 0000 xxxx      |
| Attributes:            | Not accessible |

| 31               | 30                 | 29                | 28                | 27   | 26           | 25 | 24          |
|------------------|--------------------|-------------------|-------------------|------|--------------|----|-------------|
| Solid<br>Pattern | Clipping<br>Enable | Mono Src<br>Trans | Mono Pat<br>Trans | 32 b | pp byte mask |    | Color Depth |

| 23 |                  | 16 |
|----|------------------|----|
|    | Raster Operation |    |
|    |                  |    |
| 15 |                  | 0  |

|                            | 0 |
|----------------------------|---|
| Destination Pitch (Offset) |   |



| Bit   | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | <b>Solid Pattern Select.</b> This bit applies only when the pattern data is monochrome. This bit determines whether or not the BLT Engine actually performs read operations from the frame buffer in order to load the pattern data. Use of this feature to prevent these read operations can increase BLT Engine performance, if use of the pattern data is indeed not necessary. The BLT Engine is configured to accept either monochrome or color pattern data via the opcode field.                                                               |
|       | 0 = This causes normal operation with regard to the use of the pattern data. The BLT Engine proceeds with the process of reading the pattern data, and the pattern data is used as the pattern operand for all bit-wise operations.                                                                                                                                                                                                                                                                                                                   |
|       | 1 = The BLT Engine forgoes the process of reading the pattern data, the presumption is made that all of the bits of the pattern data are set to 0, and the pattern operand for all bit-wise operations is forced to the background color specified in the Color Expansion Background Color Register.                                                                                                                                                                                                                                                  |
| 30    | Clipping Enabled: 1 = Enabled; 0 = Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 29    | <b>Monochrome Source Transparency Mode.</b> This bit applies only when the source data is in monochrome. This bit determines whether or not the byte(s) at the destination corresponding to the pixel to which a given bit of the source data also corresponds will actually be written if that source data bit has the value of 0. This feature can make it possible to use the source as a transparency mask. The BLT Engine is configured to accepted either monochrome or color source data via the opcode field.                                 |
|       | 0 = This causes normal operation with regard to the use of the source data. Wherever a bit in the source data has the value of 0, the color specified in the background color register is used as the source operand in the bit-wise operation for the pixel corresponding to the source data bit, and the bytes at the destination corresponding to that pixel are written with the result.                                                                                                                                                          |
|       | 1 = Where a bit in the source data has the value of 0, the byte(s) at the destination corresponding to the pixel to which the source data bit also corresponds are simply not written, and the data at those byte(s) at the destination are allowed to remain unchanged.                                                                                                                                                                                                                                                                              |
| 28    | <b>Monochrome Pattern Transparency Mode.</b> This bit applies only when the pattern data is monochrome. This bit determines whether or not the byte(s) at the destination corresponding to the pixel to which a given bit of the pattern data also corresponds will actually be written if that pattern data bit has the value of 1. This feature can make it possible to use the pattern as a transparency mask. The BLT Engine is configured to accepted either monochrome or color pattern data via the opcode in the Opcode and Control register. |
|       | 0 = This causes normal operation with regard to the use of the pattern data. Where a bit in the pattern data has the value of 0, the color specified in the background color register is used as the pattern operand in the bit-wise operation for the pixel corresponding to the pattern data bit, and the bytes at the destination corresponding to that pixel are written with the result.                                                                                                                                                         |
|       | 1= Wherever a bit in the pattern data has the value of 0, the byte(s) at the destination corresponding to the pixel to which the pattern data bit also corresponds are simply not written, and the data at those byte(s) at the destination are allowed to remain unchanged.                                                                                                                                                                                                                                                                          |
| 25:24 | Color Depth.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|       | 00 = 8 Bit Color Depth                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | 01 = 16 Bit Color Depth                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 10 = 24 Bit Color Depth                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 11 = Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 23:16 | <b>Raster Operation Select.</b> These 8 bits are used to select which one of 256 possible raster operations is to be performed by the BLT Engine. The 8-bit values, and their corresponding raster operations, are intended to correspond to the 256 possible raster operations specified for graphics device drivers. The opcode must indicate a monochrome source operand if ROP = F0.                                                                                                                                                              |



| Bit  | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | <b>Destination Pitch (Offset).</b> These 16 bits store the signed memory address offset value by which the destination address originally specified in the Destination Address Register is incremented or decremented as each scan line's worth of destination data is written into the frame buffer by the BLT Engine, so that the destination address will point to the next memory address to which the next scan line's worth of destination data is to be written.                                                                                                                                                                          |
|      | If the intended destination of a BLT operation is within on-screen frame buffer memory, this offset is normally set so that each subsequent scan line's worth of destination data lines up vertically with the destination data in the scan line, above. However, if the intended destination of a BLT operation is within off-screen memory, this offset can be set so that each subsequent scan line's worth of destination data is stored at a location immediately after the location where the destination data for the last scan line ended, in order to create a single contiguous block of bytes of destination data at the destination. |

#### 1.10.10 BR14—Destination Width and Height

| Memory Offset Address: | None |
|------------------------|------|
| Default:               | None |

Attributes: Not accessible

BR14 contains the values for the height and width of the data to be BLT. If these values are not correct, such that the BLT Engine is either expecting data it does not receive or receives data it did not expect, the system can hang.

| 31 | 29       | 28                 | 16 |
|----|----------|--------------------|----|
|    | Reserved | Destination Height |    |
|    |          |                    |    |

| 15 | 13       | 12    | 0                 |
|----|----------|-------|-------------------|
|    | Reserved | Desti | nation Byte Width |

| Bit       | Descriptions                                                                                                                                                                                                                                                                      |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2<br>9 | Reserved.                                                                                                                                                                                                                                                                         |
| 28:1<br>6 | <b>Destination Height.</b> These 13 bits specify the height of the destination data in terms of the number of scan lines. This is a working register.                                                                                                                             |
| 15:1<br>3 | Reserved.                                                                                                                                                                                                                                                                         |
| 12:0      | <b>Destination Byte Width.</b> These 13 bits specify the width of the destination data in terms of the number of bytes per scan line. The number of pixels per scan line into which this value translates depends upon the color depth to which the graphics system has been set. |



## 1.10.11 BR15—Color Pattern Address

| Memory Offset Address: | None           |
|------------------------|----------------|
| Default:               | None           |
| Attributes:            | Not accessible |

.

| Reserved Color Pattern Address Bits [28:16] |  |
|---------------------------------------------|--|

| 15 |                                   | 6 | 5 | 0        |
|----|-----------------------------------|---|---|----------|
|    | Color Pattern Address Bits [15:6] |   |   | Reserved |

| Bit       | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2<br>9 | Reserved. The maximum GC graphics address is 512 MBs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 28:6      | <b>Color Pattern Address.</b> There is no change to the Color Pattern address specification due to Non-Power-<br>of-2 change. It remains the same as before. The pattern data must be located in linear memory.                                                                                                                                                                                                                                                                                                                                                      |
|           | These 23 bits specify the starting address of the pattern.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|           | The pattern data must be located on a pattern-size boundary. The pattern is always of 8x8 pixels, and therefore, its size is dependent upon its pixel depth. The pixel depth may be 8, 16, or 32 bits per pixel if the pattern is in color (the pixel depth of a color pattern must match the pixel depth to which the graphics system has been set). Monochrome patterns require 8 bytes and are applied through the instruction. Color patterns of 8, 16, and 32 bits per pixel color depth must start on 64-byte, 128-byte and 256-byte boundaries, respectively. |
| 5:0       | Reserved. These bits always return 0 when read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



#### 1.10.12 BR16—Pattern Expansion Background and Solid Pattern Color

| Memory Offset Address: | Memorv | Offset | Address: |  |
|------------------------|--------|--------|----------|--|
|------------------------|--------|--------|----------|--|

40040h

Default:

None

Attributes:

RO; DWord accessible

| 31 |                                                | 0 |
|----|------------------------------------------------|---|
|    | Pattern Expansion Background Color Bits [31:0] |   |

| Bit  | Descriptions                                                                                                                                                                                                                            |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Pattern Expansion Background Color Bits [31:0]. These bits provide the one, two, or four bytes worth of color data that select the background color to be used in the color expansion of monochrome pattern data during BLT operations. |
|      | Whether one, two, or four bytes worth of color data is needed depends upon the color depth to which the BLT Engine has been set. For a color depth of 32bpp, 16bpp and 8bpp, bits [31:0], [15:0] and [7:0], respectively, are used.     |

## 1.10.13 BR17—Pattern Expansion Foreground Color

| Memory Offset Address: | None           |
|------------------------|----------------|
| Default:               | None           |
| Attributes:            | Not accessible |
|                        |                |

| 31 |                                                | 0 |
|----|------------------------------------------------|---|
|    | Pattern Expansion Foreground Color Bits [31:0] |   |

| Bit  | Descriptions                                                                                                                                                                                                                            |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Pattern Expansion Foreground Color Bits [31:0]. These bits provide the one, two, or four bytes worth of color data that select the foreground color to be used in the color expansion of monochrome pattern data during BLT operations. |
|      | Whether one, two, or four bytes worth of color data is needed depends upon the color depth to which the BLT Engine has been set. For a color depth of 32bpp, 16bpp and 8bpp, bits [31:0], [15:0] and [7:0], respectively, are used.     |



#### 1.10.14 BR18—Source Expansion Background, and Destination Color

Memory Offset Address:

Default:

Attributes:

Not accessible

None

None

31 0 Source Expansion Background Color Bits [31:0]

| Bit  | Descriptions                                                                                                                                                                                                                                 |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | <b>Source Expansion Background Color Bits [31:0].</b> These bits provide the one, two, or four bytes worth of color data that select the background color to be used in the color expansion of monochrome source data during BLT operations. |
|      | This register is also used to support destination transparency mode and Solid color fill.                                                                                                                                                    |
|      | Whether one, two, three, or four bytes worth of color data is needed depends upon the color depth to which the BLT Engine has been set. For a color depth of 32bpp, 16bpp and 8bpp, bits [31:0], [15:0] and [7:0], respectively, are used.   |

#### 1.10.15 BR19—Source Expansion Foreground Color

Memory Offset Address: None

Default:

None

Attributes:

Not accessible

31 0 Pattern Expansion Foreground Color Bits [31:0]

| Bit  | Descriptions                                                                                                                                                                                                                                  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Pattern/Source Expansion Foreground Color Bits [31:0]. These bits provide the one, two, or four bytes worth of color data that select the foreground color to be used in the color expansion of monochrome source data during BLT operations. |
|      | Whether one, two, or four bytes worth of color data is needed depends upon the color depth to which the BLT Engine has been set. For a color depth of 32bpp, 16bpp and 8bpp, bits [31:0], [15:0] and [7:0], respectively, are used.           |



## 2. Blitter (Blt) Engine Command Streamer

The Blitter register interface is only implemented on DevSNB+.

A separate pipeline for blitter operations is introduced on DevSNB+. This pipeline has its own command streamer and operates completely independently of the other command streamers. This command streamer supports a separate set of registers starting at offset 20000h.

## 2.1 Registers for Blitter Engine

#### 2.1.1 Introduction

Each register is at the same offset from 020000h as its primary counterpart is offset from 02000h.



## 2.1.2 GAB PWR CTX STORAGE REGISTERS

#### 2.1.2.1 GAB\_CTL\_REG – GAB unit Control Register

|                                                                              | GAB_CTL_REG |                                                                                                                                                                                                                    |  |
|------------------------------------------------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Register Type:                                                               |             | MMIO                                                                                                                                                                                                               |  |
| Address Offset:                                                              |             | 24000h                                                                                                                                                                                                             |  |
| Project:                                                                     |             | DevSNB+                                                                                                                                                                                                            |  |
| Default Value:                                                               |             | FF0000BFh                                                                                                                                                                                                          |  |
| Access:                                                                      |             | R/W                                                                                                                                                                                                                |  |
| Size (in bi                                                                  | ts):        | 32                                                                                                                                                                                                                 |  |
| Trusted T                                                                    | ype:        | 1                                                                                                                                                                                                                  |  |
| Bit                                                                          |             | Description                                                                                                                                                                                                        |  |
| 31:9 Reserved                                                                |             | ved                                                                                                                                                                                                                |  |
| 8                                                                            |             | ontinue after Page Fault. If set to 1: upon receiving a page fault when requesting an address translation, AB will set address bit 39 to 1 and continue. If set to 0: GAB will hang on a page fault. Default = b0. |  |
|                                                                              | Contro      | ol added in C-step ECO.                                                                                                                                                                                            |  |
|                                                                              | NOTE        | E TO DRIVER: for gen6 this bit needs to be written to "1"                                                                                                                                                          |  |
| 7:6 PPGTT BCS TLB LRA MIN: TLB Depth Partitioning Register In PP GTT Mode. D |             | T BCS TLB LRA MIN: TLB Depth Partitioning Register In PP GTT Mode. Default = b10                                                                                                                                   |  |
| 5:4                                                                          | GAB         | write request priority signal value used in GAC arbitration. Default = b11                                                                                                                                         |  |
| 3:2                                                                          | GAB         | read only request priority signal value used in GAC arbitration. Default = b11                                                                                                                                     |  |
| 1:0                                                                          | GAB         | read request priority signal value used in GAC arbitration. Default = b11                                                                                                                                          |  |



## 2.1.3 Virtual Memory Control

#### 2.1.3.1 BCS\_HWS\_PGA — Hardware Status Page Address Register

| E                      | BCS_HWS_PGA — Hardware Status Page A                                                                                                                                                                                                                                           | ddress Register                                               |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| Register T             | Type: MMIO_BCS                                                                                                                                                                                                                                                                 |                                                               |
|                        | Offset: 24080 for [DevSNB]                                                                                                                                                                                                                                                     |                                                               |
| _                      |                                                                                                                                                                                                                                                                                |                                                               |
| Project:               | DevSNB                                                                                                                                                                                                                                                                         |                                                               |
| Default Val            |                                                                                                                                                                                                                                                                                |                                                               |
| Access:                | R/W                                                                                                                                                                                                                                                                            |                                                               |
| Size (in bit           |                                                                                                                                                                                                                                                                                |                                                               |
| Trusted Ty             | ype: 1<br>ster is used to program the 4 KB-aligned System Memory address                                                                                                                                                                                                       |                                                               |
| register is snoop nati | eport hardware status into (typically cacheable) System Memory.<br>s translated using the Global GTT in memory. The mapping type of<br>ture of the transaction to memory.<br><b>ning Notes</b><br>-] If this register is written, a workload must subsequently be dispatched t | of the GTT entry determines the                               |
| Bit                    |                                                                                                                                                                                                                                                                                |                                                               |
| ыт                     | Description                                                                                                                                                                                                                                                                    |                                                               |
| 31:12                  | Address                                                                                                                                                                                                                                                                        |                                                               |
|                        | Project: DevSNB                                                                                                                                                                                                                                                                |                                                               |
|                        | Security: None                                                                                                                                                                                                                                                                 |                                                               |
|                        | Address: GraphicsAddress[31:12]                                                                                                                                                                                                                                                |                                                               |
|                        | This field is used by SW to specify Bits 31:12 of the 4 KB-aligned Sys page known as the "Hardware Status Page". The Global GTT is used graphics virtual address to physical address                                                                                           | tem Memory address of the 4 KB<br>I to map this page from the |
|                        | Programming Notes                                                                                                                                                                                                                                                              |                                                               |
|                        | If the Per-Process Virtual Address Space is set, HW requires that th allow for the context switch status to be reported                                                                                                                                                        | e status page is programmed to                                |
| 12:1                   | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                              |                                                               |
| 0                      | Translation in Progress                                                                                                                                                                                                                                                        |                                                               |
|                        | Project: DevSNB                                                                                                                                                                                                                                                                |                                                               |
|                        | Access: RO                                                                                                                                                                                                                                                                     |                                                               |
|                        | Format: U1                                                                                                                                                                                                                                                                     |                                                               |
|                        | This field indicates that the translation for the hardware status page fr<br>to the physical address is pending. Software can use this indicator to<br>when there is a pending cycle for translation.                                                                          |                                                               |



The following table defines the layout of the Hardware Status Page:

| DWord<br>Offset  | Description                                                                                                                                                                                                                                             |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0              | Reserved. Must not be used.                                                                                                                                                                                                                             |
| 4                | <b>Head Pointer Storage:</b> The contents of the Ring Buffer Head Pointer register (register DWord 1) are written to this location either as result of an MI_REPORT_HEAD instruction or as the result of an "automatic report" (see RINGBUF registers). |
| 0Fh:05h          | Reserved. Must not be used.                                                                                                                                                                                                                             |
| (3FFh –<br>010h) | These locations can be used for general purpose via the MI_STORE_DATA_INDEX or MI_STORE_DATA_IMM instructions.                                                                                                                                          |

#### 2.1.3.2 BCS\_PP\_DIR\_BASE – Page Directory Base Register

| Register Type:                              | MMIO_CS                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address Offset:                             | 22228h                                                                                                                                                                                                                                                                                                                                    |
| Project:                                    | All                                                                                                                                                                                                                                                                                                                                       |
| Default Value:                              | 0000 0000h                                                                                                                                                                                                                                                                                                                                |
| Access:                                     | R/W                                                                                                                                                                                                                                                                                                                                       |
| Size (in bits):                             | 32                                                                                                                                                                                                                                                                                                                                        |
| register is restore<br>this register in the | ains the offset into the GGTT where the (current context's) PPGTT page directory begins. This d with context. The Page Directory Base Address is set by SW only by modifying the value of context image such that the new value is restored the next time the context runs. A write via gister triggers the render pipe to fetch all PDs. |

| Bit   | Description                                                                                              |
|-------|----------------------------------------------------------------------------------------------------------|
| 30:16 | Page Directory Base Offset                                                                               |
|       | Project: All                                                                                             |
|       | Default Value: 0h                                                                                        |
|       | Format: U15                                                                                              |
|       | Range [0,GGTT Size in cachelines - 1]                                                                    |
|       | Contains the cacheline (64-byte) offset into the GGTT where the page directory begins.                   |
| 15:1  | Reserved Project: All Format: MBZ                                                                        |
| 0     | PD Load Busy Project: DevSNB Format: Valid                                                               |
|       | +                                                                                                        |
|       | This is a read-only field that indicates if the page directories are currently being fetched and loaded. |



#### 2.1.3.3 BCS\_PP\_DCLV – PPGTT Directory Cacheline Valid Register

# BCS\_PP\_DCLV – PPGTT Directory Cacheline Valid Register Register Type: MMIO\_CS Address Offset: 22220h Project: All

| Access: |
|---------|
|---------|

0h

**Default Value:** 

Size (in bits): 64

This register controls update of the on-chip PPGTT Directory Cache during a context restore. Bits that are set will trigger the load of the corresponding 16 directory entry group. This register is restored with context (prior to restoring the on-chip directory cache itself). This register is also restored when switching to a context whose LRCA matches the current CCID if the **Force PD Restore** bit is set in the context descriptor.

The context image of this register must be updated and maintained by SW; SW should not normally need to read this register.

This register can also effectively be used to limit the size of a processes' virtual address space. Any access by a process that requires a PD entry in a set that is not enabled in this register will cause a fatal error, and no fetch of the PD entry will be attempted

| Bit   |                           |                      |         | Desc     | ription |                                                                             |
|-------|---------------------------|----------------------|---------|----------|---------|-----------------------------------------------------------------------------|
| 63:32 | Reserved                  | Project:             | All     | Format:  | MBZ     |                                                                             |
| 31:0  | PPGTT Dire<br>[132] 16 en | ctory Cache<br>tries | Restore | Project: | All     | Format: Array:Enable                                                        |
|       |                           | store. If clear      |         |          |         | ered valid and will be brought in on and fetch of these entries will not be |

The field below needs to go in some register to enable PPGTT, either in GAB MMIO or BCS MMIO

| 1 | Per-Process GTT<br>Enable                               | Project: | DevSNB<br>+ | Format:      | Enable                                        |
|---|---------------------------------------------------------|----------|-------------|--------------|-----------------------------------------------|
|   | If set, PPGTT support in<br>bit also allows support for |          |             | his bit must | be set if runlist enable is set. Setting this |



## 2.1.4 Mode and Misc Ctrl Registers

#### 2.1.4.1 BCS\_MI\_MODE — Mode Register for Software Interface

| Address Offset: | 2209Ch-2209Fh |
|-----------------|---------------|
| Default Value:  | 0000 0000h    |
| Access:         | Read/Write    |
| Size:           | 32 bits       |

The MI\_MODE register contains information that controls software interface aspects of the command parser.

| Bit   |                                                                                                                                                     |                     | Description                                                                                                                 |         |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------|---------|--|--|
| 31:16 | Masks: A "1" in a bit in this field allows the modification of the corresponding bit in Bits 15:0                                                   |                     |                                                                                                                             |         |  |  |
| 15    | Suspend Flush                                                                                                                                       |                     |                                                                                                                             |         |  |  |
|       | Project:                                                                                                                                            | All                 |                                                                                                                             |         |  |  |
|       | Mask:                                                                                                                                               | M№                  | /IO(0x209c)#31                                                                                                              |         |  |  |
|       | Value                                                                                                                                               | Name                | Description                                                                                                                 | Project |  |  |
|       | 0h                                                                                                                                                  | No Delay            | HW will not delay flush, this bit will get cleared by<br>MI_SUSPEND_FLUSH as well                                           | All     |  |  |
|       | 1h                                                                                                                                                  | Delay Flush         | HW will delay the flush because of sync flush or VTD regimes until reset, this bit will get set by MI_SUSPEND_FLUSH as well | All     |  |  |
| 14:12 | Reserved                                                                                                                                            | d Read/Write        |                                                                                                                             |         |  |  |
| 11    | <b>Invalidate UHPTR enable:</b> If bit set H/W clears the valid bit of BCS_UHPTR (4134h, bit 0) when current active head pointer is equal to UHPTR. |                     |                                                                                                                             |         |  |  |
| 10    | Reserved                                                                                                                                            | Reserved Read/Write |                                                                                                                             |         |  |  |
| 9     | Ring Idle (Read Only Status bit)                                                                                                                    |                     |                                                                                                                             |         |  |  |
|       | 0 = Parse                                                                                                                                           | 0 = Parser not Idle |                                                                                                                             |         |  |  |
|       | 1 = Parse                                                                                                                                           | er Idle             |                                                                                                                             |         |  |  |
|       | Writes to                                                                                                                                           | this bit are not a  | allowed.                                                                                                                    |         |  |  |



| Bit      | Description                                                                                                                                                                                          |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8        | Stop Ring                                                                                                                                                                                            |
|          | 0 = Normal Operation.                                                                                                                                                                                |
|          | 1 = Parser is turned off.                                                                                                                                                                            |
|          | Software must set this bit to force the Ring and Command Parser to Idle. Software must read a "1" in Ring Idle bit after setting this bit to ensure that the hardware is idle.                       |
|          | Software must clear this bit for Ring to resume normal operation.                                                                                                                                    |
| 7:2      | Reserved Read/Write                                                                                                                                                                                  |
| 1        | Bypass Fence Write [DevSNB]                                                                                                                                                                          |
|          | 0 = Normal Operation.                                                                                                                                                                                |
|          | 1 = Bypass.                                                                                                                                                                                          |
|          | If set, this bit will bypass all writes during flushes, independent of programming. This includes post-sync op bits, the implicit TLB invalidate write (set in GFX_MODE[13]), and sync flush fences. |
|          | Note this is only intended for work-arounds                                                                                                                                                          |
| 0        | Reserved Read/Write                                                                                                                                                                                  |
| <u> </u> |                                                                                                                                                                                                      |



|              |                                                                                                                                               | BC      | S_NO                       | PID — | - NOP Ide                              | ntificat    | tion Register                            |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------|----------------------------|-------|----------------------------------------|-------------|------------------------------------------|
| Register T   | ype: MI                                                                                                                                       | MIO_B   | CS                         |       |                                        |             |                                          |
| Address O    | ffset: 22                                                                                                                                     | 094h    |                            |       |                                        |             |                                          |
| Project:     | All                                                                                                                                           |         |                            |       |                                        |             |                                          |
| Default Va   | lue: 00                                                                                                                                       | 00000   | Dh                         |       |                                        |             |                                          |
| Access:      | R                                                                                                                                             | 2       |                            |       |                                        |             |                                          |
| Size (in bit | s): 32                                                                                                                                        |         |                            |       |                                        |             |                                          |
| Trusted Ty   | v <b>pe:</b> 1                                                                                                                                |         |                            |       |                                        |             |                                          |
|              | The NOPID register contains the Noop Identification value specified by the last MI_NOOP instruction that enabled this register to be updated. |         |                            |       | d by the last MI_NOOP instruction that |             |                                          |
| Bit          |                                                                                                                                               |         |                            |       | Des                                    | ription     |                                          |
| 31:22        | Reser                                                                                                                                         | ved     | Project:                   | All   | Format:                                | MBZ         |                                          |
| 21:0         | Identific                                                                                                                                     | ation N | lumber                     |       |                                        |             |                                          |
|              | Project:                                                                                                                                      |         |                            | II    |                                        |             |                                          |
|              | Security                                                                                                                                      | :       |                            | one   |                                        |             |                                          |
|              | Default                                                                                                                                       | Value:  |                            | h     | ef                                     | aultVaueD   | Desc                                     |
|              |                                                                                                                                               |         | ains the 22<br>eld to be u |       | Identification va                      | lue specifi | ied by the last MI_NOOP instruction that |

#### 2.1.4.2 BCS\_NOPID — NOP Identification Register

#### 2.1.4.3 BCS\_INSTPM—Instruction Parser Mode Register

| Address Offset: | 220C0h-220C3h |
|-----------------|---------------|
| Default Value:  | 0000 0000h    |
| Access:         | Read/Write    |
| Size:           | 32 bits       |

The BCS\_INSTPM register is used to control the operation of the BCS Instruction Parser. Certain classes of instructions can be disabled (ignored) – often useful for detecting performance bottlenecks. Also, "Synchronizing Flush" operations can be initiated – useful for ensuring the completion (vs. only parsing) of rendering instructions.

#### **Programming Notes:**

• All Reserved bits are implemented.



|               | BCS_INSTPM—Instruction Parser Mode Register                                                                                                                                   |  |  |  |  |  |  |  |  |  |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Register Ty   | e: MMIO_BCS                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |
| Address Of    | t: 220C0h                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
| Project:      | DevSNB+                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| Default Val   | ue: 0000000h                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |
| Access:       | R/W                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |
| Size (in bits | 32                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |
| Trusted Ty    | <b>be:</b> 1                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |
| Bit           | Description                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |
| 31:16         | Mask Bits                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
|               | Format: Mask[15:0]                                                                                                                                                            |  |  |  |  |  |  |  |  |  |
|               | Must be set to modify corresponding bit in Bits 15:0. (All implemented bits)                                                                                                  |  |  |  |  |  |  |  |  |  |
| 15:10         | Reserved         Project:         All         Format:         MBZ                                                                                                             |  |  |  |  |  |  |  |  |  |
| 9             | Reserved                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
| 8:7           | Reserved Project: All Format: MBZ                                                                                                                                             |  |  |  |  |  |  |  |  |  |
| 6             | Memory Sync Enable Project: DevSN Format: U1<br>B+                                                                                                                            |  |  |  |  |  |  |  |  |  |
|               | This set, this bit allows the blitter decode engine to write out the data from the local caches to memory.                                                                    |  |  |  |  |  |  |  |  |  |
|               | This bit is not persistent. S/W must define this bit each time a sync flush is requested                                                                                      |  |  |  |  |  |  |  |  |  |
| 5             | Sync Flush Enable Project: DevSN Format: U1<br>B+                                                                                                                             |  |  |  |  |  |  |  |  |  |
|               | This field is used to request a Sync Flush operation. The device will automatically clear this bit before completing the operation. See Sync Flush (Programming Environment). |  |  |  |  |  |  |  |  |  |
|               | Format = Enable (cleared by HW)                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|               | [DevSNB] When using MI_SUSPEND_FLUSH, this bit cannot be relied on as an indicator of sync flush complete. Instead, driver must wait until head == tail                       |  |  |  |  |  |  |  |  |  |
| 4:0           | Reserved Project: All Format: MBZ                                                                                                                                             |  |  |  |  |  |  |  |  |  |



|             |                                                                                                                                                         | BCS_EXCC—Execute Condition Code Register                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Register 1  | Гуре:                                                                                                                                                   | MMIO_VCS                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| Address (   | Offset:                                                                                                                                                 | 22028h                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
| Project:    |                                                                                                                                                         | All                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
| Default Va  | alue:                                                                                                                                                   | 0000000h                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| Access:     |                                                                                                                                                         | R/W,RO                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
| Size (in bi | its):                                                                                                                                                   | 32                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
| Trusted T   | ype:                                                                                                                                                    | 1                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
| from arbit  | tration if                                                                                                                                              | EVENT commands. An MI_WAIT_FOR_EVENT instruction excludes the executing ring the selected event evaluates to a "1", while instruction is discarded if the condition ". Once excluded a ring is enabled into arbitration when the selected condition evaluates |  |  |  |  |  |  |  |  |
| Bit         |                                                                                                                                                         | Description                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
| 31:16       | Mask                                                                                                                                                    | ask Bits                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|             | Form                                                                                                                                                    | at: Mask[1]                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
|             | This bit serves as a write enable for bit 1. If this register is written with this bit clear the corresponding bit in the field 1 will not be modified. |                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|             | Reading these bits always returns 0s.                                                                                                                   |                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| 15:5        | Rese                                                                                                                                                    | erved Project: All Format: MBZ                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
| 4:0         | User                                                                                                                                                    | Defined Condition Codes                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
|             |                                                                                                                                                         | The software may signal a Stream Semaphore by setting the Mask bit and Signal Bit together to match the bit field specified in a WAIT_FOR_EVENT (Semaphore).                                                                                                  |  |  |  |  |  |  |  |  |

## 2.1.4.4 BCS\_EXCC—Execute Condition Code Register



## 2.1.4.5 BRSYNC – Blitter/Render Semaphore Sync Register

|                   | E        | BRSYNC – Blitter/Render Semaphore Sync Register                          |
|-------------------|----------|--------------------------------------------------------------------------|
| Register Type:    |          | MMIO_BCS                                                                 |
| Address Offset:   |          | 22040h                                                                   |
| Project:          |          | All                                                                      |
| Default Value:    |          | 0000000h                                                                 |
| Access:           |          | R/W                                                                      |
| Size (in bits):   |          | 32                                                                       |
| Trusted Type:     |          | 1                                                                        |
| This registe      | er is wr | ritten by CS, read by BCS.                                               |
| Bit Description   |          |                                                                          |
| 31:0 Semaphore Da |          | aphore Data                                                              |
| Sem               |          | aphore data for synchronization between blitter engine and render engine |

#### 2.1.4.6 BVSYNC – Blitter/Video Semaphore Sync Register

|                                               |                                                                                   | BVSYNC – Blitter/Video Semaphore Sync Register |
|-----------------------------------------------|-----------------------------------------------------------------------------------|------------------------------------------------|
| Register Type:                                |                                                                                   | MMIO_BCS                                       |
| Address Off                                   | fset:                                                                             | 22044h                                         |
| Project:                                      |                                                                                   | All                                            |
| Default Valu                                  | le:                                                                               | 0000000h                                       |
| Access:                                       |                                                                                   | R/W                                            |
| Size (in bits):                               |                                                                                   | 32                                             |
| Trusted Type:                                 |                                                                                   | 1                                              |
| This register is written by VCS, read by BCS. |                                                                                   | itten by VCS, read by BCS.                     |
| Bit Description                               |                                                                                   |                                                |
| 31:0 Sema                                     |                                                                                   | aphore Data                                    |
|                                               | Semaphore data for synchronization between blitter engine and video codec engine. |                                                |



#### 2.1.4.7 GAB\_MODE — Mode Register for GAB

| Address Offset: | 220A0h-220A3h |
|-----------------|---------------|
| Default Value:  | 0000 0000h    |
| Access:         | Read/Write    |
| Size:           | 32 bits       |

The GAB\_MODE register contains information that controls configurations in the GAB.

| Bit   | Description                                                                                       |
|-------|---------------------------------------------------------------------------------------------------|
| 31:16 | Masks: A "1" in a bit in this field allows the modification of the corresponding bit in Bits 15:0 |
| 15:0  | Reserved Read/Write                                                                               |

#### 2.1.4.8 Logical Ring Context Format

The format of the logical ring context is documented in the "GPU Overview" volume, "Memory Data Formats" chapter.

#### 2.1.4.9 Context Status

A context switch interrupt will be sent anytime a context switch occurs. This is documented in the "GPU Overview" volume, "Memory Data Formats" chapter. A status DW for the context that was just switched away from will be written to the Context Status Buffer in the Global Hardware Status Page. The status contains the context ID and the reason for the context switch. Note that since there will have been no running contexts when the very first (after reset) context is submitted, the Context ID in the first Context Status DWord will be UNDEFINED.

| Bit   | Description                                                            |  |  |
|-------|------------------------------------------------------------------------|--|--|
| 31:12 | Context ID. Contains the context ID copied from the submitted context. |  |  |
| 11:8  | Reserved: MBZ                                                          |  |  |
| 7     | Reserved: MBZ                                                          |  |  |
| 6     | Reserved: MBZ                                                          |  |  |
| 5     | Reserved: MBZ                                                          |  |  |
| 4     | Ring Buffer Becoming Empty Caused context to Switch.                   |  |  |
| 3     | Reserved: MBZ                                                          |  |  |
| 2     | Reserved: MBZ                                                          |  |  |
| 1     | Waiting on a Semaphore Caused Context to Switch.                       |  |  |
| 0     | Reserved: MBZ                                                          |  |  |



#### 2.1.4.10 BCS\_RCCID—Ring Buffer Current Context ID Register

| Address Offset: | 22190h-22197h |
|-----------------|---------------|
| Default Value:  | 00 00 00 00h  |
| Access:         | Read/Write    |
| Size:           | 32 bits       |

This register contains the current "ring context ID" associated with the ring buffer.

#### **Programming Notes:**

• The current context registers must not be written directly (via MMIO). The RCCID register should only be updated indirectly from RNCID.

| Bit  | Description                    |
|------|--------------------------------|
| 63:0 | See Context Descriptor for BCS |

#### 2.1.4.11 VCS\_RNCID—Ring Buff er Next Context ID Register

| Address Offset: | 22198h-2219fh |
|-----------------|---------------|
| Default Value:  | 00 00 00 00h  |
| Access:         | Read/Write    |
| Size:           | 64 bits       |

This register contains the *next* "ring context ID" associated with the ring buffer.

#### **Programming Notes:**

• The current context (RCCID) register can be updated indirectly from this register on a context switch event. Note that the only time a context switch can occur is when MI\_ARB\_CHECK enables preemption or the current context runs dry (head pointer becomes equal to tail pointer).

| Bit  | Description                    |  |
|------|--------------------------------|--|
| 63:0 | See Context Descriptor for BCS |  |



#### 2.1.4.12 Context Status

A context switch interrupt will be sent anytime a context switch occurs. This is documented in the "GPU Overview" volume, "Memory Data Formats" chapter. A status DW for the context that was just switched away from will be written to the Context Status Buffer in the Global Hardware Status Page. The status contains the context ID and the reason for the context switch. Note that since there will have been no running contexts when the very first (after reset) context is submitted, the Context ID in the first Context Status DWord will be UNDEFINED.

| Bit   | Description                                                            |  |  |
|-------|------------------------------------------------------------------------|--|--|
| 31:12 | Context ID. Contains the context ID copied from the submitted context. |  |  |
| 11:8  | Reserved: MBZ                                                          |  |  |
| 7     | Reserved: MBZ                                                          |  |  |
| 6     | Reserved: MBZ                                                          |  |  |
| 5     | Reserved: MBZ                                                          |  |  |
| 4     | Ring Buffer Becoming Empty Caused context to Switch.                   |  |  |
| 3     | Reserved: MBZ                                                          |  |  |
| 2     | Reserved: MBZ                                                          |  |  |
| 1     | Waiting on a Semaphore Caused Context to Switch.                       |  |  |
| 0     | Reserved: MBZ                                                          |  |  |

#### 2.1.5 BCS\_RINGBUF—Ring Buffer Registers

| RINGBUF—Ring Buffer Registers |                                        |  |
|-------------------------------|----------------------------------------|--|
| Register Type:                | MMIO_BCS                               |  |
| Address Offset:               | 22030h                                 |  |
| Project:                      | All                                    |  |
| Default Value:                | 0000000h; 0000000h; 0000000h; 0000000h |  |
| Access:                       | R/W                                    |  |
| Size (in bits):               | 4x32                                   |  |
| Trusted Type:                 | 1                                      |  |

instructions to the command interface. The buffer itself is located in a physical memory region. The ring buffer is defined by a 4 Dword register set that includes starting address, length, head offset, tail offset, and control information. Refer to the *Programming Interface* chapter for a detailed description of the parameters specified in this ring buffer register set, restrictions on the placement of ring buffer memory, arbitration rules, and in how the ring buffer can be used to pass

#### Ring Buffer Head and Tail Offsets must be properly programmed before it is enabled. A Ring Buffer can be enabled when empty.



| RINGBUF—Ring Buffer Registers |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|-------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DWord                         | Bit   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| 0                             | 31:21 | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|                               | 20:3  | Tail Offset Project: All Format: U18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                               |       | This field is written by software to specify where the valid instructions placed in the ring buffer end. The value written points to the QWord <i>past</i> the last valid QWord of instructions. In other words, it can be defined as the <i>next</i> QWord that software will write instructions into. Software must write subsequent instructions to QWords following the Tail Offset, possibly wrapping around to the top of the buffer (i.e., software can't skip around within the buffer). Note that all DWords prior to the location indicated by the Tail Offset must contain valid instruction data – which may require instruction padding by software. See Head Offset for more information. |  |
|                               |       | QWord Offset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|                               |       | [DevSNB+] To work around a known hardware bug, the first command parsed when the tail is moved must always be an MI_BATCH_BUFFER_START command. Once inside, the batch buffer can be (but not required to be) immediately closed via MI_BATCH_BUFFER_END.                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|                               |       | [DevSNB+]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|                               |       | Commands                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                               |       | MI_NOOP * 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|                               |       | MI_BATCH_BUFFER_START                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                               |       | (only MI_BATCH_BUFFER_END inside batch)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                               |       | Blitter work                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|                               |       | MI_LOAD_REGISTER_IMM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                               |       | - addr: 0x2209c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                               |       | - data: 0x00020002                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                               |       | MI_FLUSH_DW w/ no post-sync op                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|                               |       | MI_LOAD_REGISTER_IMM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                               |       | - addr: 0x2209c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                               |       | - data: 0x00020000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                               |       | MI_NOOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                               | 2:0   | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |



|   |       | RINGBUF—Ring Buffer Registers                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | 31:21 | Wrap Count Project: All Format: U11                                                                                                                                                                                                                                                                                                                                                                                                                   |
|   |       | This field is incremented by 1 whenever the Head Offset wraps from the end of the buffer back to the start (i.e., whenever it wraps back to 0). Appending this field to the Head Offset field effectively creates a virtual 4GB Head "Pointer" which can be used as a tag associated with instructions placed in a ring buffer. The Wrap Count itself will wrap to 0 upon overflow.                                                                   |
|   | 20:2  | Head Offset Project: All Format: U19                                                                                                                                                                                                                                                                                                                                                                                                                  |
|   |       | This field indicates the offset of the <i>next</i> instruction DWord to be parsed. Software will initialize this field to select the first DWord to be parsed once the RB is enabled. (Writing the Head Offset while the RB is enabled is UNDEFINED). Subsequently, the device will increment this offset as it executes instructions – until it reaches the QWord specified by the Tail Offset. At this point the ring buffer is considered "empty". |
|   |       | Programming Notes:                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|   |       | • A RB can be enabled empty or containing some number of valid instructions.                                                                                                                                                                                                                                                                                                                                                                          |
|   | 1:0   | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2 | 31:12 | Starting Address Project: All Format: Graphics Address[31:12]                                                                                                                                                                                                                                                                                                                                                                                         |
|   |       | This field specifies Bits 31:12 of the 4KB-aligned starting Graphics Address of the ring buffer. Address bits 31 down to 29 must be zero.                                                                                                                                                                                                                                                                                                             |
|   |       | All ring buffer pages must map to Main Memory (uncached) pages.<br>Ring Buffer addresses are always translated through the global GTT. Per-process<br>address space can only be used via a batch buffer.                                                                                                                                                                                                                                              |
|   | 11:0  | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3 | 31:21 | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                                                                                                                                                                                                     |
|   | 20:12 | Buffer Length Project: All Format: U9                                                                                                                                                                                                                                                                                                                                                                                                                 |
|   |       | This field is written by SW to specify the length of the ring buffer in 4 KB Pages.                                                                                                                                                                                                                                                                                                                                                                   |
|   |       | Range = [0 = 1 page = 4 KB, 1FFh = 512 pages = 2 MB]                                                                                                                                                                                                                                                                                                                                                                                                  |
|   | 11    | RB Wait Project: All Format: Boolean                                                                                                                                                                                                                                                                                                                                                                                                                  |
|   |       | Indicates that this ring has executed a WAIT_FOR_EVENT instruction and is currently waiting. Software can write a "1" to clear this bit, write of "0" has no effect. When the RB is waiting for an event and this bit is cleared, the wait will be terminated and the RB will be returned to arbitration.                                                                                                                                             |
|   | 10    | Semaphore Wait Project: DevSNB Format: Boolean<br>+                                                                                                                                                                                                                                                                                                                                                                                                   |
|   |       | Indicates that this ring has executed a MI_SEMAPHORE_MBOX instruction with register compare and is currently waiting. Software can write a "1" to clear this bit, write of "0" has no effect. When the RB is waiting for the compare to meet and this bit is cleared, the wait will be terminated and the RB will be returned to arbitration.                                                                                                         |
|   | 9:3   | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                                                                                                                                                                                                     |
|   |       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



| RINGBUF—Ring Buffer Registers |     |                                                                                                                                                                                                                                                                                                                               |  |
|-------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                               | 2:1 | Automatic Report Project: All Format: U2<br>Head Pointer                                                                                                                                                                                                                                                                      |  |
|                               |     | This field is written by software to control the automatic "reporting" (write) of this ring buffer's "Head Pointer" register (register DWord 1) to the corresponding location within the Hardware Status Page. Automatic reporting can either be disabled or enabled at 4KB, 64KB or 128KB boundaries within the ring buffer. |  |
|                               |     | Format =                                                                                                                                                                                                                                                                                                                      |  |
|                               |     | 0: MI_AUTOREPORT_OFF – Automatic reporting disabled                                                                                                                                                                                                                                                                           |  |
|                               |     | 1: MI_AUTOREPORT_64KB – Report every 16 pages (64KB)                                                                                                                                                                                                                                                                          |  |
|                               |     | 2: MI_AUTOREPORT_4KB – Report every page (4KB)                                                                                                                                                                                                                                                                                |  |
|                               |     | 3: MI_AUTOREPORT_128KB – Report every 32 pages (128KB)                                                                                                                                                                                                                                                                        |  |
|                               |     | When the Per-Process Virtual Address Space bit is set and automatic head reporting is desired, this field must be set to option 2 since the ring buffer will be only 16KB in size. The head pointer will be reported to the head pointer location in the PP HW Status Page when it passes each 4KB page boundary.             |  |
|                               | 0   | Ring Buffer Project: All Format: Enable<br>Enable                                                                                                                                                                                                                                                                             |  |
|                               |     | This field is used to enable or disable this ring buffer. It can be enabled or disabled regardless of whether there are valid instructions pending.                                                                                                                                                                           |  |



## 2.1.5.1 BCS\_UHPTR — Pending Head Pointer Register

|              | BCS                                                                                                                                                                                                                                                  |                    | 'R — Р                | ending              | g Head                                               | Pointer   | Register |     |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------------|---------------------|------------------------------------------------------|-----------|----------|-----|
| Register T   | ype: MMIO                                                                                                                                                                                                                                            |                    |                       |                     |                                                      |           |          |     |
| Address O    |                                                                                                                                                                                                                                                      | –22137h            |                       |                     |                                                      |           |          |     |
| Project:     | All                                                                                                                                                                                                                                                  |                    |                       |                     |                                                      |           |          |     |
| Security:    | None                                                                                                                                                                                                                                                 |                    |                       |                     |                                                      |           |          |     |
| Default Va   | lue: 0000 00                                                                                                                                                                                                                                         | )00h               |                       |                     |                                                      |           |          |     |
| Access:      | R/W                                                                                                                                                                                                                                                  |                    |                       |                     |                                                      |           |          |     |
| Size (in bit | <b>s):</b> 32                                                                                                                                                                                                                                        |                    |                       |                     |                                                      |           |          |     |
| Trusted Ty   | -                                                                                                                                                                                                                                                    |                    |                       |                     |                                                      |           |          |     |
| Desc         |                                                                                                                                                                                                                                                      |                    |                       |                     |                                                      |           |          |     |
| Bit          |                                                                                                                                                                                                                                                      |                    |                       |                     | Description                                          |           |          |     |
| 31:3         | Head Pointer                                                                                                                                                                                                                                         | Address            |                       |                     |                                                      |           |          |     |
|              | Project:                                                                                                                                                                                                                                             |                    | All                   |                     |                                                      |           |          |     |
|              | Security:                                                                                                                                                                                                                                            |                    | None                  |                     |                                                      |           |          |     |
|              | Default Value:                                                                                                                                                                                                                                       |                    | 0h DefaultVaueDesc    |                     |                                                      |           |          |     |
|              | Mask:                                                                                                                                                                                                                                                |                    | MMIO(0x2000)#16       |                     |                                                      |           |          |     |
|              | Format:                                                                                                                                                                                                                                              |                    | MI_Graphics_Offset    |                     |                                                      | FormatDes | SC       |     |
|              | Address:                                                                                                                                                                                                                                             |                    | GraphicsAddress[31:0] |                     |                                                      |           |          |     |
|              | Surface Type:                                                                                                                                                                                                                                        |                    | U32                   |                     |                                                      |           |          |     |
|              | Range                                                                                                                                                                                                                                                |                    | 02^32-1               |                     |                                                      |           |          |     |
|              | This register represents the GFX address offset where execution should continue in the ring buffer following execution of an MI_ARB_CHECK command.                                                                                                   |                    |                       |                     |                                                      |           |          |     |
| 2:1          | Reserved                                                                                                                                                                                                                                             | Project:           | All                   |                     |                                                      |           | Format:  | MBZ |
| 0            | Head Pointer                                                                                                                                                                                                                                         | <sup>.</sup> Valid | Project:              | All                 | Format:                                              | U32       |          |     |
|              | This bit is set by the software to request a pre-emption. It is reset by hardware when an MI_ARB_CHECK command is parsed by the command streamer. The hardware uses the head pointer programmed in this register at the time the reset is generated. |                    |                       |                     |                                                      |           |          |     |
|              | Value                                                                                                                                                                                                                                                |                    | -                     |                     |                                                      |           | Project  |     |
|              | 1                                                                                                                                                                                                                                                    | Enable             |                       | Indicate<br>updated | es that there i<br>I head pointe<br>nmed in this     | er        |          |     |
|              | 0                                                                                                                                                                                                                                                    | Disable            |                       | regist              | updated hea<br>er, resume e<br>current loca<br>uffer | execution |          |     |



### 2.1.6 Interrupt Control Registers

The Interrupt Control Registers described below all share the same bit definition. The bit definition is as follows:

#### Table 2-1. Bit Definition for Interrupt Control Registers

| Bit   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | Reserved. MBZ: These bits may be assigned to interrupts on future products/steppings.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 29    | Page Fault: This bit is set whenever there is a pending PPGTT (page or directory) fault.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 28:27 | Reserved. MBZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 26    | <b>MI_FLUSH_DW Notify Interrupt:</b> The Pipe Control packet (Fences) specified in <i>3D pipeline</i> document may optionally generate an Interrupt. The Store QW associated with a fence is completed ahead of the interrupt.                                                                                                                                                                                                                                                                                                                                            |
| 25    | <b>Blitter Command Parser Master Error:</b> When this status bit is set, it indicates that the hardware has detected an error. It is set by the device upon an error condition and cleared by a CPU write of a one to the appropriate bit contained in the Error ID register followed by a write of a one to this bit in the IIR. Further information on the source of the error comes from the "Error Status Register" which along with the "Error Mask Register" determine which error conditions will cause the error status bit to be set and the interrupt to occur. |
|       | Page Table Error: Indicates a page table error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       | Instruction Parser Error: The Blitter Instruction Parser encounters an error while parsing an instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 24    | <b>Sync Status:</b> This bit is set when the Instruction Parser completes a flush with the sync enable bit active in the INSTPM register. The event will happen after all the blitter engines are flushed. The HW Status DWord write resulting from this event will cause the CPU's view of graphics memory to be coherent as well (flush and invalidate the blitter cache). It is the driver's responsibility to clear this bit before the next sync flush with HWSP write enabled.                                                                                      |
| 23    | Reserved. MBZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 22    | Blitter Command Parser User Interrupt: This status bit is set when an MI_USER_INTERRUPT instruction is executed on the Render Command Parser. Note that instruction execution is not halted and proceeds normally. A mechanism such as an MI_STORE_DATA instruction is required to associate a particular meaning to a user interrupt.                                                                                                                                                                                                                                    |
| 21:0  | Reserved. MBZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



## 2.1.6.1 HWSTAM — Hardware Status Mask Register

|                       | Hardware Status Mask Register                                                                                                                                                                                                                                    |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Type:        | : MMIO_BCS                                                                                                                                                                                                                                                       |
| Address Offse         | t: 22098h                                                                                                                                                                                                                                                        |
| Project:              | All                                                                                                                                                                                                                                                              |
| <b>Default Value:</b> | FFFF FFFFh                                                                                                                                                                                                                                                       |
| Access:               | R/W, RO for Reserved Control bits                                                                                                                                                                                                                                |
| Size (in bits):       | 32                                                                                                                                                                                                                                                               |
| Trusted Type:         | 1                                                                                                                                                                                                                                                                |
| Status Registe        | PCI write cycle). Any unmasked interrupt bit (HWSTAM bit set to 0) will allow the Interrupt<br>or to be written to the ISR location (within the memory page specified by the Hardware Status<br>Register) when that Interrupt Status Register bit changes state. |
| Programming           | Note:                                                                                                                                                                                                                                                            |
| • To wri              | ite the interrupt to the HWSP, the corresponding IMR bit must also be clear (enabled).                                                                                                                                                                           |
| At mo                 | st 1 bit can be unmasked at any given time                                                                                                                                                                                                                       |
| Bit                   | Description                                                                                                                                                                                                                                                      |
| 31:0 <b>H</b>         | ardware Status Mask Register                                                                                                                                                                                                                                     |

| Dir  |                       |                            | Description                    |
|------|-----------------------|----------------------------|--------------------------------|
| 31:0 | Hardware Status M     | lask Register              |                                |
|      | Project:              | All                        |                                |
|      | Default Value:        | FFFFFFFh                   | DefaultVaueDesc                |
|      | Format:               | Array of Masks             |                                |
|      | Refer to Table 5-1 ir | n Interrupt Control Regist | er section for bit definitions |



## 2.1.6.2 IMR—Interrupt Mask Register

|              |                                                                                                         | IM                       | R—Interrupt                                                                           | Mask Register                                           |                                    |  |
|--------------|---------------------------------------------------------------------------------------------------------|--------------------------|---------------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------|--|
| Register T   | ype: MMI                                                                                                | O_BCS                    |                                                                                       |                                                         |                                    |  |
| Address O    | ffset: 220A                                                                                             | \8h                      |                                                                                       |                                                         |                                    |  |
| Project:     | All                                                                                                     |                          |                                                                                       |                                                         |                                    |  |
| Default Va   | ue: FFFI                                                                                                | F FFFFh                  |                                                                                       |                                                         |                                    |  |
| Access:      | R/W                                                                                                     |                          |                                                                                       |                                                         |                                    |  |
| Size (in bit | <mark>s):</mark> 32                                                                                     |                          |                                                                                       |                                                         |                                    |  |
| Bit          | "Masked" bits will not be reported in the IIR and therefore cannot generate CPU interrupts. Description |                          |                                                                                       |                                                         |                                    |  |
| 31:0         | Interrupt Mask Bits                                                                                     |                          |                                                                                       |                                                         |                                    |  |
| 31:0         | Interrupt                                                                                               | Mask Bits                |                                                                                       |                                                         |                                    |  |
| 31:0         | Interrupt<br>Project:                                                                                   | Mask Bits                | All                                                                                   |                                                         |                                    |  |
| 31:0         | -                                                                                                       |                          | All<br>FFFF FFFFh                                                                     |                                                         |                                    |  |
| 31:0         | Project:                                                                                                |                          |                                                                                       | Refer to Table 5-1 in Inte<br>section for bit definitio | , ,                                |  |
| 31:0         | Project:<br>Default Va<br>Format:                                                                       | lue:                     | FFFF FFFFh<br>Array of interrupt<br>mask bits                                         |                                                         | ns                                 |  |
| 31:0         | Project:<br>Default Va<br>Format:                                                                       | lue:                     | FFFF FFFFh<br>Array of interrupt<br>mask bits                                         | section for bit definitio                               | ns                                 |  |
| 31:0         | Project:<br>Default Va<br>Format:<br>This field o                                                       | lue:<br>contains a bit m | FFFF FFFFh<br>Array of interrupt<br>mask bits<br>hask which selects wh<br>Description | section for bit definitio                               | ns<br>SR) are reported in the IIR. |  |



#### 2.1.6.3 Hardware-Detected Error Bit Definitions (for EIR, EMR, ESR)

This section defines the Hardware-Detected Error bit definitions and ordering that is common to the EIR, EMR and ESR registers. The EMR selects which error conditions (bits) in the ESR are reported in the EIR. Any bit set in the EIR will cause the Master Error bit in the ISR to be set. EIR bits will remain set until the appropriate bit(s) in the EIR is cleared by writing the appropriate EIR bits with '1' (except for the unrecoverable bits described below).

The following table describes the Hardware-Detected Error bits:

| Bit  | Description                                                                                                                   |
|------|-------------------------------------------------------------------------------------------------------------------------------|
| 15:1 | Reserved: MBZ                                                                                                                 |
| 0    | <b>Instruction Error:</b> This bit is set when the Renderer Instruction Parser detects an error while parsing an instruction. |
|      | Instruction errors include:                                                                                                   |
|      | 1) Client ID value (Bits 31:29 of the Header) is not supported (only MI, 2D and 3D are supported).                            |
|      | 2) Defeatured MI Instruction Opcodes:                                                                                         |
|      |                                                                                                                               |
|      | 1: Instruction Error detected                                                                                                 |
|      | Programming Note:                                                                                                             |
|      | This error indication can not be cleared except by reset (i.e., it is a fatal error).                                         |

#### Table 2-2. Hardware-Detected Error Bits



### 2.1.6.3.1 EIR — Error Identity Register

|               | EIR — Error Identity Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |             |                         |               |     |                                                                   |            |  |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------------------|---------------|-----|-------------------------------------------------------------------|------------|--|--|--|
| Register Ty   | er Type: MMIO_BCS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |                         |               |     |                                                                   |            |  |  |  |
| Address O     | fset: 220B0h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |             |                         |               |     |                                                                   |            |  |  |  |
| Project:      | All                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | All         |                         |               |     |                                                                   |            |  |  |  |
| Default Val   | ue: 0000 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 000h        |                         |               |     |                                                                   |            |  |  |  |
| Access:       | R/WC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |                         |               |     |                                                                   |            |  |  |  |
| Size (in bits |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |             |                         |               |     |                                                                   |            |  |  |  |
| will cause th | The EIR register contains the persistent values of Hardware-Detected Error Condition bits. Any bit set in this register will cause the Master Error bit in the ISR to be set. The EIR register is also used by software to clear detected errors (by writing a '1' to the appropriate bit(s) except for the unrecoverable bits described).).                                                                                                                                                                        |             |                         |               |     |                                                                   |            |  |  |  |
| Bit           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Description |                         |               |     |                                                                   |            |  |  |  |
| 31:16         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Project:    | All                     | Format:       |     | MBZ                                                               |            |  |  |  |
| 15:0          | Error Identity Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |                         |               |     |                                                                   |            |  |  |  |
|               | Project:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |             | All                     |               |     |                                                                   |            |  |  |  |
|               | Default Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ):          | 0h                      |               |     |                                                                   |            |  |  |  |
|               | Format:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             | Array of Er condition b |               | See | Table 1 5. Hardware-Detected                                      | Error Bits |  |  |  |
|               | This register contains the persistent values of ESR error status bits that are unmasked via the EMR register. (See <b>Error! Reference source not found.</b> ). The logical OR of all (defined) bits in this register is reported in the Master Error bit of the Interrupt Status Register. In order to clear an error condition, software must first clear the error by writing a '1' to the appropriate bit(s) in this field. If required, software should then proceed to clear the Master Error bit of the IIR. |             |                         |               |     |                                                                   |            |  |  |  |
|               | Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Name        | D                       | escription    |     |                                                                   | Project    |  |  |  |
|               | 1h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Error occu  | rred E                  | rror occurred | I   |                                                                   | All        |  |  |  |
|               | Programmi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ng Notes    |                         |               |     |                                                                   | Project    |  |  |  |
|               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |             |                         |               |     | to be cleared. However, the by reset (i.e., it is a fatal error). | All        |  |  |  |



#### 2.1.6.3.2 EMR—Error Mask Register

|             |                                                                                                                   | E                         | MR—Error                           | Mask    | Registe      | ər          |                   |  |
|-------------|-------------------------------------------------------------------------------------------------------------------|---------------------------|------------------------------------|---------|--------------|-------------|-------------------|--|
| Register 1  | Type: MMIC                                                                                                        | D_BCS                     |                                    |         |              |             |                   |  |
| Address (   | Offset: 220B4h                                                                                                    |                           |                                    |         |              |             |                   |  |
| Project:    | All                                                                                                               |                           |                                    |         |              |             |                   |  |
| Default Va  | alue: FFFF FFFFh                                                                                                  |                           |                                    |         |              |             |                   |  |
| Access:     | R/W                                                                                                               |                           |                                    |         |              |             |                   |  |
| Size (in bi | its): 32                                                                                                          |                           |                                    |         |              |             |                   |  |
|             | cannot genera                                                                                                     | te Master Error           | r conditions or CPU                | •       |              |             |                   |  |
| Bit         |                                                                                                                   |                           |                                    | Descrip | otion        |             |                   |  |
| 31:16       | Reserved                                                                                                          | Project:                  | All For                            | mat:    | MBZ          |             |                   |  |
| 15:0        | Error Mas                                                                                                         | k Bits                    |                                    |         |              |             |                   |  |
|             | Project:                                                                                                          |                           | All                                |         |              |             |                   |  |
|             | Default Va                                                                                                        | lue:                      | FFFF FFFFh                         |         |              |             |                   |  |
|             | Format:                                                                                                           |                           | Array of error condition mask bits |         | Table 1 5. I | Hardware-De | tected Error Bits |  |
|             | This register contains a bit mask that selects which error condition bits (from the ESR) are reported in the EIR. |                           |                                    |         |              |             |                   |  |
|             | the EIR.                                                                                                          |                           |                                    |         |              |             |                   |  |
|             | the EIR.<br>Value                                                                                                 | Name                      | Descriptio                         | n       |              |             | Project           |  |
|             |                                                                                                                   | <b>Name</b><br>Not Masked | -                                  |         | ne EIR       |             |                   |  |



### 2.1.6.3.3 ESR—Error Status Register

|              |                       | E                       | SR-     | -Error Sta              | atu    | s Registe      | er               |                                                                             |  |
|--------------|-----------------------|-------------------------|---------|-------------------------|--------|----------------|------------------|-----------------------------------------------------------------------------|--|
| Register T   | ype: MMI              | O_BCS                   |         |                         |        |                |                  |                                                                             |  |
| Address C    | offset: 220E          | iset: 220B8h            |         |                         |        |                |                  |                                                                             |  |
| Project:     | All                   | All                     |         |                         |        |                |                  |                                                                             |  |
| Default Va   | lue: 0000             | ) 0000h                 |         |                         |        |                |                  |                                                                             |  |
| Access:      | RO                    |                         |         |                         |        |                |                  |                                                                             |  |
| Size (in bi  | t <mark>s):</mark> 32 |                         |         |                         |        |                |                  |                                                                             |  |
| "persistent" | '). The EMR           | register select         | s which |                         | condit | ions are repo  | ted in the persi | ese are all by definition<br>istent EIR (i.e., set bits<br>rted in the ISR. |  |
| Bit          |                       |                         |         | D                       | escri  | ption          |                  |                                                                             |  |
| 31:16        | Reserved              | Project:                | All     | Forma                   | at:    | MBZ            |                  |                                                                             |  |
| 15:0         | Error State           | us Bits                 |         |                         |        |                |                  |                                                                             |  |
|              | Project:              |                         | All     |                         |        |                |                  |                                                                             |  |
|              | Default Va            | lue:                    | 0h      |                         |        |                |                  |                                                                             |  |
|              | Format:               |                         | ,       | of error<br>dition bits | See    | e Table 1 5. H | lardware-Detec   | cted Error Bits                                                             |  |
|              | This regist           | ter contains the        | non-pe  | ersistent values        | of all | hardware-det   | ected error con  | ndition bits.                                                               |  |
|              | Value                 | Name                    |         | Description             |        |                |                  | Project                                                                     |  |
|              | 1h                    | Error Condi<br>Detected | tion    | Error Conditio          | n det  | ected          |                  | All                                                                         |  |



### 2.1.7 Logical Context Support

### 2.1.7.1 BCS\_BB\_ADDR—Batch Buffer Head Pointer Register

| Address Offset: | 022140h-022147h      |
|-----------------|----------------------|
| Default Value:  | 0000 0000 0000 0000h |
| Access:         | Read-Only            |
| Size:           | 64 bits              |

This register contains the current QWord Graphics Memory Address of the last-initiated batch buffer.

| Bit   | Description                                                                                                                                                                                                                                                                |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | Reserved: MBZ                                                                                                                                                                                                                                                              |
| 31:3  | <b>Batch Buffer Head Pointer:</b> This field specifies the QWord-aligned Graphics Memory Address where the last initiated Batch Buffer is currently fetching commands. If no batch buffer is currently active, the Valid bit will be 0 and this field will be meaningless. |
| 2:1   | Reserved: MBZ                                                                                                                                                                                                                                                              |
| 0     | Valid:<br>1 = Batch buffer Valid<br>0 = Batch buffer Invalid                                                                                                                                                                                                               |



### 2.1.8 Software Control Bit Definitions

Registers in the range 22XX are not protected from the load register immediate instruction if the command is executed in the non-secure batch buffer.

#### 2.1.8.1 **TIMESTAMP** — Reported Timestamp Count

|               |                    | TIM                               | ESTA            | MP — F                | Repo     | orted    | Time      | estam     | p Count          |                     |  |
|---------------|--------------------|-----------------------------------|-----------------|-----------------------|----------|----------|-----------|-----------|------------------|---------------------|--|
| Register Ty   | vpe:               | e: MMIO_BCS                       |                 |                       |          |          |           |           |                  |                     |  |
| Address Of    | fset:              | 22358h                            |                 |                       |          |          |           |           |                  |                     |  |
| Project:      |                    | All                               |                 |                       |          |          |           |           |                  |                     |  |
| Default Valu  | ue:                | 0000 00                           | 0000 000        | 0000h                 |          |          |           |           |                  |                     |  |
| Access:       |                    | RO. Th                            | is register     | r is <i>not</i> set b | y the c  | context  | restore.  |           |                  |                     |  |
| Size (in bits | s):                | 64                                |                 |                       |          |          |           |           |                  |                     |  |
| This registe  | r provid           | es an ela                         | apsed re        | al-time val           | ue tha   | at can b | e used    | as a time | estamp.          |                     |  |
| This registe  | er is <i>not</i> i | reset by                          | a <u>graphi</u> | <u>cs</u> reset. I    | t will n | naintaiı | n its val | ue unless | s a full chipset | reset is performed. |  |
| Bit           |                    |                                   |                 |                       |          | Desc     | ription   |           |                  |                     |  |
| 63:36         | Reserve            | Reserved Project: All Format: MBZ |                 |                       |          |          |           |           |                  |                     |  |
| 35:0          | Timesta            | amp Valu                          | е               | PrProject:            | All      | F        | Format:   | U 32      |                  |                     |  |
|               | This reg           | gister tog                        | gles every      | / 640 ns of t         | ime.     |          |           |           |                  |                     |  |

### 2.2 Memory Interface Commands for Blitter Engine

### 2.2.1 Introduction

This chapter describes the formats of the "Memory Interface" commands, including brief descriptions of their use. The functions performed by these commands are discussed fully in the *Memory Interface Functions* Device Programming Environment chapter.

This chapter describes MI Commands for the blitter graphics processing engine. The term "for Blitter Engine" in the title has been added to differentiate this chapter from a similar one describing the MI commands for the Media Decode Engine and the Rendering Engine.

The commands detailed in this chapter are used across products within the Gen4 family. However, slight changes may be present in some commands (i.e., for features added or removed), or some commands may be removed entirely. Refer to the *Preface* chapter for product specific summary.



### 2.2.2 MI\_ARB\_CHECK

The instruction format is:

|                                                             |                                                        |                                                       | Μ                                 | II_ARB                                | _CHEC                                      | Κ                                   |                                                                 |                 |
|-------------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------|-----------------------------------|---------------------------------------|--------------------------------------------|-------------------------------------|-----------------------------------------------------------------|-----------------|
| Project:                                                    | All                                                    |                                                       |                                   |                                       | Lengt                                      | h Bias:                             | 1                                                               |                 |
| Engine:                                                     | Blit                                                   | ter                                                   |                                   |                                       |                                            |                                     |                                                                 |                 |
| UHPTR reg<br>empt the co<br>register new<br><b>Programm</b> | gister, dep<br>urrent exe<br>eds to be s<br>ning Note: | ending on whe<br>cution of the rin<br>set for the com | ther PP0<br>ng buffer<br>mand sti | GTT/Runlis<br>. Note tha<br>reamer to | sts are ena<br>t the valid t<br>be pre-emp | bled. This<br>bit in the I<br>bted. | text ID register (F<br>s instruction can I<br>RNCID register or | be used to pre- |
| DWord                                                       | Bit                                                    |                                                       |                                   |                                       | Desci                                      | ription                             |                                                                 |                 |
| 0                                                           | 31:29                                                  | Command Typ                                           | e                                 |                                       |                                            |                                     |                                                                 |                 |
|                                                             |                                                        | Default Value:                                        | 0h                                | MI_INST                               | RUCTION                                    |                                     | Format:                                                         | OpCode          |
|                                                             | 28:23                                                  | MI Command 0                                          | Opcode                            |                                       |                                            |                                     |                                                                 |                 |
|                                                             |                                                        | Default Value:                                        | 05h                               | MI_ARB                                | _CHECK                                     |                                     | Format:                                                         | OpCode          |
|                                                             | 22:0                                                   | Reserved                                              | Project:                          | All                                   | Format:                                    | MBZ                                 |                                                                 |                 |

### 2.2.3 MI\_BATCH\_BUFFER\_END

|                                                                                                                                                             | MI_BATCH_BUFFER_END |                                 |            |                |  |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------------------------|------------|----------------|--|--|--|--|--|--|--|--|--|
| Project:                                                                                                                                                    | Dev                 | SNB+ Le                         | ngth Bias: | 1              |  |  |  |  |  |  |  |  |  |
| Engine:                                                                                                                                                     | Blit                | er                              |            |                |  |  |  |  |  |  |  |  |  |
| The MI_BATCH_BUFFER_END command is used to terminate the execution of commands stored in a<br>patch buffer initiated using a MI_BATCH_BUFFER_START command. |                     |                                 |            |                |  |  |  |  |  |  |  |  |  |
| DWord                                                                                                                                                       | Bit                 | C                               | escription |                |  |  |  |  |  |  |  |  |  |
| 0                                                                                                                                                           | 31:29               | Command Type                    |            |                |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                             |                     | Default Value: 0h MI_COMMAND    |            | Format: OpCode |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                             | 28:23               | MI Command Opcode               |            |                |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                             |                     | Default Value: 0Ah MI_ BATCH_BL | FER_END    | Format: OpCode |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                             | 22:0                | Reserved Project: All Form      | at: MBZ    |                |  |  |  |  |  |  |  |  |  |



### 2.2.4 MI\_BATCH\_BUFFER\_START

|              |         | MI_BATCH_BUFFER_S                     | TAR  | т                                  |
|--------------|---------|---------------------------------------|------|------------------------------------|
| Project:     | DevSNB+ | Length B                              | ias: | 2                                  |
| Engine:      | Blitter |                                       |      |                                    |
| The ML BATCH | BLIFFER | START command is used to initiate the |      | tion of commands stored in a hatch |

The MI\_BATCH\_BUFFER\_START command is used to initiate the execution of commands stored in a *batch buffer.* For restrictions on the location of batch buffers, see Batch Buffers in the Device Programming Interface chapter of *MI Functions*.

The batch buffer can be specified as secure or non-secure, determining the operations considered valid when initiated from within the buffer and any attached (chained) batch buffers. See Batch Buffer Protection in the Device Programming Interface chapter of *MI Functions*.

#### Programming Notes:

- Batch buffers referenced with physical addresses must not extend beyond the end of the starting physical page (can't span physical pages). However, a batch buffer initiated using a physical address can chain to another buffer in another physical page.
- A batch buffer initiated with this command must end either with a MI\_BATCH\_BUFFER\_END command or by chaining to another batch buffer with an MI\_BATCH\_BUFFER\_START command.

| DWord | Bit   |                    | Description           |         |        |  |  |  |  |  |  |  |
|-------|-------|--------------------|-----------------------|---------|--------|--|--|--|--|--|--|--|
| 0     | 31:29 | Command Type       |                       |         |        |  |  |  |  |  |  |  |
|       |       | Default Value: 0h  | MI_COMMAND            | Format: | OpCode |  |  |  |  |  |  |  |
|       | 28:23 | MI Command Opcode  |                       |         |        |  |  |  |  |  |  |  |
|       |       | Default Value: 31h | MI_BATCH_BUFFER_START | Format: | OpCode |  |  |  |  |  |  |  |
|       | 22    | Reserved           |                       |         |        |  |  |  |  |  |  |  |
|       | 22    | Reserved           |                       |         |        |  |  |  |  |  |  |  |
|       | 21:9  | Reserved           |                       |         |        |  |  |  |  |  |  |  |



|                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                        | MI_BA                       | TCH_BUFFE                      | R_START                                                                                    |              |     |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--------------------------------|--------------------------------------------------------------------------------------------|--------------|-----|--|--|--|
| 8                                                                                                                                                                                                                                                                                                                                                                  | Buffer Security Indicator                                                                                                                                                                                              |                             |                                |                                                                                            |              |     |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                    | Project:                                                                                                                                                                                                               | oject: DevSNB+              |                                |                                                                                            |              |     |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                    | Format: MI_BufferSecurityType                                                                                                                                                                                          |                             |                                |                                                                                            |              |     |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                    | When this command is executed from within a batch buffer (i.e., is a "chained" batch buff<br>command), this field is IGNORED and the next buffer in the chain inherits the initial buffer<br>security characteristics. |                             |                                |                                                                                            |              |     |  |  |  |
| [DevSNB] If this bit is set, this batch buffer is non-secure and cannot execute privileg commands nor access privileged (GGTT) memory. It will be accessed via the PPGT clear, this batch buffer is secure and will be accessed via the GGTT. Note that MI_STORE_DATA_IMM to non-privileged memory (via the PPGTT) <i>is</i> allowed in a non-secure batch buffer. |                                                                                                                                                                                                                        |                             |                                |                                                                                            |              |     |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                    | Value                                                                                                                                                                                                                  |                             | Project                        |                                                                                            |              |     |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                    | 0h                                                                                                                                                                                                                     | GGTT                        | This batch buve via the GGT    | uffer is secure and will<br>F.                                                             | be accessed  | All |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                    | 1h                                                                                                                                                                                                                     | PPGTT                       | and cannot e<br>access privile | uffer is always treated<br>execute privileged com<br>eged (GGTT) memory.<br>via the PPGTT. | mands nor    | All |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                    | -                                                                                                                                                                                                                      | ming Notes<br>must be '0' u |                                | ess GTT Enable is '1'                                                                      |              |     |  |  |  |
| 7:0                                                                                                                                                                                                                                                                                                                                                                | DWord Le                                                                                                                                                                                                               | ength                       |                                |                                                                                            |              |     |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                    | Default Va                                                                                                                                                                                                             | •                           | Oh                             | Excludes DWord (0,1                                                                        | )            |     |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                    | Format:                                                                                                                                                                                                                |                             | =n                             | 1                                                                                          | Total - Bias |     |  |  |  |



|   |      | М              | I_BA1       | ГСН_В      | UFFER_START                    |            |
|---|------|----------------|-------------|------------|--------------------------------|------------|
|   | 31:0 | BitFieldName   | )           |            |                                |            |
|   |      | Project:       |             | All        |                                |            |
|   |      | Security:      |             | None       |                                |            |
|   |      | Access:        |             | None       |                                |            |
|   |      | Exists If:     |             | Always     |                                |            |
|   |      | Default Value: |             | 0h         | DefaultVaueDesc                |            |
|   |      | Mask:          |             | Ν          | /MIO(0x2000)#16                |            |
|   |      | Format:        |             | ι          | J32                            | FormatDesc |
|   |      | Address:       |             | GraphicsA  | Address[31:0]                  |            |
|   |      | Surface Type:  |             | U32        |                                |            |
|   |      | Range          |             | 02^32-1    |                                |            |
|   |      | BitFieldDesc   |             |            |                                |            |
|   |      | Value          | Name        |            | Description                    | Project    |
|   |      | 0h             | Disable     |            | Desc                           | All        |
|   |      | 1h             | Enable      |            | Desc                           | All        |
| 1 | 31:2 | Batch Buffer   | Start Ad    | dress      |                                |            |
|   |      | Project:       |             | All        |                                |            |
|   |      | Address:       |             | Graphics   | Address[31:2]                  |            |
|   |      | Surface Type   | :           | BatchBuff  | fer                            |            |
|   |      | This field spe | cifies Bits | 31:2 of th | e starting address of the batc | h buffer.  |
|   | 1:0  | Reserved       | Project:    | All        | Format: MBZ                    |            |



### 2.2.5 MI\_FLUSH\_DW

|           |              | MI_FLUSH_DW                                                                                                                                                                                                                              |
|-----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Project:  | Dev          | /SNB+ Length Bias: 2                                                                                                                                                                                                                     |
| Engine:   | Blit         |                                                                                                                                                                                                                                          |
|           | sh until all | command is used to perform an internal "flush" operation. The parser pauses on an drawing engines have completed any pending operations. In addition, this command                                                                       |
| Flush ar  | ny dirty da  | ta to memory.                                                                                                                                                                                                                            |
| Invalida  | te the TLE   | B cache inside the hardware                                                                                                                                                                                                              |
|           |              | s command is completed with a Store DWord enabled, CPU access to graphics memory uming the Render Cache flush is not inhibited).                                                                                                         |
| [DevSNB+] | An MI_NO     | OP with NOP_ID bit set must be programmed after the last MI_FLUSH_DW before head = tail                                                                                                                                                  |
| DWord     | Bit          | Description                                                                                                                                                                                                                              |
| 0         | 31:29        | Command Type                                                                                                                                                                                                                             |
|           |              | Default 0h MI_COMMAND Format: OpCode Value:                                                                                                                                                                                              |
|           | 28:23        | MI Command Opcode                                                                                                                                                                                                                        |
|           |              | Default 26h MI_FLUSH_DW Format: OpCode Value:                                                                                                                                                                                            |
|           | 22           | Reserved Project: All Format: U1                                                                                                                                                                                                         |
|           | 21           | Store Data Index Project: DevSNB+ Format: U1                                                                                                                                                                                             |
|           |              | This field is valid only if the post-sync operation is not 0. If this bit is set, the store data address is actually an index into the hardware status page.                                                                             |
|           |              | If this bit is set, this command will index into the per-process hardware status page if executed from within a non-secure batch buffer and if the Per-Process Virtual Address Space bit is set. Else the Global HW status page is used. |
|           | 20:19        | Reserved Project: All Format: MBZ                                                                                                                                                                                                        |
|           | 18           | TLB Invalidate Project: DevSNB+ Format: U1                                                                                                                                                                                               |
|           |              | If ENABLED, all TLBs will be invalidated once the flush operation is complete.<br>Note that if the flush TLB invalidation mode is clear, a TLB invalidate will occur<br>irrespective of this bit setting.                                |
|           |              | This bit is only valid when the Post-Sync Operation field is a value of 1h or 3h.                                                                                                                                                        |
|           | 17           | Synchronize Project: DevSNB+ Format: U1<br>GFDT surface                                                                                                                                                                                  |
|           |              | If enabled, at the end of the current flush the last level cache is cleared of all the cachelines which have been marked with the special GFDT flags. Store DW must be enabled                                                           |
|           | 16           | Reserved Project: All Format: MBZ                                                                                                                                                                                                        |



|   |       |                      |                        | MI_FL                            | USH_DW                                                                                                        |                    |                                  |
|---|-------|----------------------|------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------|--------------------|----------------------------------|
|   | 15:14 | Post-Syn             | c Operati              | on                               |                                                                                                               |                    |                                  |
|   |       | Project:             |                        | DevSNE                           | 3+                                                                                                            |                    |                                  |
|   |       | BitFieldDe           | esc                    |                                  |                                                                                                               |                    |                                  |
|   |       | Value                | Name                   | Descript                         | ion                                                                                                           |                    | Project                          |
|   |       | 0h                   |                        | instructio                       | occurs as a result of this<br>n. This can be used to implem<br>peration, etc.                                 | ient               | DevSNB+                          |
|   |       | 1h                   |                        | Write the<br>Data Low<br>Address | QWord containing Immediate<br>, High DWs to the Destination                                                   |                    | DevSNB+                          |
|   |       | 2h                   |                        | Reserved                         | 1                                                                                                             |                    | DevSNB+                          |
|   |       | 3h                   |                        | Destination                      | 32-bit TIMESTAMP register to<br>on Address with granularity of<br>Ipper 32-bits are tied to '0'               | the                | DevSNB+                          |
|   |       | Program              | nming Not              | tes                              |                                                                                                               |                    |                                  |
|   |       | If execut<br>address | ted in nor<br>space. I | n-secure ba<br>f in a secur      | tch buffer, the address given v<br>e ring or batch, address given                                             | vill be<br>will be | in a PPGTT<br>e in GGTT space    |
|   | 13:9  | Reserved             | d Proje                | ct: All                          |                                                                                                               | Forma              | at: MBZ                          |
|   | 8     | Notify En            | able                   | Project:                         | DevSNB+ Format: U1                                                                                            |                    |                                  |
|   |       | Interrupt            | Control re             | egisters) or                     | tion Interrupt will be generated<br>nee the sync operation is comp<br><i>Interface Registers</i> for details. | lete. S            | abled by the MI<br>See Interrupt |
|   | 7:6   | Reserved             | Proje                  | ct: All                          |                                                                                                               | Forma              | at: MBZ                          |
|   | 5:0   | DWord Le             | ength                  |                                  |                                                                                                               |                    |                                  |
|   |       | Default V            | alue:                  | 2h                               | Excludes DWord (0,                                                                                            | 1) =               |                                  |
|   |       |                      |                        |                                  | 1 for DWord, 2 for Q                                                                                          | Word               |                                  |
|   |       | Format:              |                        | =n                               |                                                                                                               | Total I            | Length - 2                       |
|   |       | Project:             |                        | All                              |                                                                                                               |                    |                                  |
| 1 | 31:3  | Address              |                        |                                  |                                                                                                               |                    |                                  |
|   |       | Project:             |                        | DevSNE                           | 3+                                                                                                            |                    |                                  |
|   |       | Address:             |                        | Graphic                          | sAddress[31:2]                                                                                                |                    |                                  |
|   |       | Surface T            | уре:                   | U32                              |                                                                                                               |                    |                                  |
|   |       |                      |                        |                                  | of the Address where the DWor<br>s can only be QWord aligned, i                                               |                    |                                  |



|    |      |            | МІ              | _FLUSH_DW                                                                          |            |
|----|------|------------|-----------------|------------------------------------------------------------------------------------|------------|
|    | 2    | Destinatio | n Address Ty    | ре                                                                                 |            |
|    |      | Project:   | Al              |                                                                                    |            |
|    |      | Defines ad | ddress space    | of Destination Address                                                             |            |
|    |      | Value      | Name            | Description                                                                        | Project    |
|    |      | 0h         | PPGTT           | Use PPGTT address space for DW<br>write                                            | / All      |
|    |      | 1h         | GGTT            | Use GGTT address space for DW write                                                | All        |
|    |      | -          | ming Notes      |                                                                                    |            |
|    |      | -          | f "No write" is | the selected in Operation.                                                         |            |
|    | 1:0  | Reserved   | Project:        | All Fo                                                                             | ormat: MBZ |
| 23 | 31:0 | Immediate  | e Data          |                                                                                    |            |
|    |      | Format:    | U               | 32                                                                                 |            |
|    |      | Address:   | Gr              | aphicsAddress[31:0]                                                                |            |
|    |      | Range      | 0               | 2^32-1                                                                             |            |
|    |      |            |                 | DWord value to be written to the targete<br>desired. Only valid when 15:14 in head |            |



## 2.2.6 MI\_LOAD\_REGISTER\_IMM

|                                             |                                       | MI_L                                                                                                                                                                                                                     | OAD_F                                                                        | REGISTEF                                                                                                     | R_IMM                                              |                                                                 |                  |
|---------------------------------------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------------|------------------|
| Project:                                    | De                                    | vSNB+                                                                                                                                                                                                                    |                                                                              | Length                                                                                                       | Bias:                                              | 2                                                               |                  |
| Engine:                                     | Bli                                   | tter                                                                                                                                                                                                                     |                                                                              |                                                                                                              | •                                                  |                                                                 |                  |
| command                                     | to the spe                            | SISTER_IMM command<br>scified Register Offset<br>ext command is exect                                                                                                                                                    | t (i.e., offse                                                               |                                                                                                              |                                                    |                                                                 |                  |
| Programm                                    | ning Note                             | s:                                                                                                                                                                                                                       |                                                                              |                                                                                                              |                                                    |                                                                 |                  |
|                                             |                                       | vior of this command i<br>f this command is dis                                                                                                                                                                          |                                                                              |                                                                                                              |                                                    |                                                                 |                  |
| ( <b>Security</b><br>command<br>register up | Indicator<br>stream co<br>odate for t | executed from a BB th<br>of the BATCH_BUF<br>onverts this command<br>his command to exect<br>sses should NOT be                                                                                                          | FER_STA<br>d to a NOC<br>cute.                                               | RT Command<br>P. Note that                                                                                   | d. If the ba                                       | tch buffer is inse                                              | ecure then the   |
|                                             | •                                     |                                                                                                                                                                                                                          |                                                                              | 15                                                                                                           |                                                    |                                                                 |                  |
| 1. 0x8                                      | 3800 - 0x8                            | 88FF                                                                                                                                                                                                                     |                                                                              |                                                                                                              |                                                    |                                                                 |                  |
| 2. >=                                       | 0x40000                               |                                                                                                                                                                                                                          |                                                                              |                                                                                                              |                                                    |                                                                 |                  |
|                                             |                                       |                                                                                                                                                                                                                          |                                                                              |                                                                                                              |                                                    |                                                                 |                  |
|                                             | 1                                     |                                                                                                                                                                                                                          |                                                                              |                                                                                                              |                                                    |                                                                 |                  |
| DWord                                       | Bit                                   |                                                                                                                                                                                                                          |                                                                              | Descri                                                                                                       | iption                                             |                                                                 |                  |
| <b>DWord</b>                                | Bit<br>31:29                          | Command Type                                                                                                                                                                                                             |                                                                              | Descri                                                                                                       | iption                                             |                                                                 |                  |
|                                             |                                       | Command Type<br>Default Value: 0h                                                                                                                                                                                        | MI_CC                                                                        | Descri                                                                                                       | iption                                             | Format:                                                         | OpCode           |
|                                             |                                       |                                                                                                                                                                                                                          |                                                                              |                                                                                                              | iption                                             | Format:                                                         | OpCode           |
|                                             | 31:29                                 | Default Value: 0h                                                                                                                                                                                                        | e                                                                            |                                                                                                              | iption                                             | Format:<br>Format:                                              | OpCode<br>OpCode |
|                                             | 31:29                                 | Default Value: 0h<br>MI Command Opcod                                                                                                                                                                                    | le<br>MI_                                                                    |                                                                                                              | MBZ                                                |                                                                 |                  |
|                                             | 31:29<br>28:23                        | Default Value: 0h<br>MI Command Opcod<br>Default Value: 22h                                                                                                                                                              | le<br>MI_                                                                    | DMMAND                                                                                                       |                                                    |                                                                 |                  |
|                                             | 31:29<br>28:23<br>22:12               | Default Value: 0h<br>MI Command Opcod<br>Default Value: 22h<br>Reserved Project                                                                                                                                          | le<br>MI_                                                                    | DMMAND<br>Format:                                                                                            | MBZ                                                |                                                                 | OpCode           |
|                                             | 31:29<br>28:23<br>22:12               | Default Value: 0h<br>MI Command Opcod<br>Default Value: 22h<br>Reserved Project<br>Byte Write Disables                                                                                                                   | e MI_<br>ct: All<br>Enable[4                                                 | DMMAND<br>Format:                                                                                            | MBZ<br>Bit 8                                       | Format:<br>corresponds to Da                                    | OpCode           |
|                                             | 31:29<br>28:23<br>22:12               | Default Value: 0h<br>MI Command Opcod<br>Default Value: 22h<br>Reserved Projec<br>Byte Write Disables<br>Format:                                                                                                         | e <u>MI_</u><br>ct: All<br>Enable[4<br>Must spe                              | DMMAND<br>Format:<br>4]<br>ecify a valid reg                                                                 | MBZ<br>Bit 8<br>ister write o                      | Format:<br>corresponds to Da                                    | OpCode           |
|                                             | 31:29<br>28:23<br>22:12               | Default Value: 0h<br>MI Command Opcod<br>Default Value: 22h<br>Reserved Projec<br>Byte Write Disables<br>Format:<br>Range                                                                                                | e MI_<br>ct: All<br>Enable[4<br>Must spe                                     | DMMAND<br>Format:<br>4]<br>ecify a valid reg                                                                 | MBZ<br>Bit 8<br>ister write o<br>occur.            | Format:<br>corresponds to Da                                    | OpCode           |
|                                             | 31:29<br>28:23<br>22:12               | Default Value: 0h<br>MI Command Opcod<br>Default Value: 22h<br>Reserved Projec<br>Byte Write Disables<br>Format:<br>Range<br>If [11:8] is '1111', the                                                                    | e <u>MI_</u><br>ct: All<br>Enable[ <sup>2</sup><br>Must spo<br>en the regist | DMMAND<br>Format:<br>1]<br>ecify a valid reg<br>ter write will not<br>er DW will be u                        | MBZ<br>Bit 8<br>ister write o<br>occur.<br>pdated. | Format:<br>corresponds to Da                                    | OpCode           |
|                                             | 31:29<br>28:23<br>22:12               | Default Value: 0h<br>MI Command Opcod<br>Default Value: 22h<br>Reserved Projec<br>Byte Write Disables<br>Format:<br>Range<br>If [11:8] is '1111', the<br>If [11:8] is '0000', the<br>Any other value, the                | e <u>MI_</u><br>ct: All<br>Enable[ <sup>2</sup><br>Must spo<br>en the regist | DMMAND<br>Format:<br>1]<br>ecify a valid reg<br>ter write will not<br>er DW will be u                        | MBZ<br>Bit 8<br>ister write o<br>occur.<br>pdated. | Format:<br>corresponds to Da                                    | OpCode           |
|                                             | 31:29<br>28:23<br>22:12<br>11:8       | Default Value: 0h<br>MI Command Opcod<br>Default Value: 22h<br>Reserved Project<br>Byte Write Disables<br>Format:<br>Range<br>If [11:8] is '1111', the<br>If [11:8] is '0000', the<br>Any other value, the<br>undefined. | e <u>MI_</u><br>ct: All<br>Enable[ <sup>2</sup><br>Must spo<br>en the regist | DMMAND<br>Format:<br>4]<br>ecify a valid reg<br>ter write will not<br>er DW will be u<br>ill be specifically | MBZ<br>Bit 8<br>ister write o<br>occur.<br>pdated. | Format:<br>corresponds to Da<br>operation<br>by the register or | OpCode           |



|   |      | MI_LOAD_REGISTER_IMM                                                                                                              |
|---|------|-----------------------------------------------------------------------------------------------------------------------------------|
| 1 | 31:2 | Register Offset                                                                                                                   |
|   |      | Format: U30                                                                                                                       |
|   |      | Address: MmioAddress[31:2]                                                                                                        |
|   |      | This field specifies bits [31:2] of the offset into the Memory Mapped Register Range (i.e., this field specifies a DWord offset). |
|   | 1:0  | Reserved Project: All Format: MBZ                                                                                                 |
| 2 | 31:0 | Data DWord                                                                                                                        |
|   |      | Mask: Bytes Write Disables                                                                                                        |
|   |      | Format: U32                                                                                                                       |
|   |      | This field specifies the DWord value to be written to the targeted location.                                                      |

### 2.2.7 MI\_NOOP

|                                            |                                          |                                             |                                            | MI_NO                            | OP                                                     |                        |                        |                                                                            |
|--------------------------------------------|------------------------------------------|---------------------------------------------|--------------------------------------------|----------------------------------|--------------------------------------------------------|------------------------|------------------------|----------------------------------------------------------------------------|
| Project:                                   | Dev                                      | /SNB+                                       |                                            |                                  | Length Bias:                                           | 1                      |                        |                                                                            |
| Engine:                                    | Blit                                     |                                             |                                            |                                  |                                                        |                        |                        |                                                                            |
| pad the cor<br>one minor (<br>register. Tl | mmand str<br>(optional) f<br>his provide | ream (e.g.,<br>function this<br>es a genera | in order to p<br>s command<br>Il-purpose c | bad out a batch<br>can perform - | h buffer to a QV<br>a 22-bit value<br>im tagging ("bre | Vord boui<br>can be lo | ndary). H<br>aded into | s typically used to<br>lowever, there is<br>the MI NOPID<br>nism (e.g., to |
| DWord                                      | Bit                                      | Description                                 |                                            |                                  |                                                        |                        |                        |                                                                            |
| 0                                          | 31:29                                    | Command                                     | д Туре                                     |                                  |                                                        |                        |                        |                                                                            |
|                                            |                                          | Default Va                                  | lue: 0h                                    | MI_COMMA                         | ND                                                     |                        | Format:                | OpCode                                                                     |
|                                            | 28:23                                    | MI Comm                                     | and Opcode                                 |                                  |                                                        |                        |                        |                                                                            |
|                                            |                                          | Default Va                                  | llue: 0h                                   | MI_NOOP                          |                                                        |                        | Format:                | OpCode                                                                     |
|                                            | 22                                       | Identificat                                 | ion Number                                 | Register Write E                 | nable                                                  |                        |                        |                                                                            |
|                                            |                                          | Project:                                    | Project: All                               |                                  |                                                        |                        |                        |                                                                            |
|                                            |                                          | Format:                                     |                                            | Enable                           |                                                        |                        |                        |                                                                            |
|                                            |                                          | NOPID                                       |                                            | isabled, that reg                | tification Number<br>ister is unmodifie                |                        |                        |                                                                            |
|                                            |                                          | Value                                       | Name                                       | Descript                         | on                                                     |                        |                        | Project                                                                    |
|                                            |                                          | 0h                                          | Disable                                    | Do not w                         | rite the NOP_ID                                        | register.              |                        | All                                                                        |
|                                            |                                          | 1h                                          | Enable                                     | Write the                        | NOP_ID registe                                         | er.                    |                        | All                                                                        |
|                                            | 31:0                                     | Identificat                                 | ion Number                                 | Proj                             | ect: All                                               | Format:                | U22                    |                                                                            |
|                                            |                                          | This field o                                | contains a 22                              | -bit number whi                  | ch can be written                                      | to the MI              | NOPID reg              | gister.                                                                    |



### 2.2.8 MI\_REPORT\_HEAD

|            | N                                                                                                     | II_REPORT_HEAD |  |  |
|------------|-------------------------------------------------------------------------------------------------------|----------------|--|--|
| Project:   | DevSNB+                                                                                               | Length Bias: 1 |  |  |
| Engine:    | Blitter                                                                                               |                |  |  |
| The MI REP | The MI REPORT HEAD command causes the Head Pointer value of the active ring buffer to be written to a |                |  |  |

The MI\_REPORT\_HEAD command causes the Head Pointer value of the active ring buffer to be written to a cacheable (snooped) system memory location.

#### Programming Notes:

• This command must not be executed from a Batch Buffer (Refer to the description of the HSW\_PGA register).

| DWord | Bit   | Description                       |         |        |  |  |
|-------|-------|-----------------------------------|---------|--------|--|--|
| 0     | 31:29 | Command Type                      |         |        |  |  |
|       |       | Default Value: 0h MI_COMMAND      | Format: | OpCode |  |  |
|       | 28:23 | MI Command Opcode                 |         |        |  |  |
|       |       | Default Value: 07h MI_REPORT_HEAD | Format: | OpCode |  |  |
|       | 22:0  | Reserved Project: All Format: MBZ |         |        |  |  |

### 2.2.9 MI\_SEMAPHORE\_MBOX

| MI_SEMAPHORE_MBOX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                          |                                                                                                                                                                                      |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Project:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | DevSNB+                  | Length Bias: 2                                                                                                                                                                       |  |  |
| Engine:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Blitter                  |                                                                                                                                                                                      |  |  |
| This command is provided as alternative to MI_SEMAPHORE to provide mailbox-type semaphores where there is no update of the semaphore by the checking process (the consumer). Single-bit compare-and-update semantics are also provided. In either case, atomic access of semaphores need not be guaranteed by hardware as with the previous command. This command should eventually supersede the previous command.                                                                                                                                                                                                                                                 |                          |                                                                                                                                                                                      |  |  |
| Synchronization between contexts (especially between contexts running on 2 different engines) is provided by the MI_SEMAPHORE_MBOX command. Note that contexts attempting to synchronize in this fashion must be able to access a common memory location. This means the contexts must share the same virtual address space (have the same page directory), must have a common physical page mapped into both of their respective address spaces or the semaphore commands must be executing from a secure batch buffer or directly from a ring with the <b>Use Global GTT</b> bit set such that they are "privileged" and will use the (always shared) global GTT. |                          |                                                                                                                                                                                      |  |  |
| the <i>Signal</i> co                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ommand, while the Wait o | maphore bit <u>set</u> (and the Compare Semaphore bit <u>clear</u> ) implen<br>ommand is indicated by Compare Semaphore being <u>set</u> . Note th<br>al increments unconditionally. |  |  |



|       |       | MI_SEMAPHORE_MBOX                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| DWord | Bit   | Description                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| 0     | 31:29 | Command Type<br>Default Value: 0h MI_COMMAND Format: OpCode                                                                                                                                                                                                          |  |  |  |  |  |  |
|       | 28:23 | MI Command Opcode                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|       |       | Default Value: 16h MI_SEMAPHORE_MBOX Format: OpCode                                                                                                                                                                                                                  |  |  |  |  |  |  |
|       | 22    | Use Global GTT Project: All Format: U32                                                                                                                                                                                                                              |  |  |  |  |  |  |
|       |       | If set, this command will use the global GTT to translate the Semaphore Address and this command must be executing from a privileged (secure) batch buffer. If clear, the PPGTT will be used to translate the Semaphore Address.                                     |  |  |  |  |  |  |
|       |       | This bit will be ignored (and treated as if clear) if this command is executed from a non-<br>privileged batch buffer. It is allowed for this bit to be clear when executing this command<br>from a privileged (secure) batch buffer or directly from a ring buffer. |  |  |  |  |  |  |
|       | 21    | Update Project: All Format: U32<br>Semaphore                                                                                                                                                                                                                         |  |  |  |  |  |  |
|       |       | If set, the value from the Semaphore Data Dword is written to memory. If Compare Semaphore is also set, the semaphore is not updated if the semaphore comparison fails.                                                                                              |  |  |  |  |  |  |
|       |       | If clear, the data at Semaphore Address is not changed.                                                                                                                                                                                                              |  |  |  |  |  |  |
|       | 20    | Compare Project: All Format: U32<br>Semaphore                                                                                                                                                                                                                        |  |  |  |  |  |  |
|       |       | If set, the value from the Semaphore Data Dword is compared to the value from the Semaphore Address in memory. If the value at Semaphore Address is greater than the Semaphore Data Dword, execution is continued from the current command buffer.                   |  |  |  |  |  |  |
|       |       | If clear, no comparison takes place. Update Semaphore <i>must</i> be set in this case.                                                                                                                                                                               |  |  |  |  |  |  |
|       | 19    | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|       | 18    | Compare Register Project: DevSNB+ Format: Compare Type                                                                                                                                                                                                               |  |  |  |  |  |  |
|       |       | If set, data in MMIO register will be used for compare.                                                                                                                                                                                                              |  |  |  |  |  |  |
|       |       | If clear, data in memory will be used for compare.                                                                                                                                                                                                                   |  |  |  |  |  |  |
|       | 17:16 | Register Select Project: DevSNB Format: Register Select<br>+                                                                                                                                                                                                         |  |  |  |  |  |  |
|       |       | If compare register is set in bit[18], this filed indicate which register will be used.<br>0: CS register (BRSYNC)<br>1: Reserved<br>2: VCS regiser (BVSYNC)                                                                                                         |  |  |  |  |  |  |
|       |       | 3: Reserved                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|       | 15:8  | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|       | 7:0   | DWord Length                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|       |       | Default Value: 0h Excludes DWord (0,1)                                                                                                                                                                                                                               |  |  |  |  |  |  |
|       |       | Format: =n Total Length - 2                                                                                                                                                                                                                                          |  |  |  |  |  |  |



|   | MI_SEMAPHORE_MBOX |                                                                                                                                                                                                                                                                |  |  |  |
|---|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 1 | 31:0              | Semaphore Data Dword Project: All Format: U32                                                                                                                                                                                                                  |  |  |  |
|   |                   | Data dword to compare/update memory. The Data dword is supplied by software to control execution of the command buffer. If the compare is enabled and the data at Semaphore Address is greater than this dword, the execution of the command buffer continues. |  |  |  |
| 2 | 31:2              | PointerBitFieldName/MMIO Register Address                                                                                                                                                                                                                      |  |  |  |
|   |                   | Project: All                                                                                                                                                                                                                                                   |  |  |  |
|   |                   | Address: GraphicsVirtualAddress[31:2]                                                                                                                                                                                                                          |  |  |  |
|   |                   | Surface Type: Semaphore                                                                                                                                                                                                                                        |  |  |  |
|   |                   | if Compare Register bit[18] is cleared, this field if the Graphics Memory Address of the 32 bit value for the semaphore.                                                                                                                                       |  |  |  |
|   |                   | If Compare Register bit[18] is set, this field is the MMIO address of the register for the semaphore.                                                                                                                                                          |  |  |  |
|   | 1:0               | Reserved Project: All Format: MBZ                                                                                                                                                                                                                              |  |  |  |

### 2.2.10 MI\_STORE\_REGISTER\_MEM

|                             | MI_STORE_REGISTER_MEM                      |                                                                                                                                                   |  |  |  |  |  |
|-----------------------------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Project:                    | DevSNB+                                    | Length Bias: 2                                                                                                                                    |  |  |  |  |  |
| Engine:                     | Blitter                                    |                                                                                                                                                   |  |  |  |  |  |
| register loca               |                                            | EM command requests a register read from a specified memory mapped d store of that DWord to memory. The register address is specified along read. |  |  |  |  |  |
| Programmi                   | ng Notes:                                  |                                                                                                                                                   |  |  |  |  |  |
| The comma                   | nd temporarily halts                       | command execution.                                                                                                                                |  |  |  |  |  |
| The memory                  | address for the writ                       | e is snooped on the host bus.                                                                                                                     |  |  |  |  |  |
|                             | nd will cause undefir<br>0 or FENCE regist | ned data to be written to memory if given register addresses for the ers                                                                          |  |  |  |  |  |
|                             |                                            | cenarios, this command cannot be executed if there are additional posted te) being sent to the same command streamer.                             |  |  |  |  |  |
| The followin                | g addresses should l                       | NOT be used for SRMs                                                                                                                              |  |  |  |  |  |
| 1                           | . 0x8800 - 0x88                            | FF                                                                                                                                                |  |  |  |  |  |
| 2                           | . >= 0x40000                               |                                                                                                                                                   |  |  |  |  |  |
| The only exo<br>requirement |                                            | cle to 0x40000-0xBFFFF when used as part of the LRI read-after-write                                                                              |  |  |  |  |  |



|       |             | MI_STORE_REGISTER_MEM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| DWord | Bit         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
| )     | 31:29       | Command Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|       |             | Default Value: 0h MI_COMMAND Format: OpCode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|       | 28:23       | MI Command Opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|       |             | Default Value: 24h MI_STORE_REGISTER_MEM Format: OpCode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|       | 22          | Use Global GTT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|       |             | Project: All                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|       |             | This bit <i>must</i> be '1' if the Per Process GTT Enable bit is clear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|       |             | Value Name Description Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|       |             | Oh Per Process All Graphics Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|       |             | 1hGlobal Graphics<br>AddressThis command will use the global GTT to<br>translate the Address and this command must<br>be executing from a privileged (secure) batch<br>buffer.All                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|       |             | Programming Notes:<br>[DevSNB] This will be ignored and treated as if clear when executing from a PPGTT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|       |             | (i.e. runlist mode "non-secure") batch buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
|       | 21:8        | (i.e. runlist mode "non-secure") batch buffer         Reserved       Project:       All       Format:       MBZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
|       | 21:8<br>7:0 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
|       |             | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|       |             | Reserved     Project:     All     Format:     MBZ       DWord Length                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|       |             | Reserved     Project:     All     Format:     MBZ       DWord Length       Default Value:     1h     Excludes DWord (0,1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
|       | 7:0         | Reserved     Project:     All     Format:     MBZ       DWord Length       Default Value:     1h     Excludes DWord (0,1)       Format:     =n     Total Length - 2       Reserved     Project:     DevSNB     Format:     MBZ                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|       | 7:0         | Reserved       Project:       All       Format:       MBZ         DWord Length       Default Value:       1h       Excludes DWord (0,1)         Format:       =n       Total Length - 2         Reserved       Project:       DevSNB       Format:       MBZ                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|       | 7:0         | Reserved       Project:       All       Format:       MBZ         DWord Length       Default Value:       1h       Excludes DWord (0,1)         Format:       =n       Total Length - 2         Reserved       Project:       DevSNB       Format:       MBZ         +       Register Address       Register Address       Register Address                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|       | 7:0         | Reserved     Project:     All     Format:     MBZ       DWord Length     Default Value:     1h     Excludes DWord (0,1)       Format:     =n     Total Length - 2       Reserved     Project:     DevSNB     Format:     MBZ       +     Project:     All                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
|       | 7:0         | Reserved     Project:     All     Format:     MBZ       DWord Length     Default Value:     1h     Excludes DWord (0,1)       Format:     =n     Total Length - 2       Reserved     Project:     DevSNB     Format:     MBZ       Register Address     +     MBZ       Project:     All       Address:     MMIO Address[22:2]                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|       | 7:0         | Reserved       Project:       All       Format:       MBZ         DWord Length       Default Value:       1h       Excludes DWord (0,1)         Format:       =n       Total Length - 2         Reserved       Project:       DevSNB       Format:       MBZ         Register Address       +       Register Address       Project:       All         Address:       MMIO Address[22:2]       Surface Type:       MMIO Register         This field specifies Bits 22:2 of the Register offset the DWord will be read from. As the                                                                                                                                               |  |  |  |  |  |  |  |
|       | 7:0         | Reserved       Project:       All       Format:       MBZ         DWord Length       Default Value:       1h       Excludes DWord (0,1)         Format:       =n       Total Length - 2         Reserved       Project:       DevSNB       Format:       MBZ         +       Register Address       +       Register Address         Project:       All       Address[22:2]       Surface Type:       MMIO Address[22:2]         Surface Type:       MMIO Register       This field specifies Bits 22:2 of the Register offset the DWord will be read from. As the register address must be DWord-aligned, Bits 1:0 of that address MBZ.                                        |  |  |  |  |  |  |  |
|       | 7:0         | Reserved       Project:       All       Format:       MBZ         DWord Length       Default Value:       1h       Excludes DWord (0,1)         Format:       =n       Total Length - 2         Reserved       Project:       DevSNB       Format:       MBZ         Register Address       Project:       DevSNB       Format:       MBZ         Project:       All       Address[22:2]       Surface Type:       MMIO Address[22:2]         Surface Type:       MMIO Register       This field specifies Bits 22:2 of the Register offset the DWord will be read from. As the register address must be DWord-aligned, Bits 1:0 of that address MBZ.         Programming Notes |  |  |  |  |  |  |  |



|   | MI_STORE_REGISTER_MEM |                                                  |                                                                                                                                                                                      |  |  |  |  |  |
|---|-----------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 2 | 31:2                  | Memory Address                                   | Memory Address                                                                                                                                                                       |  |  |  |  |  |
|   |                       | Project:                                         | DevSNB+                                                                                                                                                                              |  |  |  |  |  |
|   |                       | Address:                                         | GraphicsAddress[31:2]                                                                                                                                                                |  |  |  |  |  |
|   |                       | Surface Type:                                    | MMIO Register                                                                                                                                                                        |  |  |  |  |  |
|   |                       | Range:                                           | GraphicsVirtualAddress[31:2] for a DWord register                                                                                                                                    |  |  |  |  |  |
|   |                       | This field specifies the<br>the DWord above will | This field specifies the address of the memory location where the register value specified in the DWord above will be written. The address specifies the DWord location of the data. |  |  |  |  |  |
|   | 1:0                   | Reserved Project:                                | All Format: MBZ                                                                                                                                                                      |  |  |  |  |  |

### 2.2.11 MI\_STORE\_DATA\_IMM

| MI_STORE_DATA_IMM                                                                                                                                                                                          |         |              |   |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------|---|--|--|
| Project:                                                                                                                                                                                                   | DevSNB+ | Length Bias: | 2 |  |  |
| Engine:                                                                                                                                                                                                    | Blitter |              |   |  |  |
| The MI_STORE_DATA_IMM command requests a write of the QWord constant supplied in the packet to the specified Memory Address. As the write targets a System Memory Address, the write operation is coherent |         |              |   |  |  |

with the CPU cache (i.e., the processor cache is snooped).

#### Programming Notes:

This command can be used for general software synchronization through variables in cacheable memory (i.e., where software does not need to poll un-cached memory or device registers). However, the cacheable nature of the transaction is determined by the setting of the "mapping type" in the GTT entry.

This command simply initiates the write operation with command execution proceeding normally. Although the write operation is guaranteed to complete "eventually", there is no mechanism to synchronize command execution with the completion (or even initiation) of these operations. All writes to memory generated using this command are expected to finish in order.

| DWord | Bit   | Description        |                   |         |        |  |  |
|-------|-------|--------------------|-------------------|---------|--------|--|--|
| 0     | 31:29 | Command Type       |                   |         |        |  |  |
|       |       | Default Value: 0h  | MI_COMMAND        | Format: | OpCode |  |  |
|       | 28:23 | MI Command Opcode  |                   |         |        |  |  |
|       |       | Default Value: 20h | MI_STORE_DATA_IMM | Format: | OpCode |  |  |



|   |      | MI_STORE_DATA_IMM                                                                                                                                                                                                 |   |  |  |  |  |  |
|---|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--|--|--|--|
|   | 22   | Use Global GTT                                                                                                                                                                                                    |   |  |  |  |  |  |
|   |      | Project: All                                                                                                                                                                                                      |   |  |  |  |  |  |
|   |      | This bit <i>must</i> be '1' if the Per Process GTT Enable bit is clear.                                                                                                                                           |   |  |  |  |  |  |
|   |      | Value Name Description Projec                                                                                                                                                                                     | t |  |  |  |  |  |
|   |      | 0h Per Process All<br>Graphics Address                                                                                                                                                                            |   |  |  |  |  |  |
|   |      | 1hGlobal Graphics<br>AddressThis command will use the global GTT to<br>translate the Address and this command must<br>be executing from a privileged (secure) batch<br>                                           |   |  |  |  |  |  |
|   |      | Programming Notes:<br>[DevSNB] This will be ignored and treated as if clear when executing from a PPGTT<br>(i.e. runlist mode "non-secure") batch buffer                                                          |   |  |  |  |  |  |
|   | 21:8 | Reserved Project: All Format: MBZ                                                                                                                                                                                 |   |  |  |  |  |  |
|   | 7:0  | DWord Length                                                                                                                                                                                                      |   |  |  |  |  |  |
|   |      | Default Value: 2h Excludes DWord (0,1) =<br>2 for DWord, 3 for QWord                                                                                                                                              |   |  |  |  |  |  |
|   |      | Format: =n Total Length - 2                                                                                                                                                                                       |   |  |  |  |  |  |
| 1 | 31:0 | Reserved Project: All Format: MBZ                                                                                                                                                                                 |   |  |  |  |  |  |
| 2 | 31:2 | Address                                                                                                                                                                                                           |   |  |  |  |  |  |
|   |      | Project: All                                                                                                                                                                                                      |   |  |  |  |  |  |
|   |      | Address: GraphicsAddress[31:2]                                                                                                                                                                                    |   |  |  |  |  |  |
|   |      | Surface Type: U32(2)                                                                                                                                                                                              |   |  |  |  |  |  |
|   |      | This field specifies Bits 31:2 of the Address where the DWord will be stored. As the store address must be DWord-aligned, Bits 1:0 of that address MBZ. This address must be 8B aligned for a store "QW" command. |   |  |  |  |  |  |
|   | 1:0  | Reserved Project: All Format: MBZ                                                                                                                                                                                 |   |  |  |  |  |  |
| 3 | 31:0 | Data DWord 0 Project: All Format: U32                                                                                                                                                                             |   |  |  |  |  |  |
|   |      | This field specifies the DWord value to be written to the targeted location.<br>For a QWord write this DWord is the lower DWord of the QWord to be reported (DW 0).                                               |   |  |  |  |  |  |
| 4 | 31:0 | Data DWord 1 Project: All Format: U32                                                                                                                                                                             |   |  |  |  |  |  |
|   |      | This field specifies the upper DWord value to be written to the targeted QWord location (DW 1).                                                                                                                   |   |  |  |  |  |  |

### 2.2.12 MI\_STORE\_DATA\_INDEX

### MI\_STORE\_DATA\_INDEX



|                         | _                        |                                                                                                                            |                                                                              |                                                                      |                                                                         |                                                 | 1.                                                         |                                |  |
|-------------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------|------------------------------------------------------------|--------------------------------|--|
| Project:                |                          | /SNB+                                                                                                                      |                                                                              |                                                                      | Length                                                                  | Bias:                                           | 2                                                          |                                |  |
| specified o             | ffset from<br>ts a Syste | TA_INDEX com<br>the System Add                                                                                             | dress de                                                                     | fined by th                                                          | he Hardwar                                                              | e Status                                        | nstant supplied in<br>Page Address R<br>PU cache (i.e., th | egister. As the                |  |
| Programm                | ning Note                | s:                                                                                                                         |                                                                              |                                                                      |                                                                         |                                                 |                                                            |                                |  |
| Jse of this<br>JNDEFINE |                          | l with an invalid                                                                                                          | l or uninit                                                                  | tialized va                                                          | lue in the H                                                            | lardware                                        | Status Page Ado                                            | dress Register is              |  |
|                         |                          | e used for gene<br>does not need                                                                                           |                                                                              |                                                                      |                                                                         |                                                 | variables in cach<br>gisters).                             | eable memory                   |  |
| the write o             | peration is              |                                                                                                                            | complete                                                                     | e "eventua                                                           | ally", there i                                                          | s no me                                         | n proceeding nor<br>chanism to synch                       | mally. Although ronize command |  |
| DWord                   | Bit                      |                                                                                                                            |                                                                              |                                                                      | Descr                                                                   | iption                                          |                                                            |                                |  |
| 0                       | 31:29                    | Command Type                                                                                                               |                                                                              |                                                                      |                                                                         |                                                 |                                                            |                                |  |
|                         |                          | Default Value: 0h MI_COMMAND Format: Op                                                                                    |                                                                              |                                                                      |                                                                         |                                                 |                                                            | OpCode                         |  |
|                         | 28:23                    | MI Command Opcode                                                                                                          |                                                                              |                                                                      |                                                                         |                                                 |                                                            |                                |  |
|                         |                          | Default Value:                                                                                                             | 21h                                                                          | MI_STO                                                               | RE_DATA_II                                                              | NDEX                                            | Format:                                                    | OpCode                         |  |
|                         | 22                       | Reserve<br>d                                                                                                               | Project:                                                                     | All                                                                  | Format:                                                                 | MBZ                                             |                                                            |                                |  |
|                         | 21                       | Lisa Par-Pro                                                                                                               | ocess Har                                                                    | dwara Stat                                                           |                                                                         |                                                 |                                                            |                                |  |
|                         | 21                       | Use Per-Process Hardware Status Page Project: All                                                                          |                                                                              |                                                                      |                                                                         |                                                 |                                                            |                                |  |
|                         | 21                       | Project:                                                                                                                   |                                                                              |                                                                      | tus Page                                                                |                                                 |                                                            |                                |  |
|                         |                          | Project:<br>If this bit is set                                                                                             | , this com                                                                   | All<br>mand will i                                                   | index into the                                                          |                                                 | ess hardware statu<br>atus Page will be in                 |                                |  |
|                         |                          | Project:<br>If this bit is set<br>28K from the<br>Programming                                                              | , this com<br>e LRCA.<br>Notes:<br>is will be                                | All<br>mand will i<br>If clear, the<br>ignored a                     | index into the<br>e Global Har<br>and treated                           | dware Sta<br>as if set                          |                                                            | dexed.                         |  |
|                         | 20:8                     | Project:<br>If this bit is set<br>28K from the<br>Programming<br>[DevSNB] Th                                               | , this com<br>e LRCA.<br>Notes:<br>is will be<br>ode "non                    | All<br>mand will i<br>If clear, the<br>ignored a                     | index into the<br>e Global Har<br>and treated                           | dware Sta<br>as if set                          | atus Page will be in                                       | dexed.                         |  |
|                         |                          | Project:<br>If this bit is set<br>28K from the<br>Programming<br>[DevSNB] Th<br>(i.e. runlist me                           | , this com<br>e LRCA.<br>Notes:<br>is will be<br>ode "non<br>Project:        | All<br>mand will i<br>If clear, the<br>ignored a<br>-secure")        | index into the<br>e Global Har<br>and treated<br>batch buffe            | dware Sta<br>as if set<br>er                    | atus Page will be in                                       | dexed.                         |  |
|                         | 20:8                     | Project:<br>If this bit is set<br>28K from the<br>Programming<br>[DevSNB] Th<br>(i.e. runlist mo<br>Reserved               | , this com<br>e LRCA.<br>Notes:<br>is will be<br>ode "non<br>Project:<br>gth | All<br>mand will i<br>If clear, the<br>ignored a<br>-secure")        | index into the<br>e Global Har<br>and treated<br>batch buffe<br>Format: | dware Sta<br>as if set<br>r<br>MBZ<br>cludes DV | atus Page will be in                                       | dexed.                         |  |
|                         | 20:8                     | Project:<br>If this bit is set<br>28K from the<br>Programming<br>[DevSNB] Th<br>(i.e. runlist me<br>Reserved<br>DWord Leng | , this com<br>e LRCA.<br>Notes:<br>is will be<br>ode "non<br>Project:<br>gth | All<br>mand will i<br>If clear, the<br>ignored a<br>-secure")<br>All | index into the<br>e Global Har<br>and treated<br>batch buffe<br>Format: | dware Sta<br>as if set<br>r<br>MBZ<br>cludes DV | atus Page will be in<br>when executing f                   | dexed.<br>rom a PPGTT          |  |



|   | MI_STORE_DATA_INDEX |                                                                                                                                                                                                                                                                         |                                                                                                                                                                     |             |                |                 |                    |
|---|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------|-----------------|--------------------|
|   | 11:2                | Offset                                                                                                                                                                                                                                                                  |                                                                                                                                                                     |             |                |                 |                    |
|   |                     | Project:                                                                                                                                                                                                                                                                | All                                                                                                                                                                 |             |                |                 |                    |
|   |                     | Format:                                                                                                                                                                                                                                                                 | U10                                                                                                                                                                 | zero-b      | ased DWord     | offset into the | e HW status page.  |
|   |                     | Address:                                                                                                                                                                                                                                                                | Hardwar                                                                                                                                                             | eStatusP    | ageOffset[17   | 1:2]            |                    |
|   |                     | Surface Type:                                                                                                                                                                                                                                                           | U32                                                                                                                                                                 |             |                |                 |                    |
|   |                     | Range                                                                                                                                                                                                                                                                   | [16, 1023                                                                                                                                                           | 3]          |                |                 |                    |
|   |                     | This field specifies the offset (into the hardware status page) to which the data will be written. Note that the first few DWords of this status page are reserved for special purpose data storage – targeting these reserved locations via this command is UNDEFINED. |                                                                                                                                                                     |             |                |                 |                    |
|   |                     | This address must b                                                                                                                                                                                                                                                     | e 8B aligneo                                                                                                                                                        | d for a sto | re "QW" cor    | nmand.          |                    |
|   | 1:0                 | Reserved Project                                                                                                                                                                                                                                                        | t: All                                                                                                                                                              | Forn        | nat: MBZ       |                 |                    |
| 2 | 31:0                | Data DWord 0                                                                                                                                                                                                                                                            | Project:                                                                                                                                                            | All         | Format:        | U32             |                    |
|   |                     |                                                                                                                                                                                                                                                                         | This field specifies the DWord value to be written to the targeted location.<br>For a QWord write this DWord is the lower DWord of the QWord to be reported (DW 0). |             |                |                 |                    |
| 3 | 31:0                | Data DWord 1                                                                                                                                                                                                                                                            | Project:                                                                                                                                                            | All         | Format:        | U32             |                    |
|   |                     | This field specifies th<br>(DW 1).                                                                                                                                                                                                                                      | ne upper DV                                                                                                                                                         | Vord value  | e to be writte | en to the targe | ted QWord location |

### 2.2.13 MI\_SUSPEND\_FLUSH

|           | MI_SUSPEND_FLUSH |                           |                      |         |   |         |        |  |  |  |
|-----------|------------------|---------------------------|----------------------|---------|---|---------|--------|--|--|--|
| Project:  | All              |                           | Lengtl               | n Bias: | 1 |         |        |  |  |  |
| Engine:   | Blit             | ter                       |                      |         |   |         |        |  |  |  |
| Blocks MM | IIO sync fl      | ush or any flushes relate | ed to VT-d while ena | abled.  |   |         |        |  |  |  |
| DWord     | Bit              |                           | Desci                | ription |   |         |        |  |  |  |
| 0         | 31:29            | Command Type              |                      |         |   |         |        |  |  |  |
|           |                  | Default Value: 0h         | MI_COMMAND           |         |   | Format: | OpCode |  |  |  |
|           | 28:23            | MI Command Opcode         |                      |         |   |         |        |  |  |  |
|           |                  | Default Value: 0Bh        | MI_SUSPEND_FLU       | SH      |   | Format: | OpCode |  |  |  |
|           | 22:1             | Reserved Project:         | All Format:          | MBZ     |   |         |        |  |  |  |



| MI_SUSPEND_FLUSH |   |            |                           |       |             |                                  |
|------------------|---|------------|---------------------------|-------|-------------|----------------------------------|
|                  | 0 | Suspen     | d Flush                   |       |             |                                  |
|                  |   | Project:   |                           | All   |             |                                  |
|                  |   | Default Va | lue:                      | 0h    | DefaultVau  | eDesc                            |
|                  |   | Format:    |                           | Enabl | )           | FormatDesc                       |
|                  |   |            | suspends flu<br>and IOTLB |       |             | ush generated during VTD enable, |
|                  |   | Value      | Name                      |       | Description | Project                          |
|                  |   | 0h         | Disable                   |       |             | All                              |
|                  |   | 1h         | Enable                    |       |             | All                              |

### 2.2.14 MI\_UPDATE\_GTT

### 2.2.14.1 MI\_UPDATE\_GTT [DevSNB]

|                                                            | MI_UPDATE_GTT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                             |                       |        |                                                                    |  |  |  |
|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-----------------------|--------|--------------------------------------------------------------------|--|--|--|
| Project:                                                   | [De                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | vSNB]                                       | Length                | Bias:  | 2                                                                  |  |  |  |
| Engine:                                                    | Blitt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | er                                          |                       |        |                                                                    |  |  |  |
|                                                            | The MI_UPDATE_GTT command is used to update GTT page table entries in a coherent manner and at a<br>predictable place in the command flow.                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                             |                       |        |                                                                    |  |  |  |
| that are still<br>will also inv<br>MI_FLUSH<br>GTT entries | An MI_FLUSH should be placed before this command, since work associated with preceding commands that are still in the pipeline may be referencing GTT entries that will be changed by its execution. The flush will also invalidate TLBs and read caches that may become invalid as a result of the changed GTT entries.<br>MI_FLUSH is not required if it can be guaranteed that the pipeline is free of any work that relies on changing GTT entries (such as MI_UPDATE_GTT contained in a paging DMA buffer that is doing only update/mapping activities and no rendering). |                                             |                       |        |                                                                    |  |  |  |
|                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ommand. This comma<br>a non-secure batch bu |                       | a no-c | op and an error flagged if it is                                   |  |  |  |
|                                                            | dates canr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                             |                       |        | ent from the render CS definition.<br>ave to use storeDW for PPGTT |  |  |  |
| [DevSNB]                                                   | The addre                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ess of the header canne                     | ot be 64-bit aligned. |        |                                                                    |  |  |  |
| chooses to                                                 | Note that MI_UPDATE_GTT is mainly for the pages that are strictly used by processor graphics. If driver chooses to update the CPU used pages thru MI_UPDATE_GTT, it needs to write to MMIO address x101008 (any value) to ensure system agent TLBs are invalidated before the new pages can be used.                                                                                                                                                                                                                                                                           |                                             |                       |        |                                                                    |  |  |  |
| DWord                                                      | Dit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                             | Descrit               | tion   |                                                                    |  |  |  |
| DWord                                                      | Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                             | Descri                | uon    |                                                                    |  |  |  |
| 0                                                          | 31:29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Command Type                                |                       |        |                                                                    |  |  |  |
|                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Default Value: 0h                           | MI_COMMAND            |        | Format: OpCode                                                     |  |  |  |



|      |       | MI_UPDATE_GTT                                                                                                                                                                                                                                                                |
|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 28:23 | MI Command Opcode Default Value: 23h MI_UPDATE_GTT Format: OpCode                                                                                                                                                                                                            |
|      | 22    | Use Global GTT Project: All Reserved: Must be 1h. Updating Per Process Graphics Address is not supported                                                                                                                                                                     |
|      |       | Value Name Description Project<br>Oh Per Process Illegal, not supported. All<br>Graphics<br>Address                                                                                                                                                                          |
|      |       | 1hGlobalThis command will use the global GTTAllGraphicsto translate the Address and thisAddresscommand must be executing from a<br>privileged (secure) batch buffer.                                                                                                         |
|      | 21: 6 | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                            |
|      | 5:0   | DWord Length         Default Value:       0h         Excludes DWord (0,1)         Format:       = n         Total Length - 2, max 61                                                                                                                                         |
| 1n+1 | 63:44 | Entry Address         Project:       All         Address:       GraphicsAddress[31:12]         This field simply holds the DW offset of the first table entry to be modified. Note that one or more of the upper bits may need to be 0, i.e., for a 2G aperture, bit 31 MBZ. |
|      | 43:32 | Reserved Project: All Format: MBZ                                                                                                                                                                                                                                            |
|      | 31:0  | Entry Data         Project:       All         Format:       Table Entry         This Dword becomes the new page table entry. See PPGTT/Global GTT Table Entries (PTEs) in Memory Interface Registers.                                                                        |



### 2.2.15 MI\_USER\_INTERRUPT

| MI_USER_INTERRUPT                                                                                                                                                    |       |                                                     |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------------------------------------|--|--|--|--|--|
| Project:                                                                                                                                                             | Dev   | SNB+ Length Bias: 1                                 |  |  |  |  |  |
| Engine:                                                                                                                                                              | Blit  | ter                                                 |  |  |  |  |  |
| The MI_USER_INTERRUPT command is used to generate a User Interrupt condition. The parser will<br>continue parsing after processing this command. See User Interrupt. |       |                                                     |  |  |  |  |  |
| DWord                                                                                                                                                                | Bit   | Description                                         |  |  |  |  |  |
| 0                                                                                                                                                                    | 31:29 | Command Type                                        |  |  |  |  |  |
|                                                                                                                                                                      |       | Default Value: 0h MI_COMMAND Format: OpCode         |  |  |  |  |  |
|                                                                                                                                                                      | 28:23 | MI Command Opcode                                   |  |  |  |  |  |
|                                                                                                                                                                      |       | Default Value: 02h MI_USER_INTERRUPT Format: OpCode |  |  |  |  |  |
|                                                                                                                                                                      | 22:0  | Reserved Project: All Format: MBZ                   |  |  |  |  |  |

### 2.2.16 MI\_WAIT\_FOR\_EVENT [DevSNB]

| MI_WAIT_FOR_EVENT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |                       |                    |           |       |         |        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------|--------------------|-----------|-------|---------|--------|
| Project:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | [D    | evSNB] Length Bias: 1 |                    |           |       |         |        |
| Engine:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | BI    | itter                 |                    |           |       |         |        |
| The MI_WAIT_FOR_EVENT command is used to pause command stream processing until a specific event occurs or while a specific condition exists. See Wait Events/Conditions, Device Programming Interface in <i>MI Functions</i> . Only one event/condition can be specified specifying multiple events is UNDEFINED.<br>The effect of the wait operation depends on the source of the command. If executed from a batch buffer, the parser will halt (and suspend command arbitration) until the event/condition occurs. If executed from a ring buffer, further processing of that ring will be suspended, although command arbitration (from other rings) will continue. Note that if a specified condition does not exist (the condition code is inactive) at the time the parser executes this command, the parser proceeds, treating this command as a no-operation.<br>If execution of this command from a primary ring buffer causes a wait to occur, the active ring buffer will <i>effectively</i> give up the remainder of its time slice (required in order to enable arbitration from other primary ring buffers). |       |                       |                    |           |       |         |        |
| DWord                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Bit   |                       |                    | Descrip   | otion |         |        |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 31:29 | Command Type          |                    |           |       |         |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       | Default Value: 0h     | MI_COMM            | IAND      |       | Format: | OpCode |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 28:23 | MI Command Opcode     |                    |           |       |         |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       | Default Value: 03ł    | n <u>MI_WAIT</u> _ | FOR_EVENT |       | Format: | OpCode |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 22:20 | Reserved Proje        | ct: All            | Format: N | IBZ   |         |        |

1



| MI_WAIT_FOR_EVENT |                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                     |              |                                                                |          |  |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------------------------------------------|----------|--|--|--|
|                   | 19:16                                                                                                                                                                                                                                                 | Condition Code Wait Select                                                                                                                                                                                                                                          |              |                                                                |          |  |  |  |
|                   | Project: All                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                     |              |                                                                |          |  |  |  |
|                   | This field enables a wait for the duration that the corresponding condition code is active.<br>These enable select one of 15 condition codes in the EXCC register, that cause the<br>parser to wait until that condition-code in the EXCC is cleared. |                                                                                                                                                                                                                                                                     |              |                                                                |          |  |  |  |
|                   | Value Name Description Project                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                     |              |                                                                |          |  |  |  |
|                   |                                                                                                                                                                                                                                                       | 0h                                                                                                                                                                                                                                                                  | Not enabled  | Condition Code Wait Not Enabled                                | All      |  |  |  |
|                   |                                                                                                                                                                                                                                                       | 1h-5h                                                                                                                                                                                                                                                               | Enable       | Condition Code select enabled; selects one of 5 codes, $0 - 4$ | All      |  |  |  |
|                   |                                                                                                                                                                                                                                                       | 6h-15h                                                                                                                                                                                                                                                              | Reserved     |                                                                | All      |  |  |  |
|                   | Programming Notes                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                     |              |                                                                |          |  |  |  |
|                   |                                                                                                                                                                                                                                                       | Note that not all condition codes are implemented. The parser operation is UNDEFINED if an unimplemented condition code is selected by this field. The description of the EXCC register ( <i>Memory Interface Registers</i> ) lists the codes that are implemented. |              |                                                                |          |  |  |  |
|                   | 15:0                                                                                                                                                                                                                                                  | Reserve                                                                                                                                                                                                                                                             | d Project: A | ll Forn                                                        | nat: MBZ |  |  |  |

### 2.2.17 MSG\_LOAD\_SL – Load Scan Lines Message

| MSG_LOAD_SL—Load Scan Lines Message                                                                                                                                                                                                                                                                                                                                               |                                                  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--|--|--|--|--|--|
| Register Type:                                                                                                                                                                                                                                                                                                                                                                    | Inbound Message                                  |  |  |  |  |  |  |
| Address Offset: Pipe A: 50020h                                                                                                                                                                                                                                                                                                                                                    |                                                  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                   | Pipe B: 50028h                                   |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                   | Pipe C: 5002Ch                                   |  |  |  |  |  |  |
| Project:                                                                                                                                                                                                                                                                                                                                                                          | All                                              |  |  |  |  |  |  |
| Access:                                                                                                                                                                                                                                                                                                                                                                           | Sent from PG to North Display on Primary Channel |  |  |  |  |  |  |
| Size (in bits):                                                                                                                                                                                                                                                                                                                                                                   | 32                                               |  |  |  |  |  |  |
| This message is used to initiate a display scan line compare.                                                                                                                                                                                                                                                                                                                     |                                                  |  |  |  |  |  |  |
| When this message is received with the Init_Compare bit set to 1b, the Display Engine (DE) will start comparing the display pipe timing generator current scan line value (current scan line) with the start scan line value (current scan line) with the start scan line value (current scan line >= start scan line) and the end scan line value (current scan line <= end scan |                                                  |  |  |  |  |  |  |

line value (current scan line >= start scan line) and the end scan line value (current scan line <= end scan line) to decide if the the pipe scan line is inside or outside the scan line window of interest. DE will wait until the current scan line is either outside (Inclusive mode) or inside (Exclusive mode) the scan line window, then trigger a scan line event and stop any further comparing.

The scan line event can cause display to send a scan line compare response to the render command streamer, used for releasing a MI\_WAIT\_FOR\_EVENT on scan line window, if unmasked in the DERRMR mask register 0x44050. The scan line event can also cause display to generate a scan line compare interrupt, if unmasked and enabled in the DEIMR and DEIER display engine interrupt registers.

The end scan line value must be greater than or equal to the start scan line value.

The value programmed should be the desired value – 1, so for scan line 0, the value programmed is vertical



### MSG\_LOAD\_SL—Load Scan Lines Message

total, and for scan line 1, the value programmed is 0.

In interlaced display timings, the current scan line is the the current line of the current interlaced field.

#### Notes for command streamer programming:

• Either MMIO or a MI\_LOAD\_REGISTER\_IMM command can be used to unmask the scan line render response 0x44050.

| Bit   | Description                                                                                                                                                                                                                 |                           |                                                                           |         |  |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|---------------------------------------------------------------------------|---------|--|--|--|
| 31    | Initiate_Compare                                                                                                                                                                                                            |                           |                                                                           |         |  |  |  |
|       | Default V                                                                                                                                                                                                                   | Value: 0b                 |                                                                           |         |  |  |  |
|       | This field                                                                                                                                                                                                                  | initiates the scan        | line compare.                                                             |         |  |  |  |
|       |                                                                                                                                                                                                                             |                           | ived with this bit set to 1b, the display engine will do one complete     | e       |  |  |  |
|       | -                                                                                                                                                                                                                           |                           | scan line event, then stop comparing.                                     |         |  |  |  |
|       | A compa                                                                                                                                                                                                                     | re can <u>not</u> be can  | celled by writing with this bit set to 0b.                                |         |  |  |  |
|       | Value                                                                                                                                                                                                                       | Name                      | Description                                                               | Project |  |  |  |
|       | 0b                                                                                                                                                                                                                          | Do nothing                | Do nothing                                                                | All     |  |  |  |
|       | 1b                                                                                                                                                                                                                          | Initiate                  | Initiate the scan line compare.                                           | All     |  |  |  |
| 30    | Inclusive                                                                                                                                                                                                                   |                           | ect                                                                       |         |  |  |  |
|       | Default V                                                                                                                                                                                                                   | alue: (                   | Db                                                                        |         |  |  |  |
|       | This field selects whether the scan line compare is done in inclusive mode, where display triggers the scan line event when outside the scan line window, or inclusive mode, where display triggers when inside the window. |                           |                                                                           |         |  |  |  |
|       |                                                                                                                                                                                                                             |                           |                                                                           |         |  |  |  |
|       | Value                                                                                                                                                                                                                       | Name                      | Description                                                               | Project |  |  |  |
|       | 0b                                                                                                                                                                                                                          | Exclusive                 | Exclusive mode: trigger scan line event when inside the scan line window  | All     |  |  |  |
|       | 1b                                                                                                                                                                                                                          | Inclusive                 | Inclusive mode: trigger scan line event when outside the scan line window | All     |  |  |  |
| 29    | Reserve                                                                                                                                                                                                                     | rved Project: All Format: |                                                                           |         |  |  |  |
| 28:16 | Start_Scan_Line Project: All Format:                                                                                                                                                                                        |                           |                                                                           |         |  |  |  |
|       | This field specifies the starting scan line number of the scan line window.                                                                                                                                                 |                           |                                                                           |         |  |  |  |
| 15    | Load_Source                                                                                                                                                                                                                 |                           |                                                                           |         |  |  |  |
|       | Project: All                                                                                                                                                                                                                |                           |                                                                           |         |  |  |  |
|       | Default Value: 0b                                                                                                                                                                                                           |                           |                                                                           |         |  |  |  |
|       | This bit indicates if the source of the load scan lines is CS or BCS so display can send the scan line event to the appropriate destination.                                                                                |                           |                                                                           |         |  |  |  |
|       | Value                                                                                                                                                                                                                       | Name                      | Description                                                               | Project |  |  |  |
|       | 0b                                                                                                                                                                                                                          | CS                        | Source is CS                                                              | All     |  |  |  |
|       | 1b                                                                                                                                                                                                                          | BCS                       | Source is BCS                                                             | All     |  |  |  |



| MSG_LOAD_SL—Load Scan Lines Message |                                                                           |          |     |          |      |         |
|-------------------------------------|---------------------------------------------------------------------------|----------|-----|----------|------|---------|
| 14:13                               | Reserved                                                                  | Project: | All |          | Form | at:     |
| 12:0                                | End_Scan_L                                                                | ine      |     | Project: | All  | Format: |
|                                     | This field specifies the ending scan line number of the scan line window. |          |     |          |      |         |



# **Revision History**

| Revision<br>Number | Description                   | Date     |
|--------------------|-------------------------------|----------|
| 1.0                | First 2011 OpenSource edition | May 2011 |
|                    |                               |          |

