

# Intel<sup>®</sup> Open Source HD Graphics, Intel Iris<sup>™</sup> Graphics, and Intel Iris<sup>™</sup> Pro Graphics

**Programmer's Reference Manual** 

For the 2015 - 2016 Intel Core<sup>™</sup> Processors, Celeron<sup>™</sup> Processors, and Pentium<sup>™</sup> Processors based on the "Skylake" Platform

Volume 16: Workarounds

May 2016, Revision 1.0



## **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.

## **Notices and Disclaimers**

INFORMATION IN THIS DOCUMENT IS PROVIDED IN CONNECTION WITH INTEL® 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.

A "Mission Critical Application" is any application in which failure of the Intel Product could result, directly or indirectly, in personal injury or death. SHOULD YOU PURCHASE OR USE INTEL'S PRODUCTS FOR ANY SUCH MISSION CRITICAL APPLICATION, YOU SHALL INDEMNIFY AND HOLD INTEL AND ITS SUBSIDIARIES, SUBCONTRACTORS AND AFFILIATES, AND THE DIRECTORS, OFFICERS, AND EMPLOYEES OF EACH, HARMLESS AGAINST ALL CLAIMS COSTS, DAMAGES, AND EXPENSES AND REASONABLE ATTORNEYS' FEES ARISING OUT OF, DIRECTLY OR INDIRECTLY, ANY CLAIM OF PRODUCT LIABILITY, PERSONAL INJURY, OR DEATH ARISING IN ANY WAY OUT OF SUCH MISSION CRITICAL APPLICATION, WHETHER OR NOT INTEL OR ITS SUBCONTRACTOR WAS NEGLIGENT IN THE DESIGN, MANUFACTURE, OR WARNING OF THE INTEL PRODUCT OR ANY OF ITS PARTS.

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 information here is subject to change without notice. Do not finalize a design with this information.

The products described in this document 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.

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 © 2016, Intel Corporation. All rights reserved.** 



## **Table of Contents**

Workarounds......1

# Workarounds

This table lists all SKL workarounds. Note that the functional area for each item is listed below, and you can search on this value or other content on this page using search (e.g. Ctrl-F).

| BSpec<br>ID | Functional<br>Area/Component | Workaround Name                                        | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Valid Steppings                                                                                       |
|-------------|------------------------------|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| 0210        | 3D                           | WaDisable MidObject Preemption For GSLine Strip<br>Adj | This is a bug in GS. GS expected vertex<br>count doesn't decode<br>linestrip_adj_cont nor polygon_cont.<br>Only linestrip_adj_cont since polygon<br>is not pre-empted.<br>WA: Disable mid-draw preemption<br>when draw-call is a linestrip_adj and<br>GS is enabled.                                                                                                                                                                                                                            | SIWA_FOREVER (all<br>SKUs/ steppings for<br>applicable projects - no<br>HW workaround<br>planned)     |
| 0233        | 3D                           | WaForceMinMaxGSThreadCount                             | GS being stalled can cause the fftid to<br>go over max threads causing<br>undefined scratch space to be used.<br>WA: Limit the number of handles to<br>the number of threads, with some GS<br>performance loss. Set min/max threads<br>to 8 for GS. Should be handled in<br>USC/IGC.                                                                                                                                                                                                            | SIWA_FOREVER (Means<br>this applies to all<br>SKUs/steppings for SKL-<br>no HW fix is planned)        |
| 0234        | 3D                           | WaGrfScoreboardClearInGpgpuContextSave                 | Need to use stop_done pulse to clear<br>grf scoreboard on save. Logic exists to<br>restore grf scoreboard based on MDE<br>data being restored to MEU.<br>WA: Software workaround in SIP:<br>State register special handling against<br>page fault issue; change is requested<br>by EU team. In Context save sr0.1<br>register is stored in temporary register,<br>temporary register is masked and sent<br>to csr buffer, next sr0.1 is cleared. In<br>context restore sr0.1 is restored as one | SKL SIWA_FOREVER (all<br>SKUs/ steppings for<br>applicable projects - no<br>HW workaround<br>planned) |







| BSpec<br>ID |    | nctional<br>Component                    | Workaround Name                     | Workaround Description                                                                                                                                                                                                                | Valid Steppings                                                                                   |
|-------------|----|------------------------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
|             |    |                                          |                                     | of the last registers (just before r0 restore and exception clear).                                                                                                                                                                   |                                                                                                   |
| 0236        | 3D |                                          | WaAdditionalMovWhenSrc1ModOnMulMach | A source modifier must not be used<br>on src1 for the mul/mach macro<br>operations.<br>WA: Use extra move instead of src<br>modifier for src1.                                                                                        | All                                                                                               |
| 0237        | 3D |                                          | WaRestoreFC4RegisterDW0fromDW1      | GfxSV - [MDT] - GPGPU Pre-emption -<br>Execution Mask not being<br>saved/restored correctly (memdiff).<br>WA: SIP routine has to correct the<br>address while restoring. Flow control<br>register FC4 has to be restored from<br>DW1. | SIWA_FOREVER (all<br>SKUs/ steppings for<br>applicable projects - no<br>HW workaround<br>planned) |
| 0238        | 3D |                                          | WaScalarAtomic                      | This is a performance improvement<br>implemented as a W/A. Improves<br>append counter updates from 1/6 clks<br>(L3 limit) to 16/6 clks.                                                                                               | SIWA_FOREVER                                                                                      |
| 0240        | 3D | Media State<br>and Primitive<br>Commands |                                     | Two MEDIA_STATE_FLUSH commands need to be used to ensure that the flush is complete.                                                                                                                                                  | All                                                                                               |
| 0241        | 3D | Extended Math<br>Function                |                                     | When both srcs are NAN, FDIV produces denorminator NAN as output.                                                                                                                                                                     | All                                                                                               |
| 0242        | 3D |                                          | WaThreadSwitchAfterCall             | [MDT}GfxSV - GPGPU Pre-emption -<br>CALL Inst ruction Hang.<br>WA: Follow every call by a dummy<br>non-JEU and non-send instruction with<br>a SWITCH for both cases whether a<br>subroutine is taken or not.                          | SIWA_FOREVER (all<br>SKUs/ steppings for<br>applicable projects - no<br>HW workaround<br>planned) |

| W | orka | rou | nds  |
|---|------|-----|------|
|   | UIKa | 10u | IIGS |

| BSpec |         | ctional                                |                         |                                                                                                                                                                                                                                                                                                                             |                                                                                                |
|-------|---------|----------------------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| ID    | Area/Co | omponent                               | Workaround Name         | Workaround Description                                                                                                                                                                                                                                                                                                      | Valid Steppings                                                                                |
| 0243  |         | MEDIA_STATE_<br>FLUSH                  |                         | A MEDIA_STATE_FLUSH with no<br>options must be added after a<br>GPGPU_WALKER command which<br>doesn't use either SLM or barriers.                                                                                                                                                                                           | All                                                                                            |
| 0244  | 3D      |                                        | WaNearestFilterLODClamp | <pre>DX10.1 LOD clamping VS Max LOD DX case. Workarounds: DX: If ( mipfilter_nearest )     MaxLOD = floor(MaxLOD)     MinLOD = floor(MinLOD) OGL: If ( mipfilter_nearest )     lodbiad = lodbiad - 0.00001b Dx9 - (Not Required for Dx9. Max always set to to 14.0) Mac - Should not be needed - but needs follow up.</pre> | SIWA_FOREVER (Means<br>this applies to all<br>SKUs/steppings for SKL-<br>no HW fix is planned) |
| 0245  | S       | GPGPU Context<br>Switch<br>Workarounds |                         | After either a MI_SET_CONTEXT or a<br>PIPE_CONTROL with Generic Media<br>State Clear, there must be a<br>MEDIA_VFE_STATE command before<br>any pre-emptable command. The<br>parameter of this MEDIA_VFE_STATE<br>command can be set to default values.                                                                      | All                                                                                            |







| BSpec<br>ID |    | nctional<br>Component                                  | Workaround Name                    | Workaround Description                                                                                                                             | Valid Steppings |
|-------------|----|--------------------------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 0248        | 3D | 3D Sampler<br>Message Types                            |                                    | If Surface Format is<br>R10G10B10_SNORM_A2_UNORM and<br>Gather4 Source Channel Select is alpha<br>channel, the returned value may be<br>incorrect. | SKL             |
| 0249        | 3D | Programming<br>Media Pipeline<br>- Command<br>Sequence |                                    | A MEDIA_STATE_FLUSH needs to be<br>placed right before the<br>MI_BATCH_BUFFER_END of any batch<br>buffer that uses MEDIA_OBJECT.                   | SKL             |
| 0257        | 3D |                                                        | WaCallForcesThreadSwitch           | RTL TC: (Tracking) Dependency is not<br>set for call instruction.<br>WA: Call instructions must have<br>Thread switch bit set.                     | All             |
| 0261        | 3D |                                                        | WaClearFlowControlGpgpuContextSave | Stack entry valid will no t be reset<br>during ctxsave.<br>WA: Set the value to 0 through<br>restore SIP.                                          | All             |
| 0262        | 3D |                                                        | WaClearArfDependenciesBeforeEot    | GFXDRV [B0] - BattleForge3 hang -<br>flag register dependency not cleared<br>after EOT.<br>WA: Source ARF registers before EOT.                    | All             |
| 0263        | 3D |                                                        | WaClearCr0SpfInGpgpuContextRestore | GfxSV - GPGPU Pre-emption -<br>Corruption on context restore.<br>WA: To reset SPF bit through SIP<br>during restore.                               | All             |
| 0265        | 3D |                                                        | WaDisableNoSrcDepSetBeforeEOTSend  | GFXDRV: [MDT] WGF11Compute UAV<br>hang.<br>WA: The send or sends before the<br>EOT should not have the NoSrcDepSet<br>bit set.                     | All             |



| BSpec<br>ID |    | nctional<br>Component                      | Workaround Name                                      | Workaround Description                                                                                                                                                                                                                                                                                                                                            | Valid Steppings |
|-------------|----|--------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 0266        | 3D |                                            | WaClearNotificationRegInGpgpuContextSave             | GFXSV GPGPU: GPG PU Pre-emption<br>test hang 4.<br>WA: In SIP, move zeroes into notify<br>count registers.                                                                                                                                                                                                                                                        | All             |
| 0268        | 3D |                                            | WaL3UseSamplerForVectorLoadScatter                   | WA: Use sampler for vector load.                                                                                                                                                                                                                                                                                                                                  | All             |
| 0270        | 3D |                                            | Walnteger Division Source Modifier Not Supporte<br>d | Both Fulsim and RTL do not apply src<br>mod for integer divide - BSPEC needs<br>update.<br>WA: Src mods cannot be used for<br>integer divide math ints.                                                                                                                                                                                                           | All             |
| 0272        | 3D |                                            | WaDoNotPushConstantsForAllPulledGSTopolog<br>ies     | SKL GFXDRV: GS Patchlist_14 and<br>above in PULL Model - Cannot push<br>constants. When Include Vertex<br>Handles is set for non-instanced<br>SIMD8 dispatch of PATCHLIST_1432<br>objects, pushed vertex data and/or<br>pushed constants cannot be used as<br>they would need to start in the<br>payload beyond the range of this field<br>(that is, beyond R15). | All             |
| 0275        | 3D | Addressing 1D,<br>2D, 3D, CUBE<br>Surfaces |                                                      | If the surface state indicates the<br>Number of Multisamples > 1, then the<br>LOD parameter is not optional: the R<br>and LOD parameters must be specified<br>along with the MSAA sample number<br>parameter.                                                                                                                                                     | All             |
| 0278        | 3D |                                            | WaZeroOneClearValuesMSAA                             | Precision issue with non 0/1 clears for<br>MSAA.<br>WA: For SKL, disable non 0/1 clears<br>for any MSAA surface.                                                                                                                                                                                                                                                  | All             |



| BSpec<br>ID | _  | nctional<br>Component                                    | Workaround Name                               | Workaround Description                                                                                                                                                                       | Valid Steppings                                          |
|-------------|----|----------------------------------------------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| 0279        | 3D |                                                          | WaZeroOneClearValuesAtSampler                 | Precision match fix for Non-0/1 Clear<br>color [ S/W H/W Bypass codesign ]<br>WA: SKL clear values other than 0/1<br>need resolve pass before being<br>sampled. This is a BSPEC Restriction. | SIWA_FROM_B0 (all<br>SKUs/steppings starting<br>with B0) |
| 0280        | 3D | MSAA Typed<br>Surface<br>ReadWrite<br>Messages [SKL<br>] |                                               | The SIMD4x2 MSAA Read message<br>may not correctly handle out-of-range<br>sample numbers on the second slot.<br>Software workaround is use the SIMD8<br>version of the message.              | All                                                      |
| 0282        | 3D |                                                          | WaOCLEnableFMaxFMinPlusZero                   | FMIN/FMAX behavior dependent on denormal bit.                                                                                                                                                | All                                                      |
| 0283        | 3D |                                                          | WaVFComponentPackingRequiresEnabledCom ponent | GFXDRV: StreamOut hangs with VF,<br>VS, and CS not done.                                                                                                                                     | All                                                      |
| 0284        | 3D | QWord<br>Untyped<br>Atomic Integer<br>Messages           |                                               | AOP CMPWR_2W is not supported in<br>A64 SIMD4x2 DWord operations. Use<br>the A64 SIMD8 DWord operation as a<br>workaround.                                                                   | All                                                      |
| 0285        | 3D | OWord<br>Untyped<br>Atomic Integer<br>Messages           |                                               | AOP_CMPWR_2W is not supported on<br>A64 Qword SIMD4x2 or SIMD8.                                                                                                                              | All                                                      |
| 0286        | 3D |                                                          | WaSet Tri Linear Filter For LOD Preclamp      | FPF: OGL LOD rounding when LOD<br>calculated is 0.5.<br>WA: S/W w/a in place; no BSpec<br>update is required.                                                                                | All                                                      |

| BSpec |        |                                        |                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |
|-------|--------|----------------------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| ID    | Area/Q | Component                              | Workaround Name         | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Valid Steppings |
| 0287  | 3D     |                                        |                         | GS issue with inputvtxramout read ptr<br>in trail mode Issue is in Trail mode -<br>RD pointers getting corrupted. SW WA<br>exists; need confirmation if it is<br>acceptable for SKL CO.<br>WA: Reorder mode bit in 3DSTATE_GS<br>should be always leading. Dx10 does<br>this by default and is only API with GS.                                                                                                                                                                                                                                                        | All             |
| 0289  | 3D     |                                        | WaDisable1DDepthStencil | Common tiler: Linear tiling Support for<br>STC Decision made to not support<br>Linear STC for A0 SKLGFX<br>WA: Fix is to change 1D depth/stencil<br>to 2D with height of 1. B0 Candidate:<br>[64KB Tiling] 1d Surfaces illegal for<br>depth and stencil buffers on SKL A0<br>WA: WA on SKL to disable 1D Depth<br>Stencil buffers and use 2D with ht of 1<br>instead.                                                                                                                                                                                                   | All             |
| 0290  | 3D     | GPGPU Context<br>Switch<br>Workarounds |                         | HW does not support pre-empting<br>implicit flushes triggered by Render CS<br>on parsing non-pipeline state<br>commands. When a pending execlist<br>gets submitted during an ongoing<br>implicit flush on parsing a non-<br>pipeline state command, HW will wait<br>for the completion of implicit flush and<br>to encounter a pre-emptable<br>command before accepting the new<br>pending execlist. This leads to<br>increased pre-emption latencies<br>compared to when pending execlist is<br>submitted when a pre-emptable<br>command is being executed. This issue | All             |







| BSpec<br>ID |    | nctional<br>Component                         | Workaround Name | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Valid Steppings |
|-------------|----|-----------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|             |    |                                               |                 | is unique to GPGPU workloads where<br>mid thread pre-emption is supported<br>and does not apply for 3D workloads.<br>Note: To circumvent this issue SW<br>must always program PIPE_CONTROL<br>with "CS Stall" and "Render Target<br>Cache Flush Enable" set prior to<br>programming the following<br>commands for GPGPU workloads (that<br>is, when pipeline select is GPGPU via<br>PIPELINE_SELECT command).<br>STATE_BASE_ADDRESS,<br>GPGPU_CSR_BASE_ADDRESS,<br>PIPELINE_SELECT |                 |
| 0292        | 3D | Notification<br>Registers                     |                 | Write operation is allowed in normal operation and is not restricted to context restore.                                                                                                                                                                                                                                                                                                                                                                                           | All             |
| 0294        | 3D | 3D Sampler<br>Messages -<br>Message<br>Format |                 | When 16-bit return format is used,<br>SIMD16 messages should always be<br>used with a header.                                                                                                                                                                                                                                                                                                                                                                                      | SKL,            |
| 0301        | 3D | State Register                                |                 | WA: These bits will have undefined<br>value if a previously saved GPGPU<br>context is restored for execution. All<br>new contexts will have these bits<br>initialized to zero.<br>Bits Definition<br>[6:5] Reserved<br>4 Inexact Exception<br>3 Overflow<br>2 Underflow<br>1 Divide by Zero                                                                                                                                                                                        | All             |



| BSpec<br>ID |         | Inctional<br>Component    | Workaround Name        | Workaround Description                                                                                                                                                                                                                                                                                                                                | Valid Steppings |
|-------------|---------|---------------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|             |         |                           |                        | 0 Invalid Operation                                                                                                                                                                                                                                                                                                                                   |                 |
| 0308        | Blitter |                           |                        | No Blitter workarounds have been submitted for SKL.                                                                                                                                                                                                                                                                                                   | ALL             |
| 0342        | Display | DisplayPort               |                        | DP MST output incorrect for certain M<br>and N and VC payload size values.<br>WA: VC payload must be multiple of 4<br>in x1 lane config, 2 in x2, 1 in x4. See<br>M/N Values.                                                                                                                                                                         | All             |
| 0347        | Display | DisplayPort               |                        | Aux channel transactions get<br>intermittent NAK errors with some<br>receivers.<br>WA: Increase DDI_AUX_CTL bits 27:26<br>Time out timer value to 600us 01b<br>when doing DDI aux transactions.                                                                                                                                                       | All             |
| 0371        | Display | Panel fitter              | WaPanelFitterDownscale | Not a bug, but good to know. When<br>using panel fitter downscaling (pipe<br>source size is larger than panel fitter<br>window size) the maximum supported<br>pixel rate will be reduced by the<br>downscale amount, and watermarks<br>must be adjusted. Use panel fitter<br>scale amount when calculating<br>maximum pixel rate and watermarks.      | All             |
| 0373        | Display | Panel power<br>sequencing | WaVDDOverrideT4Power   | When software clears the panel power<br>sequencing VDD override bit from 1 to<br>0 (disable VDD override) it must<br>ensure that T4 power cycle delay is<br>met before setting the bit to 1 again,<br>else panel ma y be damaged.<br>WA: Use software timers to ensure T4<br>delay is met or use full panel power<br>enable and not the VDD override. | All             |





| <b>BSpec</b> |                 | Inctional                     |                  |                                                                                                                                                                                                          |                 |
|--------------|-----------------|-------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| ID           | Area/           | Component                     | Workaround Name  | Workaround Description                                                                                                                                                                                   | Valid Steppings |
| 0386         | Display         | PSR                           |                  | PSR single frame update - When single<br>frame update is enabled, the PSR CRC<br>must be disabled for panel<br>compatibility. See North Display<br>Engine Registers SRD_CTL register for<br>details.     | All             |
| 0387         | Display         | PSR                           |                  | PSR single frame update - Mask<br>register write events when using single<br>frame update. See North Display<br>Engine Registers SRD_CTL register for<br>details.                                        | All             |
| 0388         | Display         | PSR                           |                  | PSR power saving - Mask PSR max<br>timeout when PSR CRC is enabled. See<br>North Display Engine Registers,<br>SRD_CTL register for details.                                                              | All             |
| 0456         | Memory<br>Views | Planar Memory<br>Organization |                  | The offset for the start of the U and V<br>plane must be a multiple of 4 cache-<br>lines except YUV_PLANAR_* surface<br>formats.                                                                         | All             |
| 0457         | Memory<br>Views | Planar Memory<br>Organization |                  | When using Planar formats for YUV<br>with half-pitch chroma planes (for<br>example, YV12), fenced tiling is not<br>supported.                                                                            | All             |
| 0517         | 3D              | Depth Buffer                  | DepthBufferR2T8x | WA: Depth surface aligned to 128<br>bytes and pitch a multiple of 256<br>byteswhen samples == 16                                                                                                         | SKL All         |
| 0527         | Display         | Power                         |                  | MMIO accesses to 0x8Fxxx registers<br>are not allowed when DC5/DC6 power<br>states are enabled.<br>Disable DC5/DC6 during mode set<br>and re-enable them after the mode set<br>programming is completed. | All             |



| BSpec<br>ID |         | nctional<br>Component | Workaround Name | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Valid Steppings |
|-------------|---------|-----------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|             |         |                       |                 | For optimal performance, disable<br>DC5/DC6 when programming a set of<br>registers and re-enable them after the<br>programming is completed. MMIO<br>accesses have more latency when<br>DC5/DC6 is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | tuid Steppings  |
| 0529        | Display | FBC                   |                 | Corruption in some cases when FBC is<br>enabled and the plane surface format<br>is in linear, tile Y legacy or tile Yf<br>WA: Display register 4208Ch bit 13<br>must be set to 1b and bits 12:0 must<br>be programmed with the compressed<br>buffer stride value.<br>The compressed buffer stride must be<br>calculated using the following<br>equation: Compressed buffer stride =<br>ceiling [(at least plane width in pixels) /<br>(32 * compression limit factor)] * 8<br>At least plane width = a value greater<br>than or equal to the width of the<br>plane. Software may choose to use a<br>greater value in order to handle cases<br>where the plane width is changing<br>from frame to frame.<br>Compression limit factor is either 1, 2<br>or 4 based on the Compression Limit<br>field. If the limit is 2:1, the compression<br>limit factor to be used is 2. Ceiling<br>function rounds up any non-integer<br>value to next greater number. Example<br>ceiling [0.3] = 1, ceiling[2.1] = 3,<br>ceiling[4.8] = 5, ceiling[4] = 4. | ALL             |



| BSpec |         | Inctional                             |                                      |                                                                                                                                                                                                                                                                                                                                                                          |                   |
|-------|---------|---------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| ID    | Area/   | Component                             | Workaround Name                      | Workaround Description                                                                                                                                                                                                                                                                                                                                                   | Valid Steppings   |
| 0530  | Display | Render<br>Compression,<br>Async Flips |                                      | When render decompression is<br>enabled, hardware internally converts<br>the Async flips to Sync flips<br>WA: Do not enable render<br>decompression when Async flips are<br>enabled.                                                                                                                                                                                     | All               |
| 0531  | Display | Render<br>Compression                 |                                      | Render decompression is broken when<br>plane widths greater than 3840 are<br>used with horizontal panning.<br>WA: When the render compression is<br>enabled with plane width greater than<br>3840 and horizontal panning (Start X<br>Position in the PLANE_OFFSET register<br>is not 0), the stride programmed in the<br>PLANE_STRIDE register must be<br>multiple of 4. | All               |
| 0540  | KMD     |                                       | WaForceContextSaveRestoreNonCoherent | To avoid a potential hang condition<br>with TLB invalidation driver should<br>enable masked bit 5 of MMIO 0x7300<br>at boot.                                                                                                                                                                                                                                             | SIWA_FOREVER      |
| 0551  | KMD     |                                       | WaDisableMidThreadPreempt            | Disable GPGPU thread-level (a.k.a.<br>mid-thread) preemption on parts (until<br>B0) since validation was minimal on<br>those parts.                                                                                                                                                                                                                                      | SKL: SIWA_FOREVER |
| 0556  | KMD     |                                       | Wa4x4STCOptimizationDisable          | HIZ/STC hang in hawx frames.<br>W/A: Disable 4x4 RCPFE-STC<br>optimization and therefore only send<br>one valid 4x4 to STC on 4x4 interface.<br>This will require setting bit 6 of reg.<br>0x7004. Must be done at boot and all<br>save/restore paths.                                                                                                                   | SIWA_FOREVER      |

| Workarounds |
|-------------|
|-------------|

| <b>BSpec</b> |       | nctional  |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                   |
|--------------|-------|-----------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| ID           | Area/ | Component | Workaround Name                            | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Valid Steppings   |
| 0562         | Power | FBC       |                                            | FBC sometimes causes screen<br>corruption.<br>WA: 'FBC Watermark Disable' bit in                                                                                                                                                                                                                                                                                                                                                                                                                         | SKL:ALL           |
|              |       |           |                                            | ARB_CTL register must be set to 1b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                   |
| 0572         | KMD   | RTL       | WaFlushCoherentL3CacheLinesAtContextSwitch | Coherent L3 cache lines are not<br>getting flushed during context switch<br>which is causing issues like corruption.<br>Need to set bit 21 of MMIO b118, then<br>send PC with DC flush and then reset<br>bit 21 of b118. This programming<br>sequence needs to be part of the<br>indirect context WA BB                                                                                                                                                                                                  | SIWA_FOREVER      |
| 0590         | KMD   |           | WaSkipInvalidSubmitsFromOS                 | For Invalid submits from OS - simply<br>report fence completion without<br>submitting the DMA buffer to GPU.                                                                                                                                                                                                                                                                                                                                                                                             | SIWA_FOREVER      |
| 0594         | 3D    |           |                                            | Tristrip- wrong provoking vertex<br>If there is an odd number of TRs in<br>the clipper, we have an issue in picking<br>the correct provoking vertex in SF. We<br>swap the vertices to right winding<br>order in clipper, and in SF we pick the<br>provoking vertex. If there is odd TRs in<br>clipper, these two go out of sync and<br>SF picks vtx1 instead of vtx2 and vice<br>versa.<br>WA: Using flip logic from clipper<br>instead of local flip logic to set the<br>provoking vertex for tristrip. | SKL:SIWA_UNTIL_H0 |







| BSpec<br>ID | Functional<br>Area/Component | Workaround Name | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Valid Steppings   |
|-------------|------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| 0596        | GT                           |                 | While CS deciding to do sync ctx<br>switch on semaphore wait lite restore<br>happens. As a result CS does lite<br>restore and skips the semaphore wait.<br>This happens only on a particular clock<br>if lite restore occurs during semaphore<br>wait.                                                                                                                                                                                                                                                                                                                                                                                                             | SKL:SIWA_UNTIL_H0 |
| 0598        | GTI                          |                 | An invalidation request comes from<br>GAMT to GAMD after an RCP request<br>for which an RCP\$ miss request was<br>already sent to memory. After this<br>there is another RCP request to RCP\$<br>which occupies the same cacheline.<br>WA: RCP Invalidation pulse will be<br>sent from GAMT only when the<br>corresponding atomic fence advances<br>from the TLB. Fix in one of the TLBs is<br>given below:<br>always_comb ctrl_rcp_mfx0_inv_nxt =<br>(reg_rcpinvalidate_atfncadv &<br>ctrl_wcp_flush_mfx0)  <br>(~reg_rcpinvalidate_atfncadv &<br>ctrl_rcp_mfx0_inv_i);<br>'GT_ASYNC_RSTB_MSFF(ctrl_rcp_mfx0_i<br>nv, ctrl_rcp_mfx0_inv_nxt, cuclk,<br>cdevrst_b) | SKL:SIWA_UNTIL_H0 |
| 0599        | GTI                          |                 | GA MMCD: in RCP cahce even if fine<br>miss resposne is not present , new<br>miss cycle evicts out this entry                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | SKL:SIWA_UNTIL_H0 |

| Wor | karou | nds   |
|-----|-------|-------|
|     |       | 11015 |

| BSpec | Fu      | nctional    |                 |                                                                                                                                                                                                                                                                                                                                                 |                   |
|-------|---------|-------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| ID    | Area/   | Component   | Workaround Name | Workaround Description                                                                                                                                                                                                                                                                                                                          | Valid Steppings   |
| 0601  | 3D      |             |                 | When there is a sequence of non-<br>media message followed by media<br>MMCD message in back to back clock<br>inside HDC pipeline, the non-media<br>message incorrectly gets the MMCD<br>values of the next message in pipeline.<br>This leads to memory corruption in<br>GAM.<br>WA: Muxed the mmcd values to 0<br>when the msg is a non-media. | SKL:SIWA_UNTIL_H0 |
| 0603  | GTI     |             |                 | Media: Decoder DN test hang with<br>MMCD bug Fix emulation model<br>WA: The test has virtual64 enabled<br>and the test passes without virtual64.                                                                                                                                                                                                | SKL:SIWA_UNTIL_I0 |
| 0622  | Blitter | Blitter FBC |                 | Incorrect MUX select in BLB to select<br>between Fast Copy and Legacy FBC<br>requests.<br>WA: Blitter FBC front buffer<br>modification tracking must not be<br>enabled (BCS_ECOSKPD bit[3] must<br>always be 0).                                                                                                                                | SKL:SIWA_FOREVER  |
|       |         |             |                 | <ul> <li>If using Front buffer rendering via BLT &amp; Display FBC compression feature is enabled, SW must follow the BLT commands that target the front buffer with:         <ul> <li>Flush</li> <li>LRI to 0x50380 with data 0x0000_0004 (This</li> </ul> </li> </ul>                                                                         |                   |





| BSpec<br>ID | Functional<br>Area/Component | Workaround Name                   | Workaround Description                                                                                                                                                                                                                                                                                                                                    | Valid Steppings  |
|-------------|------------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
|             |                              |                                   | recompress the entire<br>buffer after BLT<br>operation)                                                                                                                                                                                                                                                                                                   |                  |
| 0642        | 3D                           | WaClearCCStatePriorPipelineSelect | Architecture hole; on GPGPU context<br>restore, at the end of the context when<br>CS sends a null prim, SVG and SARB<br>does a state prefetch; by the time the<br>data returns from memory, CS gates<br>the FF clock.<br>WA: In GPGPU mode, color cal state<br>should not have valid bits. Before<br>switching pipelines, send null CC state<br>pointers. | SKL:SIWA_FOREVER |
| 0671        | 3D                           |                                   | DF> f format conversion for align16<br>has wrong emask calculation when the<br>source is immediate.<br>WA: In Align16 mode, format<br>conversion from double-float to floats<br>is not allowed when source is<br>immediate data.                                                                                                                          | SIWA_FOREVER     |
| 0673        | 3D                           | WaStallBeforePostSyncOpOnGPGPU    | Preemption mid-thread focused test<br>failures.<br>WA:<br>PIPECONTROL command with<br>"Command Streamer Stall Enable"must<br>be programmed prior to programming<br>MI_SEMAPHORE_SIGNAL command<br>with Post-Sync Operation set in<br>GPGPU mode of operation (i.e when<br>PIPELINE_SELECT command is set to                                               | SIWA_FOREVER     |

| Workarounds |
|-------------|
|-------------|

| BSpec<br>ID |    | tional<br>mponent | Workaround Name                                      | Workaround Description                                                                                                                                                                                                                                                | Valid Steppings |
|-------------|----|-------------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|             |    |                   |                                                      | GPGPU mode of operation).                                                                                                                                                                                                                                             |                 |
|             |    |                   |                                                      | PIPECONTROL command with<br>"Command Streamer Stall Enable" must<br>be programmed prior to programming<br>MI_ATOMIC command with Post-Sync<br>Operation set in GPGPU mode of<br>operation (i.e when PIPELINE_SELECT<br>command is set to GPGPU mode of<br>operation). |                 |
|             |    |                   |                                                      | PIPECONTROL command with<br>"Command Streamer Stall Enable" must<br>be programmed prior to programming<br>a PIPECONTROL command with Post<br>Sync Op in GPGPU mode of operation<br>(i.e when PIPELINE_SELECT command<br>is set to GPGPU mode of operation).           |                 |
| 0675        | 3D |                   | WaFlushBefore3DSTATEGS                               | GS_SIMD8_OTHANDLE_RELAX test<br>hanging due to an issue in gs_trg clock<br>gating logic.<br>WA: Add state_osb_statedv into<br>trg_cg equation.                                                                                                                        | SIWA_FOREVER    |
| 0677        | 3D |                   | WaDisableLosslessCompressionForSampleL               | Sampler Throughput drop with lossless<br>enabled for 0% & 50%, compression<br>tests with 100%bypass.<br>WA: Disabe double-fetch.                                                                                                                                      | SIWA_FOREVER    |
| 0678        | 3D |                   | WaDisableStencilBufferTestOnStencilBufferDisa<br>ble | MSAA test hangs with RCZ, IZ, WMFE<br>and SVL not done.<br>WA: Force the<br>3DSTATE_WM_DEPTH_STENCIL ::<br>Stencil Buffer Test Enable to 0 when<br>3DSTATE_STENCIL_BUFFER                                                                                             | SIWA_FOREVER    |







| BSpec<br>ID | Functional<br>Area/Component | Workaround Name                                      | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Valid Steppings |
|-------------|------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|             |                              |                                                      | ::STENCIL_BUFFER_ENABLE = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |
| 0680        | 3D                           | WaDisableSamplerL2BypassForTextureCompres sedFormats | RTL DM producing Xs for SC output.<br>WA: Disable Bypass on some of the<br>compressed formats.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | SIWA_FOREVER    |
| 0684        | 3D                           | WaDisableKillLogic                                   | System hang while using RC6 and HW<br>TRTT.<br>WA: Platform work stable with RC6<br>disabled or after switching to SW<br>TRTT.                                                                                                                                                                                                                                                                                                                                                                                                                                   | SIWA_FOREVER    |
| 0689        | 3D                           | WaPipeControlBeforeVFCacheInvalidationEnabl<br>e     | Vf randomly decodes nullprim packets<br>as state packets causing illegal internal<br>states in it.<br>WA: B2B control packets to be sent<br>when VS_cache_enable is programmed<br>to be enabled. First control packet with<br>bit11 as '0' and the next control packet<br>with bit11 as '1'.                                                                                                                                                                                                                                                                     | SIWA_FOREVER    |
| 0692        | 3D                           | WaKVMNotificationOnConfigChange                      | DPR currently sends a "decreg" signal<br>to DPCEUNIT for TRANS_CONF_EDP.<br>The signal is expected only to pulse<br>when a write on TRANS_CONF_EDP<br>has occurred, but the signal is actually<br>assigned to logic directly out of the<br>automated register code which is read<br>and write accesses.<br>This is resulting in repeated KVM<br>config changes being sent to ME in<br>silicon when using an EDP panel and<br>ultimately results in poor performance<br>and notable lag in mouse movements<br>when using EDP.<br>WA: Current workaround is to set | SIWA_FOREVER    |



| BSpec<br>ID |     | nctional<br>Component | Workaround Name                      | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Valid Steppings  |
|-------------|-----|-----------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
|             |     |                       |                                      | DPCE to be less aggressive with its config change checks.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                  |
| 0696        | 3D  |                       | WaBindlessSurfaceStateModifyEnable   | Missing "Size Modify Enable" Bit For<br>Bindless Sizes in<br>STATE_BASE_ADDRESS.<br>WA: The suggested WA is that when<br>NOT setting the modify enable bit for<br>Bindless Surface State Base Address,<br>program the dword length to<br>"Eh"instead of "11h"and zero out the<br>last 3 DW or not send them.                                                                                                                                                                                                                                                                                                                 | SIWA_FOREVER     |
| 0703        | GTI | L3                    | WaDisableL3ErrorDetectionHangOnError | <ul> <li>Model hang in wgf11shader5x<br/>store_raw tests.</li> <li>WA: Connected ~SVL[9] to LNCFUNIT<br/>Incf_csr_bank_hang_override which is<br/>then routed to LBCFUNIT.</li> <li>On SKL A0, Bit(9) must be set to<br/>zero (no hang on error) due to<br/>hw bug.</li> <li>On SKL B0 this bit can be set to<br/>either 0 or 1,setting the bit to<br/>one will ensure error data does<br/>not get propagated.</li> <li>For SKL A0, no driver<br/>programming is required. That<br/>means no hang on<br/>uncorrectable error. For SKLB0<br/>onwards, set BIT(9) of<br/>L3CNTLREG (0x7034h) for<br/>GPGPU context.</li> </ul> | SKL:SIWA_FROM_A0 |





| BSpec<br>ID |    | nctional<br>Component       | Workaround Name | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Valid Steppings                          |
|-------------|----|-----------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| 0707        | 3D |                             |                 | MMIO address for preemption<br>save/restore, barrier prog. need to be<br>fixed for GW, GWC and TDL.<br>WA: Fixed MMIO addresses for slice1<br>and slice2 signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | SKL:SIWA_FROM_C0                         |
| 0708        | 3D |                             |                 | Eutc generates wrong dst length for<br>simd16 call with source register offset<br>0.4<br>WA: Use SIMD16 and SIMD32 call<br>instruction with offset .0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | SKL:SIWA_FROM_B0                         |
| 0709        | 3D | Surface State<br>used by RT |                 | Failing to implement the following<br>WA, can cause Gfx device to hang<br>WA : Option 1 (exhaustive conditions<br>to limit performance impact of WA.<br>requires SW to check both surface<br>state and per draw call state<br>parameters)<br>When all the following conditions are<br>true for any render target:<br>[(SURFACE_STATE.SurfaceType ==<br>SURFTYPE_2D ) &<br>(SURFACE_STATE.SurfaceMinLOD < 2<br>or SURFACE_STATE.LOD < 2 ) &<br>(SURFACE_STATE.NumberOfMultisamp<br>les != MULTISAMPLECOUNT_16) &<br>(3DSTATE_PS_EXTRA.PixelShaderIsPerS<br>ample != 1) &<br>(SURFACE_STATE.SurfaceFormat != 64<br>bits/pixel) &<br>(SURFACE_STATE.SurfaceFormat !=<br>128 bits/pixel) & | SKL:GT2:ALL<br>SKL:GT3:SIWA_UNTIL_K<br>0 |



| BSpec | Functional     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |
|-------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| ID    | Area/Component | Workaround Name | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Valid Steppings |
|       |                |                 | (SURFACE_STATE.TileMode ==<br>XMAJOR or YMAJOR) &<br>((BLEND_STATE_ENTRY.LogicOpEnable<br>== 1) or<br>(BLEND_STATE_ENTRY.ColorBufferBlen<br>dEnable == 1) or<br>((SURFACE_STATE.SurfaceFormat has<br>non byte aligned channels &<br>(BLEND_STATE.WriteDisableAlpha ==<br>1) or (BLEND_STATE.WriteDisableAlpha ==<br>1) or (BLEND_STATE.WriteDisableRed<br>== 1) or<br>(BLEND_STATE.WriteDisableBlue == 1)<br>or (BLEND_STATE.WriteDisableBlue == 1)<br>or (BLEND_STATE.WriteDisableGreen<br>== 1)))) &<br>(SURFACE_STATE.renderTargetRotatio<br>n == 0DEG) & |                 |
|       |                |                 | (SURFACE_STATE.XOffset == 0)],<br>SW must set render targets'<br>SURFACE_STATE.AuxiliarySurfaceMode<br>to AUX_CCS or AUX_MCS. SW may set<br>CACHE_MODE_1.MCSCacheDisable if<br>all render targets do not support MCS                                                                                                                                                                                                                                                                                                                                         |                 |
|       |                |                 | Option 2 : The following simplified<br>version of the WA removes all per<br>draw call state from the list of<br>conditions and keeps only the surface<br>state parameters. This makes the WA<br>coarser and will likely have bigger<br>performance impact than option 1                                                                                                                                                                                                                                                                                      |                 |
|       |                |                 | When all the following conditions are<br>true for any render target:<br>[(SURFACE_STATE.SurfaceType ==                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |



| BSpec<br>ID | Functional<br>Area/Component | Workaround Name | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                          | Valid Steppings |
|-------------|------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|             |                              |                 | SURFTYPE_2D ) &<br>(SURFACE_STATE.SurfaceMinLOD < 2<br>or SURFACE_STATE.LOD < 2 ) &<br>(SURFACE_STATE.NumberOfMultisamp<br>les != MULTISAMPLECOUNT_16) &<br>(SURFACE_STATE.SurfaceFormat != 64<br>bits/pixel) &<br>(SURFACE_STATE.SurfaceFormat !=<br>128 bits/pixel) &<br>(SURFACE_STATE.TileMode ==<br>XMAJOR or YMAJOR) &<br>(SURFACE_STATE.renderTargetRotatio<br>n == 0DEG) &<br>(SURFACE_STATE.XOffset == 0)],<br>SW must |                 |
|             |                              |                 | set SURFACE_STATE.AuxiliarySurfaceM<br>ode to AUX_CCS or AUX_MCS. SW<br>needs to set<br>CACHE_MODE_1.MCSCacheDisable if<br>render target does not support MCS                                                                                                                                                                                                                                                                   |                 |
| 0711        | 3D                           |                 | While executing<br>MI_SEMAPHORE_SIGNAL command<br>from per ctx WA batch buffer after a<br>context switch - CS will not release<br>credits and can stall and hang in WA<br>batch execution.<br>WA: Not to put semaphore signal<br>command for per context WA batch<br>buffer.                                                                                                                                                    | SIWA_FOREVER    |



| BSpec<br>ID | Functional<br>Area/Component | Workaround Name | Workaround Description                                                                                                                                                                                                                                      | Valid Steppings   |
|-------------|------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| 0712        | 3D                           |                 | Byte Mask Media write have issue with<br>byte enable when block width is less<br>then 32.<br>WA: Restriction for A0 and B0 : byte<br>mask media message cannot be used.                                                                                     | SKL:SIWA_FROM_A0  |
| 0715        | 3D                           |                 | Dst dependency is getting cleared on<br>commit. It should be cleared on<br>writeback data.<br>WA: During HDC page fault mode,<br>destination and source overlap cannot<br>happen for send instruction.                                                      | SKL: SIWA_FROM_A0 |
| 0716        | Blitter                      |                 | When subblt is off: Ty->Ty single CL in<br>the y-direction<br>When subblt is on: Ty-Ty copy where a<br>subblt is created that is a single CL in<br>the y-direction<br>Under this case, Two CLs with the                                                     | SKL:SIWA_FROM_B0  |
|             |                              |                 | same address will be created. Sine the<br>signal one_cl doesn't assert causing<br>the walker to have it's "run" bit set.<br>"run" should not be set under this<br>case.<br>WA: Restriction on memory surface.                                               |                   |
| 0717        | GTI                          |                 | With the current implimentation, the<br>mask is applied on the allocated<br>entries in TLB, but not on the look up<br>address. This will cause issues becasue<br>we would not be invalidating the<br>entries properly.<br>WA: In Mask based TLB Shoot down, | SKL:SIWA_FROM_B0  |



| BSpec<br>ID |         | nctional<br>Component | Workaround Name          | Workaround Description                                                                                                                                                                                                                                      | Valid Steppings  |
|-------------|---------|-----------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
|             |         |                       |                          | Mask should be applied on Look up address before sending it to GAMT.                                                                                                                                                                                        |                  |
| 0719        | 3D      |                       |                          | When accumulator destination and<br>offset is odd with the stride of 2 then<br>there is mismatch. 3D driver does not<br>use this kind of instruction but need<br>feedback from media driver team.<br>WA: Do not use the odd offset with<br>the stride of 2. | SKL:SIWA_FROM_B0 |
| 0726        | 3D      |                       |                          | Free running grant in flunit is causing<br>clock ratio determinism issue in SBFT<br>mode.<br>WA: Permanent (for dft mode) is to<br>use unit level clock gating for grant<br>logic still steady state.                                                       | SKL:ALL          |
| 0729        | 3D      |                       |                          | OA can't be functional for media-only<br>perf analysis when render is<br>powerdown.<br>WA: Keep render engine powered ON<br>when OA is enabled for media only<br>perf analysis.                                                                             | SKL:SIWA_FROM_A0 |
| 0731        | Display |                       | WaDisableRCWithAsyncFlip | Display corruption with Async flips<br>when render decompression is<br>enabled.                                                                                                                                                                             | SKL:SIWA_FROM_A0 |
|             |         |                       |                          | WA: Render Compression is not<br>supported with ASync flips. Disable<br>render compression when ASync flips<br>are used.                                                                                                                                    |                  |

| BSpec<br>ID |     | ctional<br>omponent | Workaround Name                | Workaround Description                                                                                                                                                                                                                                                                                                                                                        | Valid Steppings  |
|-------------|-----|---------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0732        | 3D  | omponent            |                                | When src1 has indirect addressing with<br>sends instruction there is a<br>miscompare at the output of EU. 3D<br>and media compiler are not using this<br>instruction with indirect addressing.<br>WA: Indirect addressing not to be<br>used for src1 of sends instruction.                                                                                                    | Valid Steppings  |
| 0736        | 3D  |                     |                                | RTCompression test miscomapres in<br>the MCS buffer.<br>WA: Disable RTR for 1x case (i.e, non-<br>MSAA).                                                                                                                                                                                                                                                                      | SKL:SIWA_FROM_C0 |
| 0737        | 3D  |                     | WaDisableDither                | OptHizClear test with partial clear<br>miscomparing.<br>WA: Dither to be disabled.                                                                                                                                                                                                                                                                                            | SKL:SWIA_FROM_A0 |
| 0738        | GTI |                     | WaSetMDRBunitClckGatingDisable | Clkgating bugs in mdrbunit.<br>WA: Disable clkgating on mdrbunit.                                                                                                                                                                                                                                                                                                             | SKL:SWIA_FROM_A0 |
| 0740        | 3D  |                     |                                | Groupd id select is not resettiing for<br>media walker during context switch<br>from media to GPGPU mode.<br>WA: Need to disable media walker<br>with groups.                                                                                                                                                                                                                 | SKL:SWIA_FROM_A0 |
| 0742        | 3D  |                     |                                | In certain cases in 3D workload if CS is<br>preempted in window of<br>MI_RS_CONTROL(OFF) to<br>MI_RS_CONTROL(ON), then CS may<br>start RS for the instruction which are in<br>RS disable window bracketed by<br>MI_RS_CONTROL(OFF) to<br>MI_RS_CONTROL(OFF) to<br>MI_RS_CONTROL(ON) after<br>resubmission.<br>WA: Whenever programming<br>MI_RS_CONTROL(OFF), disable all the | SKL:SWIA_FROM_A0 |





| BSpec<br>ID | Functional<br>Area/Component | Workaround Name                               | Workaround Description                                                                                                                                                                                                              | Valid Steppings   |
|-------------|------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
|             |                              |                                               | pools so that RS will not generate any<br>produce after execution instruction<br>from this MI_RS_CONTROL(OFF) to<br>MI_RS_CONTROL(ON) zone.                                                                                         |                   |
| 0743        | 3D                           | WaDisableIndirectDataAndFlushGPGPUWalker      | VFE counter overflow due to missing<br>pending_cntr signal for cntr3.<br>WA: Limit urb entries to 63 and<br>MI_ATOMIC_FLUSH need to be<br>inserted after media curbe load<br>command.                                               | SKL:SWIA_UNTIL_G0 |
| 0750        | 3D                           |                                               | Mid Thread Preemption enabling<br>causes VFE TSG hang in Media<br>Context.<br>WA: MEDIA_STATE_FLUSH need to<br>programmed before<br>MI_BATCH_BUFFER_END of the batch<br>buffer with Media_Object or media<br>object walker command. | SKL:SIWA_FOREVER  |
| 0752        | 3D                           | WaSamplerResponseLengthMustBeGreaterThan<br>1 | Dcs_pwc_rc signal is not set when<br>notify clear comes out of phase<br>WA: disable MMIO reads from GW &<br>all sampler sends in GPGPU workloads<br>with response length of 1.                                                      | SKL:SIWA_UNTIL_G0 |
| 0754        | 3D                           |                                               | Select_global_ts_vld typo need to be<br>fixed in GT3 and GT4 mode.<br>WA: Slice and subslice need to be<br>changed it to slice[1:0], subslice[1:0].                                                                                 | SKL:SIWA_FROM_E0  |
| 0755        | 3D                           |                                               | Not able to preempt IDLE flush (rdop)<br>when inhibit sync ctx sw is set.<br>WA: SW must always program<br>PIPE_CONTROL with "CS Stall" and<br>"Render Target Cache Flush Enable"                                                   | SKL:SIWA_FROM_C0  |

| BSpec<br>ID | Functional<br>Area/Component |  | Workaround Name                                  | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                           | Valid Steppings   |
|-------------|------------------------------|--|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
|             |                              |  |                                                  | set prior to programming<br>MI_WAIT_FOR_EVENT command for<br>GPGPU workloads i.e when pipeline<br>select is GPGPU via PIPELINE_SELECT<br>command. This is required to achieve<br>better GPGPU preemption latencies for<br>certain programming sequences. If<br>programming PIPE_CONTROL has<br>performance implications then<br>preemption latencies can be trade off<br>against performance by not<br>implementing this programming note.       |                   |
| 0760        | 3D                           |  |                                                  | Pooled EU EUStressWorkload barrier<br>hang.<br>WA: Need to use bigger thread group<br>workloads.                                                                                                                                                                                                                                                                                                                                                 | SKL:SIWA_UNTIL_G0 |
| 0762        | GTI                          |  | WaSendExtraRSGatherConstantAndRSStoreImm<br>Cmds | RS sends Write and later L3 sends<br>same Read. If GAFM gets GFX fence<br>and do RS flush and stall RS, if RS WR<br>comes, it will stay in FIFO due to STALL<br>after fence, L3 read comes when RS is<br>present in GAFM, L3 gets blocked due<br>to same Address WR present. And gets<br>hang as GAFM cannot respond flush<br>due to this dead lock.<br>WA: Inserting 5 STDW after RS cycle<br>and once it is out then only send L3<br>RD cycle. | SKL:SIWA_FROM_A0  |







| BSpec<br>ID | Functional<br>Area/Component | Workaround Name                                    | Workaround Description                                                                                                                                                                                                                                                                                                                | Valid Steppings   |
|-------------|------------------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| 0763        | GT                           |                                                    | DOP Clock gating not supported when<br>context switching due to preemption<br>is disabled and a streamer wait<br>condition is encountered.<br>WA: Set inhibit_sync_contextswitch bit<br>in this sceanrio. It will enable clock<br>gating.                                                                                             | SKL:SIWA_FOREVER  |
| 0765        | 3D                           | WaDisableMidObjectPreemptionForTrifanOrPol<br>ygon | TriFan miscompare in Execlist<br>Preemption test. Cut index that is on a<br>previous context. End the previous, the<br>resume another context with a tri-fan<br>or polygon, and the vertex count is<br>corrupted. If we prempt again we will<br>cause corruption.<br>WA: Disable mid-draw preemption<br>when draw-call has a tri-fan. | SKL:SIWA_FOREVER  |
| 0771        | 3D                           |                                                    | Issue in Trail mode - rd pointers<br>getting corrupted.<br>WA: Reoder mode bit in 3DSTATE_GS<br>should be always leading.                                                                                                                                                                                                             | SKL:SIWA_FROM_A0  |
| 0775        | 3D                           | WaLodRequiredOnTypedMsaaUav                        | Color buffer corruption in PS UAV test<br>with typed MSAA reads enabled. WA:<br>MSAA registers are not used in SKL<br>(see HSD 2134364)                                                                                                                                                                                               | SKL: SIWA_FROM_C0 |
| 0776        | 3D                           | WaBarrierPerformanceFixDisable                     | Gw clearing N0 incorrectly without<br>complete barrier hit. WA: Disable<br>Barrier Performance DCN by<br>programming MMIO register 7300, bit<br>14 to 1.                                                                                                                                                                              | SKL:SIWA_FROM_E0  |



| BSpec<br>ID |    | nctional<br>Component | Workaround Name | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Valid Steppings  |
|-------------|----|-----------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0778        | 3D |                       |                 | gpgpu_walker_valid need to be reset<br>when start>=dim to avoid corruption<br>in context image.<br>WA: gpgpu_walker_valid need to be<br>reset when dim=0 or start>= dim to<br>avoid corruption in context image                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | SKL:SIWA_FROM_E0 |
| 0780        | 3D |                       |                 | Test hangs as stall_for_barrier_pre<br>value held from 3d workload is<br>affecting gpgpu workload which is<br>submitted later.<br>WA: Disable ACK removal DCN when<br>using both 3d and GPGPU workloads<br>together.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SKL:SIWA_FROM_E0 |
| 0794        | 3D | Media GPGPU           |                 | Address corruption from TSG to MCR<br>when VFE state and global release<br>message during 1-2 clock window:<br>WA (SKL): An MI_FLUSH is required<br>before MEDIA_VFE_STATE unless the<br>only bits that are changed are<br>scoreboard related: Scoreboard<br>Enable, Scoreboard Type, Scoreboard<br>Mask, Scoreboard * Delta. For these<br>scoreboard related states, a<br>MEDIA_STATE_FLUSH is sufficient if the<br>last command is not media<br>walker/media object group id with<br>global barrier.<br>WA: An MI_FLUSH is required before<br>MEDIA_VFE_STATE unless the only bits<br>that are changed are scoreboard<br>related: Scoreboard Enable,<br>Scoreboard Type, Scoreboard Mask,<br>Scoreboard * Delta. For these | SKL:SIWA_FROM_F0 |





|             | what's insid                 |                 |                 |                                                                                                                                                                                                                                           |                  |
|-------------|------------------------------|-----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| BSpec<br>ID | Functional<br>Area/Component |                 | Workaround Name | Workaround Description                                                                                                                                                                                                                    | Valid Steppings  |
|             |                              |                 |                 | scoreboard related states, a<br>MEDIA_STATE_FLUSH is sufficient if the<br>last command is not media<br>walker/media object group id with<br>local/global barrier.                                                                         |                  |
| 0796        | 3D                           |                 |                 | Preemption protocol of<br>csr_dispatch_done followed by<br>tsg_tdg_preemption is broken on<br>Msflush with flushtogo.<br>WA: MSFLUSH without watermark and<br>flush-to-go need to be inserted before<br>MSFLUSH with flush to go command. | SKL:SIWA_FROM_E0 |
| 0798        | 3D                           |                 |                 | VF is corrupting GAFS data when<br>preempted on an instance boundary<br>and replayed with instancing enabled.<br>WA: Disable preemption when using<br>instanceing.                                                                        | SKL:SIWA_FROM_C0 |
| 0800        | GTI                          | GA              |                 | Atomic fence is overtaking WCP<br>eviction cycles on the GAM egress.<br>WA: Add a backup 4AAC flush.                                                                                                                                      | SKL:SIWA_FROM_B0 |
| 0803        | GTI                          |                 |                 | F&H Faults pending with GFX reset<br>GO0 seq is not getting completed.<br>WA: Do a full reset if hit a gam fault.                                                                                                                         | SKL:SIWA_FROM_C0 |
| 0808        | GTI                          |                 |                 | Atomic fence is overtaking WCP<br>eviction cycles on the GAM egress.<br>WA (SKL): Add a backup 4AAC flush.                                                                                                                                | SKL:SIWA_FROM_B0 |
| 0812        | 3D                           | Tiled resources |                 | RCC cacheline is composed of X-<br>adjacent 64B fragments instead of<br>memory adjacent. This causes a single<br>128B cacheline to straddle multiple<br>LODs inside the TYF MIPtail for 3D<br>surfaces (beyond a certain slot             | ALL              |



| BSpec<br>ID | Functional<br>Area/Component | Workaround Name      | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Valid Steppings  |
|-------------|------------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
|             |                              |                      | number), leading to corruption when<br>CCS is enabled for these LODs and RT<br>is later bound as texture.<br>WA: If<br>RENDER_SURFACE_STATE.Surface Type<br>= 3D<br>and RENDER_SURFACE_STATE.Auxiliar<br>y Surface Mode != AUX_NONE<br>and RENDER_SURFACE_STATE.Tiled<br>ResourceMode is TYF or TYS, Set the<br>value of RENDER_SURFACE_STATE.Mip<br>Tail Start LOD to a mip that larger than<br>those present in the surface (i.e. 15)                                          |                  |
| 0816        | 3D                           |                      | Vertex is dropped when the<br>preempted on first vertex of a lineloop.<br>This will cause corruption.<br>WA: Disable mid-draw preemption<br>when the draw uses a lineloop<br>topology.                                                                                                                                                                                                                                                                                           | SKL:SIWA_FROM_C0 |
| 0825        | 3D                           | WaRTReadsOOBBehavior | The HW implementation returns zero<br>in all components if the RTread pixel<br>or sample is outside the primitive.<br>WA: The DirectX spec requires that if<br>the alpha component is not specified<br>in the format, the alpha return value<br>must be the default value of 0x1 for<br>uint and sint number types and 1.0f for<br>all other number types. The SW WA<br>detects this case in the pixel shader<br>and corrects it to match the DirectX<br>spec required behavior. | SKL:ALL          |





| BSpec<br>ID |         | nctional<br>Component | Workaround Name                          | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Valid Steppings   |
|-------------|---------|-----------------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| 0828        | Display | PSR2                  |                                          | PSR2 screen corruptions when multiple<br>regions are updated in a single frame.<br>WA: Set 0x42080 bit 3 = 1 before<br>enabling PSR2. The register can safely<br>remain set when PSR2 is disabled.                                                                                                                                                                                                                                                                              | SKL:ALL           |
| 0831        | KMD     |                       | WaDisableSamplerPowerBypassForSOPingPong | SI can get stuck ping ponging rows in<br>a 2-2-2 fashion instead of 1-1-1<br>leading to a ~3% performance<br>reduction.                                                                                                                                                                                                                                                                                                                                                         | SKL: SIWA_FOREVER |
|             |         |                       |                                          | WA: Disable sampler power bypass to avoid negatively impacting SO 'ping-pong' performance.                                                                                                                                                                                                                                                                                                                                                                                      |                   |
| 0836        | Display | Clocks                |                                          | Increase timeout to 1ms for gt-driver<br>pcode mailbox programming for<br>CDCLK frequency changes. Pcode can<br>take this long in extreme cases. Typical<br>time is less than 200us.                                                                                                                                                                                                                                                                                            | SKL:ALL           |
| 0837        | GAM     |                       | WaSpuriousIOMMUFaults                    | GT GAM HW prefetches context (or<br>extended context) entry when a<br>context is loaded, root pointer is<br>updated or when there is a context<br>cache flush. This prefetch happens<br>without a memory transaction from<br>the context. On this prefetch, if the<br>context entry is a NULL (P=0), HW will<br>generate a fault – invalid context entry.<br>However, it is legal to have a NULL<br>context entry, as long as no memory<br>references are done via that context | SKL:ALL           |

| <b>BSpec</b> | Functional |                     |                 |                                                                                                                                                                                           |                 |
|--------------|------------|---------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| ID           | Area/      | Component           | Workaround Name | Workaround Description                                                                                                                                                                    | Valid Steppings |
|              |            |                     |                 | entry.<br>WA: To avoid these spurious DMA<br>faults, SW should mark the context<br>entry as present (not a NULL entry),<br>and mark the page tables as not<br>present.                    |                 |
| 0838         | GTI        |                     |                 | MGSR hang when MsgCh cycle arrives<br>a couple clocks after IOSF SB shadow<br>request.<br>This is being brought up into the SW<br>WA section for completeness.                            | SKL:ALL         |
|              |            |                     |                 | 0xD00[3:1] already indicate that bits<br>should be set by SW.<br>WA: Enable 0x0D00[3:1] fixes in SW for<br>all Gen9 products.                                                             |                 |
| 0840         | Display    | Watermarks<br>SAGV  |                 | Programming needed for SAGV to<br>prevent underflows in multi-display<br>scenarios. See Display Watermark<br>Programming - Watermark<br>Calculations section.                             | SKL:ALL         |
| 0851         | Display    | FBC                 |                 | To prevent missed invalidations<br>around the time FBC is being enabled,<br>FBC render tracking must use the<br>"Render Tracking With Nuke" method.<br>See Frame Buffer Compression page. | SKL:ALL         |
| 0856         | Display    | Memory<br>Bandwidth |                 | Display underflow with high<br>resolutions and multiple displays. WA:<br>Restrict display configurations to fit<br>within system memory bandwidth                                         | SKL:ALL         |





| BSpec<br>ID |                   | nctional<br>Component | Workaround Name | Workaround Description                                                                                                                                                          | Valid Steppings |
|-------------|-------------------|-----------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|             |                   |                       |                 | threshold. Increase watermarks at<br>some system memory bandwidth<br>thresholds. See Display Watermark<br>Calculations and Display Mode Set<br>Gen9 Display Resolution Support. |                 |
| 0857        | Display           | Planes                |                 | Display underrun issues with Y & Yf<br>Tiling.<br>WA: Set the bit 13 of MMIO register<br>0x46430 to 1b.                                                                         | SKL:ALL         |
| 0859        | Display           | FBC                   |                 | This workaround helps to acheive<br>better idle power savings when FBC is<br>enabled.                                                                                           | SKL:ALL         |
|             |                   |                       |                 | WA: set bit 31 of MMIO register<br>0x45000 to 1'b1.                                                                                                                             |                 |
| 0869        | Display/Po<br>wer | SRD                   |                 | Workaround sequence for SRD/SFU<br>Mode:                                                                                                                                        | SKL:ALL         |
|             |                   |                       |                 | Scenario: Display is in MBO mode and flip occurs other frame.                                                                                                                   |                 |
|             |                   |                       |                 | Repeat:                                                                                                                                                                         |                 |
|             |                   |                       |                 | Frame Without Flip:                                                                                                                                                             |                 |
|             |                   |                       |                 | Set PIPE_MISC[21] = '0'. Optionally driver can send flip to display.                                                                                                            |                 |
|             |                   |                       |                 | Unmask bit takes effect at next<br>Vblank.                                                                                                                                      |                 |
|             |                   |                       |                 | Frame With Flip:                                                                                                                                                                |                 |
|             |                   |                       |                 | Send Flip to display. Set<br>PIPE_MISC[21] = '1'.                                                                                                                               |                 |



| BSpec<br>ID |         | Functional       Area/Component     Workaround Name |                 | Workaround Description                                                                                                                                                                                                                     | Valid Steppings |
|-------------|---------|-----------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|             |         |                                                     |                 | Mask bit takes effect at next Vblank.                                                                                                                                                                                                      |                 |
|             |         |                                                     |                 | In any scenario, PIPE_MISC[21] must not be set for more than 2 frames.                                                                                                                                                                     |                 |
|             |         |                                                     |                 | Ex: If no flip is detected for several frames, driver must unmask PIPE_MISC[21].                                                                                                                                                           |                 |
| 0872        | 3D      | CS                                                  |                 | Global Workaround Batch Buffer will<br>not execute when enabled and<br>Execution List mode is enabled.                                                                                                                                     | SKL:ALL         |
|             |         |                                                     |                 | WA: Do not enable Global WABB when in Execution List mode.                                                                                                                                                                                 |                 |
| 0873        | Display | FBC                                                 |                 | Screen corruption observed with FBC<br>when the front buffer is updated<br>by host modify.                                                                                                                                                 | SKL:ALL         |
|             |         |                                                     |                 | WA: To prevent missed host<br>invalidations around the time FBC is<br>being enabled, enable Nuke on<br>modify. Set bit 23 of MMIO register<br>0x43224 to 1'b1.                                                                             |                 |
| 0874        | GTI     | MMIO                                                | GAMGo0BeforeCPD | When the BGF receives these read-<br>return packets towards the slice when<br>the slice is in reset, it loses<br>synchronization between the valid and<br>the data parts of the transaction. Post<br>this, any actual data returns will be | SKL:ALL         |
|             |         |                                                     |                 | sent with data that is not associated<br>with that transaction, hence causing<br>various problems like corrupted                                                                                                                           |                 |



| BSpec<br>ID |     | nctional<br>Component | Workaround Name                                | Workaround Description                                                                                                                                                                                                                                                                                                                                                                                                                                        | Valid Steppings         |
|-------------|-----|-----------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
|             |     |                       |                                                | instructions, corrupted state etc. Also,<br>since the valid signals and data signals<br>are out of sync, the last data return<br>can also get indefinitely held leading<br>to L3 hangs waiting for data returns.                                                                                                                                                                                                                                              |                         |
|             |     |                       |                                                | WA: Initiate a GAM Go=0 sequence<br>prior to all CPD enter flows to block all<br>memory traffic.                                                                                                                                                                                                                                                                                                                                                              |                         |
| 0876        | GTI | CS                    | WaForceCsStallOnTimestampQueryOrDepthCo<br>unt | Due to known HW issue specific to<br>GT4; on a specific incident (few HW<br>events must happens on the same<br>clock under certain programming<br>conditions) address, data and control<br>fields corresponding to a<br>PIPECONTROL command will get<br>registered wrongly in hardware.<br>Following this incident Fence Reports,<br>Depth Statistic Report (Occlusion<br>Query) and time_stamp reports will get<br>corrupted leading to OS/KMD/UMD<br>hangs. | SKL:GT4 (all GT4 SKU's) |
|             |     |                       |                                                | Workaround (option-1):                                                                                                                                                                                                                                                                                                                                                                                                                                        |                         |
|             |     |                       |                                                | PIEPCONTROL command programmed<br>with "Post Sync Operation" set to<br>"Write Timestamp" or "Write Depth<br>Query" must also set "Command<br>Streamer stall Enable" to '1'.                                                                                                                                                                                                                                                                                   |                         |
|             |     |                       |                                                | Workaround (option-2):                                                                                                                                                                                                                                                                                                                                                                                                                                        |                         |
|             |     |                       |                                                | Software must memorize the event of programming "Post Sync Operation"                                                                                                                                                                                                                                                                                                                                                                                         |                         |

| BSpec<br>ID | Functional<br>Area/Component | Workaround Name | Workaround Description                                                                                                                                                                                                                                                                                                                | Valid Steppings |
|-------------|------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|             |                              |                 | set to "Write Timestamp" or "Write<br>Depth Query" and must set<br>"Pipecontrol Flush Enable" on next<br>PIPECONTROL programmed.                                                                                                                                                                                                      |                 |
|             |                              |                 | Note: Since the passing on the<br>memorized event between UMD and<br>KMD (ring buffer and batch buffer) is<br>difficult, one way it could be addressed<br>in following way.                                                                                                                                                           |                 |
|             |                              |                 | KMD must always program the first<br>PIPECONTROL being programmed in<br>the ringbuffer following the<br>MI_BATCH_BUFFER_START with<br>"Pipecontrol Flush Enable" set. KMD<br>must always program PIPECONTROL<br>with "Pipecontrol Flush Enable" set<br>prior to programming<br>MI_BATCH_BUFFER_START in the ring<br>buffer. <b>OR</b> |                 |
|             |                              |                 | UMD must always program the first<br>PIPECONTROL in the batch buffer with<br>"Pipecontrol Flush Enable" set and<br>must always program the last<br>command in every dispatch of the<br>batch buffer to a PIPECONTROL with<br>"Pipecontrol Flush Enable" set.                                                                          |                 |





| BSpec<br>ID |         |              | Workaround Name | Workaround Description                                                                                                                                                           | Valid Steppings |
|-------------|---------|--------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 0877        | 3D      | Pixel Shader |                 | Hang possible when pixel shader<br>dispatched with only header phases<br>(R0-R2)                                                                                                 | SKL:ALL         |
|             |         |              |                 | WA: Enable a non-header phase (e.g.<br>push constant) when dispatch would<br>have been header-only.                                                                              |                 |
| 0878        | 3D      | Pixel Shader |                 | Push constant buffer corruption possible.                                                                                                                                        | SKL:ALL         |
|             |         |              |                 | WA: Insert 2 zero-length PushConst_PS<br>before every intended PushConst_PS<br>update, issue a NULLPRIM after each<br>of the zero len PC update to make<br>sure CS commits them. |                 |
| 0880        | Display | Clocks       |                 | Timeout for display cdclk mailbox<br>programming increased from 1ms to<br>3ms to account for some corner cases<br>that can exceed 1ms.                                           | SKL:ALL         |
| 0883        | Display | FBC          |                 | When FBC is enabled sometimes<br>screen corruptions/system hangs<br>obeserved under high memory<br>bandwidth conditions.                                                         | SKL:ALL         |
|             |         |              |                 | WA: Set the bit 8 of MMIO register<br>0x43224 to 1b.                                                                                                                             |                 |
|             |         |              |                 | Set the bit 31 of MMIO register<br>0x45000 to 1b.                                                                                                                                |                 |



| BSpec<br>ID |         |                           | Workaround Name | Workaround Description                                                                                                                                                                                                                                                                        | Valid Steppings |
|-------------|---------|---------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 0884        | Display | FBC+PSR                   |                 | When FBC is enabled in DisplayPort<br>PSR mode the CPU host modify writes<br>may not get updated on the Display as<br>expected.<br>WA: Write 0x00000000 to MMIO<br>register 0x700AC with every CPU host<br>modify write.                                                                      | SKL:ALL         |
| 0887        | 3D      | URB SIMD8<br>Channel Mask |                 | URB SIMD8 messages do not support<br>some combinations of with mixed<br>settings of EU execution masks with<br>mixed settings of per-vertex Channel<br>Masks. If an unsupported<br>combination is selected, the EU can<br>hang waiting on a read data<br>completion.<br>Workaround is either: | SKL:ALL         |
|             |         |                           |                 | <ul> <li>set all EU execution masks when<br/>Channel Masks are used, or</li> <li>when EU execution masks have<br/>some cleared entries, either<br/>don't use Channel Masks data<br/>phase or set all Channel Masks<br/>to 0FFh.</li> </ul>                                                    |                 |
| 0888        | 3D      | URB SIMD8<br>Channel Mask |                 | An address corruption can occur on<br>writes, or a data hang can occur on<br>reads, if a SIMD slot address is the<br>most significant OWORD in a cache<br>line and the length of the data is > 4<br>DWORDs and the per-vertex Channel                                                         | SKL:ALL         |



| BSpec | Functional |                     |                 |                                                                                                                                                                                                                                              |                 |
|-------|------------|---------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| ID    | Area/0     | Component           | Workaround Name | Workaround Description                                                                                                                                                                                                                       | Valid Steppings |
|       |            |                     |                 | Mask has mixed settings.                                                                                                                                                                                                                     |                 |
|       |            |                     |                 | The workaround is either                                                                                                                                                                                                                     |                 |
|       |            |                     |                 | <ul> <li>restrict all Slot0 - Slot7 offsets<br/>to be aligned on a cache line, so<br/>that accesses do not span a<br/>cache line, or</li> <li>either don't use Channel Masks<br/>data phase or set all Channel<br/>Masks to 0FFh.</li> </ul> |                 |
| 0893  | Display    | Memory<br>Bandwidth |                 | Display underflow with high<br>resolutions and multiple displays<br>when using dual channel single rank<br>memory.<br>WA: Increase watermarks at some<br>system memory bandwidth<br>thresholds. See Display Watermark<br>Calculations.       | SKL:ALL         |