linux/drivers/gpu/drm/i915/i915_reg.h
<<
>>
Prefs
   1/* Copyright 2003 Tungsten Graphics, Inc., Cedar Park, Texas.
   2 * All Rights Reserved.
   3 *
   4 * Permission is hereby granted, free of charge, to any person obtaining a
   5 * copy of this software and associated documentation files (the
   6 * "Software"), to deal in the Software without restriction, including
   7 * without limitation the rights to use, copy, modify, merge, publish,
   8 * distribute, sub license, and/or sell copies of the Software, and to
   9 * permit persons to whom the Software is furnished to do so, subject to
  10 * the following conditions:
  11 *
  12 * The above copyright notice and this permission notice (including the
  13 * next paragraph) shall be included in all copies or substantial portions
  14 * of the Software.
  15 *
  16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
  17 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
  19 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
  20 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
  21 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
  22 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  23 */
  24
  25#ifndef _I915_REG_H_
  26#define _I915_REG_H_
  27
  28/**
  29 * DOC: The i915 register macro definition style guide
  30 *
  31 * Follow the style described here for new macros, and while changing existing
  32 * macros. Do **not** mass change existing definitions just to update the style.
  33 *
  34 * Layout
  35 * ''''''
  36 *
  37 * Keep helper macros near the top. For example, _PIPE() and friends.
  38 *
  39 * Prefix macros that generally should not be used outside of this file with
  40 * underscore '_'. For example, _PIPE() and friends, single instances of
  41 * registers that are defined solely for the use by function-like macros.
  42 *
  43 * Avoid using the underscore prefixed macros outside of this file. There are
  44 * exceptions, but keep them to a minimum.
  45 *
  46 * There are two basic types of register definitions: Single registers and
  47 * register groups. Register groups are registers which have two or more
  48 * instances, for example one per pipe, port, transcoder, etc. Register groups
  49 * should be defined using function-like macros.
  50 *
  51 * For single registers, define the register offset first, followed by register
  52 * contents.
  53 *
  54 * For register groups, define the register instance offsets first, prefixed
  55 * with underscore, followed by a function-like macro choosing the right
  56 * instance based on the parameter, followed by register contents.
  57 *
  58 * Define the register contents (i.e. bit and bit field macros) from most
  59 * significant to least significant bit. Indent the register content macros
  60 * using two extra spaces between ``#define`` and the macro name.
  61 *
  62 * For bit fields, define a ``_MASK`` and a ``_SHIFT`` macro. Define bit field
  63 * contents so that they are already shifted in place, and can be directly
  64 * OR'd. For convenience, function-like macros may be used to define bit fields,
  65 * but do note that the macros may be needed to read as well as write the
  66 * register contents.
  67 *
  68 * Define bits using ``(1 << N)`` instead of ``BIT(N)``. We may change this in
  69 * the future, but this is the prevailing style. Do **not** add ``_BIT`` suffix
  70 * to the name.
  71 *
  72 * Group the register and its contents together without blank lines, separate
  73 * from other registers and their contents with one blank line.
  74 *
  75 * Indent macro values from macro names using TABs. Align values vertically. Use
  76 * braces in macro values as needed to avoid unintended precedence after macro
  77 * substitution. Use spaces in macro values according to kernel coding
  78 * style. Use lower case in hexadecimal values.
  79 *
  80 * Naming
  81 * ''''''
  82 *
  83 * Try to name registers according to the specs. If the register name changes in
  84 * the specs from platform to another, stick to the original name.
  85 *
  86 * Try to re-use existing register macro definitions. Only add new macros for
  87 * new register offsets, or when the register contents have changed enough to
  88 * warrant a full redefinition.
  89 *
  90 * When a register macro changes for a new platform, prefix the new macro using
  91 * the platform acronym or generation. For example, ``SKL_`` or ``GEN8_``. The
  92 * prefix signifies the start platform/generation using the register.
  93 *
  94 * When a bit (field) macro changes or gets added for a new platform, while
  95 * retaining the existing register macro, add a platform acronym or generation
  96 * suffix to the name. For example, ``_SKL`` or ``_GEN8``.
  97 *
  98 * Examples
  99 * ''''''''
 100 *
 101 * (Note that the values in the example are indented using spaces instead of
 102 * TABs to avoid misalignment in generated documentation. Use TABs in the
 103 * definitions.)::
 104 *
 105 *  #define _FOO_A                      0xf000
 106 *  #define _FOO_B                      0xf001
 107 *  #define FOO(pipe)                   _MMIO_PIPE(pipe, _FOO_A, _FOO_B)
 108 *  #define   FOO_ENABLE                (1 << 31)
 109 *  #define   FOO_MODE_MASK             (0xf << 16)
 110 *  #define   FOO_MODE_SHIFT            16
 111 *  #define   FOO_MODE_BAR              (0 << 16)
 112 *  #define   FOO_MODE_BAZ              (1 << 16)
 113 *  #define   FOO_MODE_QUX_SNB          (2 << 16)
 114 *
 115 *  #define BAR                         _MMIO(0xb000)
 116 *  #define GEN8_BAR                    _MMIO(0xb888)
 117 */
 118
 119typedef struct {
 120        uint32_t reg;
 121} i915_reg_t;
 122
 123#define _MMIO(r) ((const i915_reg_t){ .reg = (r) })
 124
 125#define INVALID_MMIO_REG _MMIO(0)
 126
 127static inline uint32_t i915_mmio_reg_offset(i915_reg_t reg)
 128{
 129        return reg.reg;
 130}
 131
 132static inline bool i915_mmio_reg_equal(i915_reg_t a, i915_reg_t b)
 133{
 134        return i915_mmio_reg_offset(a) == i915_mmio_reg_offset(b);
 135}
 136
 137static inline bool i915_mmio_reg_valid(i915_reg_t reg)
 138{
 139        return !i915_mmio_reg_equal(reg, INVALID_MMIO_REG);
 140}
 141
 142#define _PICK(__index, ...) (((const u32 []){ __VA_ARGS__ })[__index])
 143
 144#define _PIPE(pipe, a, b) ((a) + (pipe)*((b)-(a)))
 145#define _MMIO_PIPE(pipe, a, b) _MMIO(_PIPE(pipe, a, b))
 146#define _PLANE(plane, a, b) _PIPE(plane, a, b)
 147#define _MMIO_PLANE(plane, a, b) _MMIO_PIPE(plane, a, b)
 148#define _TRANS(tran, a, b) ((a) + (tran)*((b)-(a)))
 149#define _MMIO_TRANS(tran, a, b) _MMIO(_TRANS(tran, a, b))
 150#define _PORT(port, a, b) ((a) + (port)*((b)-(a)))
 151#define _MMIO_PORT(port, a, b) _MMIO(_PORT(port, a, b))
 152#define _MMIO_PIPE3(pipe, a, b, c) _MMIO(_PICK(pipe, a, b, c))
 153#define _MMIO_PORT3(pipe, a, b, c) _MMIO(_PICK(pipe, a, b, c))
 154#define _PLL(pll, a, b) ((a) + (pll)*((b)-(a)))
 155#define _MMIO_PLL(pll, a, b) _MMIO(_PLL(pll, a, b))
 156#define _MMIO_PORT6(port, a, b, c, d, e, f) _MMIO(_PICK(port, a, b, c, d, e, f))
 157#define _MMIO_PORT6_LN(port, ln, a0, a1, b, c, d, e, f)                 \
 158        _MMIO(_PICK(port, a0, b, c, d, e, f) + (ln * (a1 - a0)))
 159#define _PHY3(phy, ...) _PICK(phy, __VA_ARGS__)
 160#define _MMIO_PHY3(phy, a, b, c) _MMIO(_PHY3(phy, a, b, c))
 161
 162#define _MASKED_FIELD(mask, value) ({                                      \
 163        if (__builtin_constant_p(mask))                                    \
 164                BUILD_BUG_ON_MSG(((mask) & 0xffff0000), "Incorrect mask"); \
 165        if (__builtin_constant_p(value))                                   \
 166                BUILD_BUG_ON_MSG((value) & 0xffff0000, "Incorrect value"); \
 167        if (__builtin_constant_p(mask) && __builtin_constant_p(value))     \
 168                BUILD_BUG_ON_MSG((value) & ~(mask),                        \
 169                                 "Incorrect value for mask");              \
 170        (mask) << 16 | (value); })
 171#define _MASKED_BIT_ENABLE(a)   ({ typeof(a) _a = (a); _MASKED_FIELD(_a, _a); })
 172#define _MASKED_BIT_DISABLE(a)  (_MASKED_FIELD((a), 0))
 173
 174/* Engine ID */
 175
 176#define RCS_HW          0
 177#define VCS_HW          1
 178#define BCS_HW          2
 179#define VECS_HW         3
 180#define VCS2_HW         4
 181
 182/* Engine class */
 183
 184#define RENDER_CLASS            0
 185#define VIDEO_DECODE_CLASS      1
 186#define VIDEO_ENHANCEMENT_CLASS 2
 187#define COPY_ENGINE_CLASS       3
 188#define OTHER_CLASS             4
 189#define MAX_ENGINE_CLASS        4
 190
 191#define MAX_ENGINE_INSTANCE    1
 192
 193/* PCI config space */
 194
 195#define MCHBAR_I915 0x44
 196#define MCHBAR_I965 0x48
 197#define MCHBAR_SIZE (4 * 4096)
 198
 199#define DEVEN 0x54
 200#define   DEVEN_MCHBAR_EN (1 << 28)
 201
 202/* BSM in include/drm/i915_drm.h */
 203
 204#define HPLLCC  0xc0 /* 85x only */
 205#define   GC_CLOCK_CONTROL_MASK         (0x7 << 0)
 206#define   GC_CLOCK_133_200              (0 << 0)
 207#define   GC_CLOCK_100_200              (1 << 0)
 208#define   GC_CLOCK_100_133              (2 << 0)
 209#define   GC_CLOCK_133_266              (3 << 0)
 210#define   GC_CLOCK_133_200_2            (4 << 0)
 211#define   GC_CLOCK_133_266_2            (5 << 0)
 212#define   GC_CLOCK_166_266              (6 << 0)
 213#define   GC_CLOCK_166_250              (7 << 0)
 214
 215#define I915_GDRST 0xc0 /* PCI config register */
 216#define   GRDOM_FULL            (0 << 2)
 217#define   GRDOM_RENDER          (1 << 2)
 218#define   GRDOM_MEDIA           (3 << 2)
 219#define   GRDOM_MASK            (3 << 2)
 220#define   GRDOM_RESET_STATUS    (1 << 1)
 221#define   GRDOM_RESET_ENABLE    (1 << 0)
 222
 223/* BSpec only has register offset, PCI device and bit found empirically */
 224#define I830_CLOCK_GATE 0xc8 /* device 0 */
 225#define   I830_L2_CACHE_CLOCK_GATE_DISABLE      (1 << 2)
 226
 227#define GCDGMBUS 0xcc
 228
 229#define GCFGC2  0xda
 230#define GCFGC   0xf0 /* 915+ only */
 231#define   GC_LOW_FREQUENCY_ENABLE       (1 << 7)
 232#define   GC_DISPLAY_CLOCK_190_200_MHZ  (0 << 4)
 233#define   GC_DISPLAY_CLOCK_333_320_MHZ  (4 << 4)
 234#define   GC_DISPLAY_CLOCK_267_MHZ_PNV  (0 << 4)
 235#define   GC_DISPLAY_CLOCK_333_MHZ_PNV  (1 << 4)
 236#define   GC_DISPLAY_CLOCK_444_MHZ_PNV  (2 << 4)
 237#define   GC_DISPLAY_CLOCK_200_MHZ_PNV  (5 << 4)
 238#define   GC_DISPLAY_CLOCK_133_MHZ_PNV  (6 << 4)
 239#define   GC_DISPLAY_CLOCK_167_MHZ_PNV  (7 << 4)
 240#define   GC_DISPLAY_CLOCK_MASK         (7 << 4)
 241#define   GM45_GC_RENDER_CLOCK_MASK     (0xf << 0)
 242#define   GM45_GC_RENDER_CLOCK_266_MHZ  (8 << 0)
 243#define   GM45_GC_RENDER_CLOCK_320_MHZ  (9 << 0)
 244#define   GM45_GC_RENDER_CLOCK_400_MHZ  (0xb << 0)
 245#define   GM45_GC_RENDER_CLOCK_533_MHZ  (0xc << 0)
 246#define   I965_GC_RENDER_CLOCK_MASK     (0xf << 0)
 247#define   I965_GC_RENDER_CLOCK_267_MHZ  (2 << 0)
 248#define   I965_GC_RENDER_CLOCK_333_MHZ  (3 << 0)
 249#define   I965_GC_RENDER_CLOCK_444_MHZ  (4 << 0)
 250#define   I965_GC_RENDER_CLOCK_533_MHZ  (5 << 0)
 251#define   I945_GC_RENDER_CLOCK_MASK     (7 << 0)
 252#define   I945_GC_RENDER_CLOCK_166_MHZ  (0 << 0)
 253#define   I945_GC_RENDER_CLOCK_200_MHZ  (1 << 0)
 254#define   I945_GC_RENDER_CLOCK_250_MHZ  (3 << 0)
 255#define   I945_GC_RENDER_CLOCK_400_MHZ  (5 << 0)
 256#define   I915_GC_RENDER_CLOCK_MASK     (7 << 0)
 257#define   I915_GC_RENDER_CLOCK_166_MHZ  (0 << 0)
 258#define   I915_GC_RENDER_CLOCK_200_MHZ  (1 << 0)
 259#define   I915_GC_RENDER_CLOCK_333_MHZ  (4 << 0)
 260
 261#define ASLE    0xe4
 262#define ASLS    0xfc
 263
 264#define SWSCI   0xe8
 265#define   SWSCI_SCISEL  (1 << 15)
 266#define   SWSCI_GSSCIE  (1 << 0)
 267
 268#define LBPC 0xf4 /* legacy/combination backlight modes, also called LBB */
 269
 270
 271#define ILK_GDSR _MMIO(MCHBAR_MIRROR_BASE + 0x2ca4)
 272#define  ILK_GRDOM_FULL         (0<<1)
 273#define  ILK_GRDOM_RENDER       (1<<1)
 274#define  ILK_GRDOM_MEDIA        (3<<1)
 275#define  ILK_GRDOM_MASK         (3<<1)
 276#define  ILK_GRDOM_RESET_ENABLE (1<<0)
 277
 278#define GEN6_MBCUNIT_SNPCR      _MMIO(0x900c) /* for LLC config */
 279#define   GEN6_MBC_SNPCR_SHIFT  21
 280#define   GEN6_MBC_SNPCR_MASK   (3<<21)
 281#define   GEN6_MBC_SNPCR_MAX    (0<<21)
 282#define   GEN6_MBC_SNPCR_MED    (1<<21)
 283#define   GEN6_MBC_SNPCR_LOW    (2<<21)
 284#define   GEN6_MBC_SNPCR_MIN    (3<<21) /* only 1/16th of the cache is shared */
 285
 286#define VLV_G3DCTL              _MMIO(0x9024)
 287#define VLV_GSCKGCTL            _MMIO(0x9028)
 288
 289#define GEN6_MBCTL              _MMIO(0x0907c)
 290#define   GEN6_MBCTL_ENABLE_BOOT_FETCH  (1 << 4)
 291#define   GEN6_MBCTL_CTX_FETCH_NEEDED   (1 << 3)
 292#define   GEN6_MBCTL_BME_UPDATE_ENABLE  (1 << 2)
 293#define   GEN6_MBCTL_MAE_UPDATE_ENABLE  (1 << 1)
 294#define   GEN6_MBCTL_BOOT_FETCH_MECH    (1 << 0)
 295
 296#define GEN6_GDRST      _MMIO(0x941c)
 297#define  GEN6_GRDOM_FULL                (1 << 0)
 298#define  GEN6_GRDOM_RENDER              (1 << 1)
 299#define  GEN6_GRDOM_MEDIA               (1 << 2)
 300#define  GEN6_GRDOM_BLT                 (1 << 3)
 301#define  GEN6_GRDOM_VECS                (1 << 4)
 302#define  GEN9_GRDOM_GUC                 (1 << 5)
 303#define  GEN8_GRDOM_MEDIA2              (1 << 7)
 304
 305#define RING_PP_DIR_BASE(engine)        _MMIO((engine)->mmio_base+0x228)
 306#define RING_PP_DIR_BASE_READ(engine)   _MMIO((engine)->mmio_base+0x518)
 307#define RING_PP_DIR_DCLV(engine)        _MMIO((engine)->mmio_base+0x220)
 308#define   PP_DIR_DCLV_2G                0xffffffff
 309
 310#define GEN8_RING_PDP_UDW(engine, n)    _MMIO((engine)->mmio_base+0x270 + (n) * 8 + 4)
 311#define GEN8_RING_PDP_LDW(engine, n)    _MMIO((engine)->mmio_base+0x270 + (n) * 8)
 312
 313#define GEN8_R_PWR_CLK_STATE            _MMIO(0x20C8)
 314#define   GEN8_RPCS_ENABLE              (1 << 31)
 315#define   GEN8_RPCS_S_CNT_ENABLE        (1 << 18)
 316#define   GEN8_RPCS_S_CNT_SHIFT         15
 317#define   GEN8_RPCS_S_CNT_MASK          (0x7 << GEN8_RPCS_S_CNT_SHIFT)
 318#define   GEN8_RPCS_SS_CNT_ENABLE       (1 << 11)
 319#define   GEN8_RPCS_SS_CNT_SHIFT        8
 320#define   GEN8_RPCS_SS_CNT_MASK         (0x7 << GEN8_RPCS_SS_CNT_SHIFT)
 321#define   GEN8_RPCS_EU_MAX_SHIFT        4
 322#define   GEN8_RPCS_EU_MAX_MASK         (0xf << GEN8_RPCS_EU_MAX_SHIFT)
 323#define   GEN8_RPCS_EU_MIN_SHIFT        0
 324#define   GEN8_RPCS_EU_MIN_MASK         (0xf << GEN8_RPCS_EU_MIN_SHIFT)
 325
 326#define WAIT_FOR_RC6_EXIT               _MMIO(0x20CC)
 327/* HSW only */
 328#define   HSW_SELECTIVE_READ_ADDRESSING_SHIFT           2
 329#define   HSW_SELECTIVE_READ_ADDRESSING_MASK            (0x3 << HSW_SLECTIVE_READ_ADDRESSING_SHIFT)
 330#define   HSW_SELECTIVE_WRITE_ADDRESS_SHIFT             4
 331#define   HSW_SELECTIVE_WRITE_ADDRESS_MASK              (0x7 << HSW_SELECTIVE_WRITE_ADDRESS_SHIFT)
 332/* HSW+ */
 333#define   HSW_WAIT_FOR_RC6_EXIT_ENABLE                  (1 << 0)
 334#define   HSW_RCS_CONTEXT_ENABLE                        (1 << 7)
 335#define   HSW_RCS_INHIBIT                               (1 << 8)
 336/* Gen8 */
 337#define   GEN8_SELECTIVE_WRITE_ADDRESS_SHIFT            4
 338#define   GEN8_SELECTIVE_WRITE_ADDRESS_MASK             (0x3 << GEN8_SELECTIVE_WRITE_ADDRESS_SHIFT)
 339#define   GEN8_SELECTIVE_WRITE_ADDRESS_SHIFT            4
 340#define   GEN8_SELECTIVE_WRITE_ADDRESS_MASK             (0x3 << GEN8_SELECTIVE_WRITE_ADDRESS_SHIFT)
 341#define   GEN8_SELECTIVE_WRITE_ADDRESSING_ENABLE        (1 << 6)
 342#define   GEN8_SELECTIVE_READ_SUBSLICE_SELECT_SHIFT     9
 343#define   GEN8_SELECTIVE_READ_SUBSLICE_SELECT_MASK      (0x3 << GEN8_SELECTIVE_READ_SUBSLICE_SELECT_SHIFT)
 344#define   GEN8_SELECTIVE_READ_SLICE_SELECT_SHIFT        11
 345#define   GEN8_SELECTIVE_READ_SLICE_SELECT_MASK         (0x3 << GEN8_SELECTIVE_READ_SLICE_SELECT_SHIFT)
 346#define   GEN8_SELECTIVE_READ_ADDRESSING_ENABLE         (1 << 13)
 347
 348#define GAM_ECOCHK                      _MMIO(0x4090)
 349#define   BDW_DISABLE_HDC_INVALIDATION  (1<<25)
 350#define   ECOCHK_SNB_BIT                (1<<10)
 351#define   ECOCHK_DIS_TLB                (1<<8)
 352#define   HSW_ECOCHK_ARB_PRIO_SOL       (1<<6)
 353#define   ECOCHK_PPGTT_CACHE64B         (0x3<<3)
 354#define   ECOCHK_PPGTT_CACHE4B          (0x0<<3)
 355#define   ECOCHK_PPGTT_GFDT_IVB         (0x1<<4)
 356#define   ECOCHK_PPGTT_LLC_IVB          (0x1<<3)
 357#define   ECOCHK_PPGTT_UC_HSW           (0x1<<3)
 358#define   ECOCHK_PPGTT_WT_HSW           (0x2<<3)
 359#define   ECOCHK_PPGTT_WB_HSW           (0x3<<3)
 360
 361#define GAC_ECO_BITS                    _MMIO(0x14090)
 362#define   ECOBITS_SNB_BIT               (1<<13)
 363#define   ECOBITS_PPGTT_CACHE64B        (3<<8)
 364#define   ECOBITS_PPGTT_CACHE4B         (0<<8)
 365
 366#define GAB_CTL                         _MMIO(0x24000)
 367#define   GAB_CTL_CONT_AFTER_PAGEFAULT  (1<<8)
 368
 369#define GEN6_STOLEN_RESERVED            _MMIO(0x1082C0)
 370#define GEN6_STOLEN_RESERVED_ADDR_MASK  (0xFFF << 20)
 371#define GEN7_STOLEN_RESERVED_ADDR_MASK  (0x3FFF << 18)
 372#define GEN6_STOLEN_RESERVED_SIZE_MASK  (3 << 4)
 373#define GEN6_STOLEN_RESERVED_1M         (0 << 4)
 374#define GEN6_STOLEN_RESERVED_512K       (1 << 4)
 375#define GEN6_STOLEN_RESERVED_256K       (2 << 4)
 376#define GEN6_STOLEN_RESERVED_128K       (3 << 4)
 377#define GEN7_STOLEN_RESERVED_SIZE_MASK  (1 << 5)
 378#define GEN7_STOLEN_RESERVED_1M         (0 << 5)
 379#define GEN7_STOLEN_RESERVED_256K       (1 << 5)
 380#define GEN8_STOLEN_RESERVED_SIZE_MASK  (3 << 7)
 381#define GEN8_STOLEN_RESERVED_1M         (0 << 7)
 382#define GEN8_STOLEN_RESERVED_2M         (1 << 7)
 383#define GEN8_STOLEN_RESERVED_4M         (2 << 7)
 384#define GEN8_STOLEN_RESERVED_8M         (3 << 7)
 385#define GEN6_STOLEN_RESERVED_ENABLE     (1 << 0)
 386
 387/* VGA stuff */
 388
 389#define VGA_ST01_MDA 0x3ba
 390#define VGA_ST01_CGA 0x3da
 391
 392#define _VGA_MSR_WRITE _MMIO(0x3c2)
 393#define VGA_MSR_WRITE 0x3c2
 394#define VGA_MSR_READ 0x3cc
 395#define   VGA_MSR_MEM_EN (1<<1)
 396#define   VGA_MSR_CGA_MODE (1<<0)
 397
 398#define VGA_SR_INDEX 0x3c4
 399#define SR01                    1
 400#define VGA_SR_DATA 0x3c5
 401
 402#define VGA_AR_INDEX 0x3c0
 403#define   VGA_AR_VID_EN (1<<5)
 404#define VGA_AR_DATA_WRITE 0x3c0
 405#define VGA_AR_DATA_READ 0x3c1
 406
 407#define VGA_GR_INDEX 0x3ce
 408#define VGA_GR_DATA 0x3cf
 409/* GR05 */
 410#define   VGA_GR_MEM_READ_MODE_SHIFT 3
 411#define     VGA_GR_MEM_READ_MODE_PLANE 1
 412/* GR06 */
 413#define   VGA_GR_MEM_MODE_MASK 0xc
 414#define   VGA_GR_MEM_MODE_SHIFT 2
 415#define   VGA_GR_MEM_A0000_AFFFF 0
 416#define   VGA_GR_MEM_A0000_BFFFF 1
 417#define   VGA_GR_MEM_B0000_B7FFF 2
 418#define   VGA_GR_MEM_B0000_BFFFF 3
 419
 420#define VGA_DACMASK 0x3c6
 421#define VGA_DACRX 0x3c7
 422#define VGA_DACWX 0x3c8
 423#define VGA_DACDATA 0x3c9
 424
 425#define VGA_CR_INDEX_MDA 0x3b4
 426#define VGA_CR_DATA_MDA 0x3b5
 427#define VGA_CR_INDEX_CGA 0x3d4
 428#define VGA_CR_DATA_CGA 0x3d5
 429
 430/*
 431 * Instruction field definitions used by the command parser
 432 */
 433#define INSTR_CLIENT_SHIFT      29
 434#define   INSTR_MI_CLIENT       0x0
 435#define   INSTR_BC_CLIENT       0x2
 436#define   INSTR_RC_CLIENT       0x3
 437#define INSTR_SUBCLIENT_SHIFT   27
 438#define INSTR_SUBCLIENT_MASK    0x18000000
 439#define   INSTR_MEDIA_SUBCLIENT 0x2
 440#define INSTR_26_TO_24_MASK     0x7000000
 441#define   INSTR_26_TO_24_SHIFT  24
 442
 443/*
 444 * Memory interface instructions used by the kernel
 445 */
 446#define MI_INSTR(opcode, flags) (((opcode) << 23) | (flags))
 447/* Many MI commands use bit 22 of the header dword for GGTT vs PPGTT */
 448#define  MI_GLOBAL_GTT    (1<<22)
 449
 450#define MI_NOOP                 MI_INSTR(0, 0)
 451#define MI_USER_INTERRUPT       MI_INSTR(0x02, 0)
 452#define MI_WAIT_FOR_EVENT       MI_INSTR(0x03, 0)
 453#define   MI_WAIT_FOR_OVERLAY_FLIP      (1<<16)
 454#define   MI_WAIT_FOR_PLANE_B_FLIP      (1<<6)
 455#define   MI_WAIT_FOR_PLANE_A_FLIP      (1<<2)
 456#define   MI_WAIT_FOR_PLANE_A_SCANLINES (1<<1)
 457#define MI_FLUSH                MI_INSTR(0x04, 0)
 458#define   MI_READ_FLUSH         (1 << 0)
 459#define   MI_EXE_FLUSH          (1 << 1)
 460#define   MI_NO_WRITE_FLUSH     (1 << 2)
 461#define   MI_SCENE_COUNT        (1 << 3) /* just increment scene count */
 462#define   MI_END_SCENE          (1 << 4) /* flush binner and incr scene count */
 463#define   MI_INVALIDATE_ISP     (1 << 5) /* invalidate indirect state pointers */
 464#define MI_REPORT_HEAD          MI_INSTR(0x07, 0)
 465#define MI_ARB_ON_OFF           MI_INSTR(0x08, 0)
 466#define   MI_ARB_ENABLE                 (1<<0)
 467#define   MI_ARB_DISABLE                (0<<0)
 468#define MI_BATCH_BUFFER_END     MI_INSTR(0x0a, 0)
 469#define MI_SUSPEND_FLUSH        MI_INSTR(0x0b, 0)
 470#define   MI_SUSPEND_FLUSH_EN   (1<<0)
 471#define MI_SET_APPID            MI_INSTR(0x0e, 0)
 472#define MI_OVERLAY_FLIP         MI_INSTR(0x11, 0)
 473#define   MI_OVERLAY_CONTINUE   (0x0<<21)
 474#define   MI_OVERLAY_ON         (0x1<<21)
 475#define   MI_OVERLAY_OFF        (0x2<<21)
 476#define MI_LOAD_SCAN_LINES_INCL MI_INSTR(0x12, 0)
 477#define MI_DISPLAY_FLIP         MI_INSTR(0x14, 2)
 478#define MI_DISPLAY_FLIP_I915    MI_INSTR(0x14, 1)
 479#define   MI_DISPLAY_FLIP_PLANE(n) ((n) << 20)
 480/* IVB has funny definitions for which plane to flip. */
 481#define   MI_DISPLAY_FLIP_IVB_PLANE_A  (0 << 19)
 482#define   MI_DISPLAY_FLIP_IVB_PLANE_B  (1 << 19)
 483#define   MI_DISPLAY_FLIP_IVB_SPRITE_A (2 << 19)
 484#define   MI_DISPLAY_FLIP_IVB_SPRITE_B (3 << 19)
 485#define   MI_DISPLAY_FLIP_IVB_PLANE_C  (4 << 19)
 486#define   MI_DISPLAY_FLIP_IVB_SPRITE_C (5 << 19)
 487/* SKL ones */
 488#define   MI_DISPLAY_FLIP_SKL_PLANE_1_A (0 << 8)
 489#define   MI_DISPLAY_FLIP_SKL_PLANE_1_B (1 << 8)
 490#define   MI_DISPLAY_FLIP_SKL_PLANE_1_C (2 << 8)
 491#define   MI_DISPLAY_FLIP_SKL_PLANE_2_A (4 << 8)
 492#define   MI_DISPLAY_FLIP_SKL_PLANE_2_B (5 << 8)
 493#define   MI_DISPLAY_FLIP_SKL_PLANE_2_C (6 << 8)
 494#define   MI_DISPLAY_FLIP_SKL_PLANE_3_A (7 << 8)
 495#define   MI_DISPLAY_FLIP_SKL_PLANE_3_B (8 << 8)
 496#define   MI_DISPLAY_FLIP_SKL_PLANE_3_C (9 << 8)
 497#define MI_SEMAPHORE_MBOX       MI_INSTR(0x16, 1) /* gen6, gen7 */
 498#define   MI_SEMAPHORE_GLOBAL_GTT    (1<<22)
 499#define   MI_SEMAPHORE_UPDATE       (1<<21)
 500#define   MI_SEMAPHORE_COMPARE      (1<<20)
 501#define   MI_SEMAPHORE_REGISTER     (1<<18)
 502#define   MI_SEMAPHORE_SYNC_VR      (0<<16) /* RCS  wait for VCS  (RVSYNC) */
 503#define   MI_SEMAPHORE_SYNC_VER     (1<<16) /* RCS  wait for VECS (RVESYNC) */
 504#define   MI_SEMAPHORE_SYNC_BR      (2<<16) /* RCS  wait for BCS  (RBSYNC) */
 505#define   MI_SEMAPHORE_SYNC_BV      (0<<16) /* VCS  wait for BCS  (VBSYNC) */
 506#define   MI_SEMAPHORE_SYNC_VEV     (1<<16) /* VCS  wait for VECS (VVESYNC) */
 507#define   MI_SEMAPHORE_SYNC_RV      (2<<16) /* VCS  wait for RCS  (VRSYNC) */
 508#define   MI_SEMAPHORE_SYNC_RB      (0<<16) /* BCS  wait for RCS  (BRSYNC) */
 509#define   MI_SEMAPHORE_SYNC_VEB     (1<<16) /* BCS  wait for VECS (BVESYNC) */
 510#define   MI_SEMAPHORE_SYNC_VB      (2<<16) /* BCS  wait for VCS  (BVSYNC) */
 511#define   MI_SEMAPHORE_SYNC_BVE     (0<<16) /* VECS wait for BCS  (VEBSYNC) */
 512#define   MI_SEMAPHORE_SYNC_VVE     (1<<16) /* VECS wait for VCS  (VEVSYNC) */
 513#define   MI_SEMAPHORE_SYNC_RVE     (2<<16) /* VECS wait for RCS  (VERSYNC) */
 514#define   MI_SEMAPHORE_SYNC_INVALID (3<<16)
 515#define   MI_SEMAPHORE_SYNC_MASK    (3<<16)
 516#define MI_SET_CONTEXT          MI_INSTR(0x18, 0)
 517#define   MI_MM_SPACE_GTT               (1<<8)
 518#define   MI_MM_SPACE_PHYSICAL          (0<<8)
 519#define   MI_SAVE_EXT_STATE_EN          (1<<3)
 520#define   MI_RESTORE_EXT_STATE_EN       (1<<2)
 521#define   MI_FORCE_RESTORE              (1<<1)
 522#define   MI_RESTORE_INHIBIT            (1<<0)
 523#define   HSW_MI_RS_SAVE_STATE_EN       (1<<3)
 524#define   HSW_MI_RS_RESTORE_STATE_EN    (1<<2)
 525#define MI_SEMAPHORE_SIGNAL     MI_INSTR(0x1b, 0) /* GEN8+ */
 526#define   MI_SEMAPHORE_TARGET(engine)   ((engine)<<15)
 527#define MI_SEMAPHORE_WAIT       MI_INSTR(0x1c, 2) /* GEN8+ */
 528#define   MI_SEMAPHORE_POLL             (1<<15)
 529#define   MI_SEMAPHORE_SAD_GTE_SDD      (1<<12)
 530#define MI_STORE_DWORD_IMM      MI_INSTR(0x20, 1)
 531#define MI_STORE_DWORD_IMM_GEN4 MI_INSTR(0x20, 2)
 532#define   MI_MEM_VIRTUAL        (1 << 22) /* 945,g33,965 */
 533#define   MI_USE_GGTT           (1 << 22) /* g4x+ */
 534#define MI_STORE_DWORD_INDEX    MI_INSTR(0x21, 1)
 535#define   MI_STORE_DWORD_INDEX_SHIFT 2
 536/* Official intel docs are somewhat sloppy concerning MI_LOAD_REGISTER_IMM:
 537 * - Always issue a MI_NOOP _before_ the MI_LOAD_REGISTER_IMM - otherwise hw
 538 *   simply ignores the register load under certain conditions.
 539 * - One can actually load arbitrary many arbitrary registers: Simply issue x
 540 *   address/value pairs. Don't overdue it, though, x <= 2^4 must hold!
 541 */
 542#define MI_LOAD_REGISTER_IMM(x) MI_INSTR(0x22, 2*(x)-1)
 543#define   MI_LRI_FORCE_POSTED           (1<<12)
 544#define MI_STORE_REGISTER_MEM        MI_INSTR(0x24, 1)
 545#define MI_STORE_REGISTER_MEM_GEN8   MI_INSTR(0x24, 2)
 546#define   MI_SRM_LRM_GLOBAL_GTT         (1<<22)
 547#define MI_FLUSH_DW             MI_INSTR(0x26, 1) /* for GEN6 */
 548#define   MI_FLUSH_DW_STORE_INDEX       (1<<21)
 549#define   MI_INVALIDATE_TLB             (1<<18)
 550#define   MI_FLUSH_DW_OP_STOREDW        (1<<14)
 551#define   MI_FLUSH_DW_OP_MASK           (3<<14)
 552#define   MI_FLUSH_DW_NOTIFY            (1<<8)
 553#define   MI_INVALIDATE_BSD             (1<<7)
 554#define   MI_FLUSH_DW_USE_GTT           (1<<2)
 555#define   MI_FLUSH_DW_USE_PPGTT         (0<<2)
 556#define MI_LOAD_REGISTER_MEM       MI_INSTR(0x29, 1)
 557#define MI_LOAD_REGISTER_MEM_GEN8  MI_INSTR(0x29, 2)
 558#define MI_BATCH_BUFFER         MI_INSTR(0x30, 1)
 559#define   MI_BATCH_NON_SECURE           (1)
 560/* for snb/ivb/vlv this also means "batch in ppgtt" when ppgtt is enabled. */
 561#define   MI_BATCH_NON_SECURE_I965      (1<<8)
 562#define   MI_BATCH_PPGTT_HSW            (1<<8)
 563#define   MI_BATCH_NON_SECURE_HSW       (1<<13)
 564#define MI_BATCH_BUFFER_START   MI_INSTR(0x31, 0)
 565#define   MI_BATCH_GTT              (2<<6) /* aliased with (1<<7) on gen4 */
 566#define MI_BATCH_BUFFER_START_GEN8      MI_INSTR(0x31, 1)
 567#define   MI_BATCH_RESOURCE_STREAMER (1<<10)
 568
 569#define MI_PREDICATE_SRC0       _MMIO(0x2400)
 570#define MI_PREDICATE_SRC0_UDW   _MMIO(0x2400 + 4)
 571#define MI_PREDICATE_SRC1       _MMIO(0x2408)
 572#define MI_PREDICATE_SRC1_UDW   _MMIO(0x2408 + 4)
 573
 574#define MI_PREDICATE_RESULT_2   _MMIO(0x2214)
 575#define  LOWER_SLICE_ENABLED    (1<<0)
 576#define  LOWER_SLICE_DISABLED   (0<<0)
 577
 578/*
 579 * 3D instructions used by the kernel
 580 */
 581#define GFX_INSTR(opcode, flags) ((0x3 << 29) | ((opcode) << 24) | (flags))
 582
 583#define GEN9_MEDIA_POOL_STATE     ((0x3 << 29) | (0x2 << 27) | (0x5 << 16) | 4)
 584#define   GEN9_MEDIA_POOL_ENABLE  (1 << 31)
 585#define GFX_OP_RASTER_RULES    ((0x3<<29)|(0x7<<24))
 586#define GFX_OP_SCISSOR         ((0x3<<29)|(0x1c<<24)|(0x10<<19))
 587#define   SC_UPDATE_SCISSOR       (0x1<<1)
 588#define   SC_ENABLE_MASK          (0x1<<0)
 589#define   SC_ENABLE               (0x1<<0)
 590#define GFX_OP_LOAD_INDIRECT   ((0x3<<29)|(0x1d<<24)|(0x7<<16))
 591#define GFX_OP_SCISSOR_INFO    ((0x3<<29)|(0x1d<<24)|(0x81<<16)|(0x1))
 592#define   SCI_YMIN_MASK      (0xffff<<16)
 593#define   SCI_XMIN_MASK      (0xffff<<0)
 594#define   SCI_YMAX_MASK      (0xffff<<16)
 595#define   SCI_XMAX_MASK      (0xffff<<0)
 596#define GFX_OP_SCISSOR_ENABLE    ((0x3<<29)|(0x1c<<24)|(0x10<<19))
 597#define GFX_OP_SCISSOR_RECT      ((0x3<<29)|(0x1d<<24)|(0x81<<16)|1)
 598#define GFX_OP_COLOR_FACTOR      ((0x3<<29)|(0x1d<<24)|(0x1<<16)|0x0)
 599#define GFX_OP_STIPPLE           ((0x3<<29)|(0x1d<<24)|(0x83<<16))
 600#define GFX_OP_MAP_INFO          ((0x3<<29)|(0x1d<<24)|0x4)
 601#define GFX_OP_DESTBUFFER_VARS   ((0x3<<29)|(0x1d<<24)|(0x85<<16)|0x0)
 602#define GFX_OP_DESTBUFFER_INFO   ((0x3<<29)|(0x1d<<24)|(0x8e<<16)|1)
 603#define GFX_OP_DRAWRECT_INFO     ((0x3<<29)|(0x1d<<24)|(0x80<<16)|(0x3))
 604#define GFX_OP_DRAWRECT_INFO_I965  ((0x7900<<16)|0x2)
 605
 606#define COLOR_BLT_CMD                   (2<<29 | 0x40<<22 | (5-2))
 607#define SRC_COPY_BLT_CMD                ((2<<29)|(0x43<<22)|4)
 608#define XY_SRC_COPY_BLT_CMD             ((2<<29)|(0x53<<22)|6)
 609#define XY_MONO_SRC_COPY_IMM_BLT        ((2<<29)|(0x71<<22)|5)
 610#define   BLT_WRITE_A                   (2<<20)
 611#define   BLT_WRITE_RGB                 (1<<20)
 612#define   BLT_WRITE_RGBA                (BLT_WRITE_RGB | BLT_WRITE_A)
 613#define   BLT_DEPTH_8                   (0<<24)
 614#define   BLT_DEPTH_16_565              (1<<24)
 615#define   BLT_DEPTH_16_1555             (2<<24)
 616#define   BLT_DEPTH_32                  (3<<24)
 617#define   BLT_ROP_SRC_COPY              (0xcc<<16)
 618#define   BLT_ROP_COLOR_COPY            (0xf0<<16)
 619#define XY_SRC_COPY_BLT_SRC_TILED       (1<<15) /* 965+ only */
 620#define XY_SRC_COPY_BLT_DST_TILED       (1<<11) /* 965+ only */
 621#define CMD_OP_DISPLAYBUFFER_INFO ((0x0<<29)|(0x14<<23)|2)
 622#define   ASYNC_FLIP                (1<<22)
 623#define   DISPLAY_PLANE_A           (0<<20)
 624#define   DISPLAY_PLANE_B           (1<<20)
 625#define GFX_OP_PIPE_CONTROL(len)        ((0x3<<29)|(0x3<<27)|(0x2<<24)|((len)-2))
 626#define   PIPE_CONTROL_FLUSH_L3                         (1<<27)
 627#define   PIPE_CONTROL_GLOBAL_GTT_IVB                   (1<<24) /* gen7+ */
 628#define   PIPE_CONTROL_MMIO_WRITE                       (1<<23)
 629#define   PIPE_CONTROL_STORE_DATA_INDEX                 (1<<21)
 630#define   PIPE_CONTROL_CS_STALL                         (1<<20)
 631#define   PIPE_CONTROL_TLB_INVALIDATE                   (1<<18)
 632#define   PIPE_CONTROL_MEDIA_STATE_CLEAR                (1<<16)
 633#define   PIPE_CONTROL_QW_WRITE                         (1<<14)
 634#define   PIPE_CONTROL_POST_SYNC_OP_MASK                (3<<14)
 635#define   PIPE_CONTROL_DEPTH_STALL                      (1<<13)
 636#define   PIPE_CONTROL_WRITE_FLUSH                      (1<<12)
 637#define   PIPE_CONTROL_RENDER_TARGET_CACHE_FLUSH        (1<<12) /* gen6+ */
 638#define   PIPE_CONTROL_INSTRUCTION_CACHE_INVALIDATE     (1<<11) /* MBZ on Ironlake */
 639#define   PIPE_CONTROL_TEXTURE_CACHE_INVALIDATE         (1<<10) /* GM45+ only */
 640#define   PIPE_CONTROL_INDIRECT_STATE_DISABLE           (1<<9)
 641#define   PIPE_CONTROL_NOTIFY                           (1<<8)
 642#define   PIPE_CONTROL_FLUSH_ENABLE                     (1<<7) /* gen7+ */
 643#define   PIPE_CONTROL_DC_FLUSH_ENABLE                  (1<<5)
 644#define   PIPE_CONTROL_VF_CACHE_INVALIDATE              (1<<4)
 645#define   PIPE_CONTROL_CONST_CACHE_INVALIDATE           (1<<3)
 646#define   PIPE_CONTROL_STATE_CACHE_INVALIDATE           (1<<2)
 647#define   PIPE_CONTROL_STALL_AT_SCOREBOARD              (1<<1)
 648#define   PIPE_CONTROL_DEPTH_CACHE_FLUSH                (1<<0)
 649#define   PIPE_CONTROL_GLOBAL_GTT (1<<2) /* in addr dword */
 650
 651/*
 652 * Commands used only by the command parser
 653 */
 654#define MI_SET_PREDICATE        MI_INSTR(0x01, 0)
 655#define MI_ARB_CHECK            MI_INSTR(0x05, 0)
 656#define MI_RS_CONTROL           MI_INSTR(0x06, 0)
 657#define MI_URB_ATOMIC_ALLOC     MI_INSTR(0x09, 0)
 658#define MI_PREDICATE            MI_INSTR(0x0C, 0)
 659#define MI_RS_CONTEXT           MI_INSTR(0x0F, 0)
 660#define MI_TOPOLOGY_FILTER      MI_INSTR(0x0D, 0)
 661#define MI_LOAD_SCAN_LINES_EXCL MI_INSTR(0x13, 0)
 662#define MI_URB_CLEAR            MI_INSTR(0x19, 0)
 663#define MI_UPDATE_GTT           MI_INSTR(0x23, 0)
 664#define MI_CLFLUSH              MI_INSTR(0x27, 0)
 665#define MI_REPORT_PERF_COUNT    MI_INSTR(0x28, 0)
 666#define   MI_REPORT_PERF_COUNT_GGTT (1<<0)
 667#define MI_LOAD_REGISTER_REG    MI_INSTR(0x2A, 0)
 668#define MI_RS_STORE_DATA_IMM    MI_INSTR(0x2B, 0)
 669#define MI_LOAD_URB_MEM         MI_INSTR(0x2C, 0)
 670#define MI_STORE_URB_MEM        MI_INSTR(0x2D, 0)
 671#define MI_CONDITIONAL_BATCH_BUFFER_END MI_INSTR(0x36, 0)
 672
 673#define PIPELINE_SELECT                ((0x3<<29)|(0x1<<27)|(0x1<<24)|(0x4<<16))
 674#define GFX_OP_3DSTATE_VF_STATISTICS   ((0x3<<29)|(0x1<<27)|(0x0<<24)|(0xB<<16))
 675#define MEDIA_VFE_STATE                ((0x3<<29)|(0x2<<27)|(0x0<<24)|(0x0<<16))
 676#define  MEDIA_VFE_STATE_MMIO_ACCESS_MASK (0x18)
 677#define GPGPU_OBJECT                   ((0x3<<29)|(0x2<<27)|(0x1<<24)|(0x4<<16))
 678#define GPGPU_WALKER                   ((0x3<<29)|(0x2<<27)|(0x1<<24)|(0x5<<16))
 679#define GFX_OP_3DSTATE_DX9_CONSTANTF_VS \
 680        ((0x3<<29)|(0x3<<27)|(0x0<<24)|(0x39<<16))
 681#define GFX_OP_3DSTATE_DX9_CONSTANTF_PS \
 682        ((0x3<<29)|(0x3<<27)|(0x0<<24)|(0x3A<<16))
 683#define GFX_OP_3DSTATE_SO_DECL_LIST \
 684        ((0x3<<29)|(0x3<<27)|(0x1<<24)|(0x17<<16))
 685
 686#define GFX_OP_3DSTATE_BINDING_TABLE_EDIT_VS \
 687        ((0x3<<29)|(0x3<<27)|(0x0<<24)|(0x43<<16))
 688#define GFX_OP_3DSTATE_BINDING_TABLE_EDIT_GS \
 689        ((0x3<<29)|(0x3<<27)|(0x0<<24)|(0x44<<16))
 690#define GFX_OP_3DSTATE_BINDING_TABLE_EDIT_HS \
 691        ((0x3<<29)|(0x3<<27)|(0x0<<24)|(0x45<<16))
 692#define GFX_OP_3DSTATE_BINDING_TABLE_EDIT_DS \
 693        ((0x3<<29)|(0x3<<27)|(0x0<<24)|(0x46<<16))
 694#define GFX_OP_3DSTATE_BINDING_TABLE_EDIT_PS \
 695        ((0x3<<29)|(0x3<<27)|(0x0<<24)|(0x47<<16))
 696
 697#define MFX_WAIT  ((0x3<<29)|(0x1<<27)|(0x0<<16))
 698
 699#define COLOR_BLT     ((0x2<<29)|(0x40<<22))
 700#define SRC_COPY_BLT  ((0x2<<29)|(0x43<<22))
 701
 702/*
 703 * Registers used only by the command parser
 704 */
 705#define BCS_SWCTRL _MMIO(0x22200)
 706
 707#define GPGPU_THREADS_DISPATCHED        _MMIO(0x2290)
 708#define GPGPU_THREADS_DISPATCHED_UDW    _MMIO(0x2290 + 4)
 709#define HS_INVOCATION_COUNT             _MMIO(0x2300)
 710#define HS_INVOCATION_COUNT_UDW         _MMIO(0x2300 + 4)
 711#define DS_INVOCATION_COUNT             _MMIO(0x2308)
 712#define DS_INVOCATION_COUNT_UDW         _MMIO(0x2308 + 4)
 713#define IA_VERTICES_COUNT               _MMIO(0x2310)
 714#define IA_VERTICES_COUNT_UDW           _MMIO(0x2310 + 4)
 715#define IA_PRIMITIVES_COUNT             _MMIO(0x2318)
 716#define IA_PRIMITIVES_COUNT_UDW         _MMIO(0x2318 + 4)
 717#define VS_INVOCATION_COUNT             _MMIO(0x2320)
 718#define VS_INVOCATION_COUNT_UDW         _MMIO(0x2320 + 4)
 719#define GS_INVOCATION_COUNT             _MMIO(0x2328)
 720#define GS_INVOCATION_COUNT_UDW         _MMIO(0x2328 + 4)
 721#define GS_PRIMITIVES_COUNT             _MMIO(0x2330)
 722#define GS_PRIMITIVES_COUNT_UDW         _MMIO(0x2330 + 4)
 723#define CL_INVOCATION_COUNT             _MMIO(0x2338)
 724#define CL_INVOCATION_COUNT_UDW         _MMIO(0x2338 + 4)
 725#define CL_PRIMITIVES_COUNT             _MMIO(0x2340)
 726#define CL_PRIMITIVES_COUNT_UDW         _MMIO(0x2340 + 4)
 727#define PS_INVOCATION_COUNT             _MMIO(0x2348)
 728#define PS_INVOCATION_COUNT_UDW         _MMIO(0x2348 + 4)
 729#define PS_DEPTH_COUNT                  _MMIO(0x2350)
 730#define PS_DEPTH_COUNT_UDW              _MMIO(0x2350 + 4)
 731
 732/* There are the 4 64-bit counter registers, one for each stream output */
 733#define GEN7_SO_NUM_PRIMS_WRITTEN(n)            _MMIO(0x5200 + (n) * 8)
 734#define GEN7_SO_NUM_PRIMS_WRITTEN_UDW(n)        _MMIO(0x5200 + (n) * 8 + 4)
 735
 736#define GEN7_SO_PRIM_STORAGE_NEEDED(n)          _MMIO(0x5240 + (n) * 8)
 737#define GEN7_SO_PRIM_STORAGE_NEEDED_UDW(n)      _MMIO(0x5240 + (n) * 8 + 4)
 738
 739#define GEN7_3DPRIM_END_OFFSET          _MMIO(0x2420)
 740#define GEN7_3DPRIM_START_VERTEX        _MMIO(0x2430)
 741#define GEN7_3DPRIM_VERTEX_COUNT        _MMIO(0x2434)
 742#define GEN7_3DPRIM_INSTANCE_COUNT      _MMIO(0x2438)
 743#define GEN7_3DPRIM_START_INSTANCE      _MMIO(0x243C)
 744#define GEN7_3DPRIM_BASE_VERTEX         _MMIO(0x2440)
 745
 746#define GEN7_GPGPU_DISPATCHDIMX         _MMIO(0x2500)
 747#define GEN7_GPGPU_DISPATCHDIMY         _MMIO(0x2504)
 748#define GEN7_GPGPU_DISPATCHDIMZ         _MMIO(0x2508)
 749
 750/* There are the 16 64-bit CS General Purpose Registers */
 751#define HSW_CS_GPR(n)                   _MMIO(0x2600 + (n) * 8)
 752#define HSW_CS_GPR_UDW(n)               _MMIO(0x2600 + (n) * 8 + 4)
 753
 754#define GEN7_OACONTROL _MMIO(0x2360)
 755#define  GEN7_OACONTROL_CTX_MASK            0xFFFFF000
 756#define  GEN7_OACONTROL_TIMER_PERIOD_MASK   0x3F
 757#define  GEN7_OACONTROL_TIMER_PERIOD_SHIFT  6
 758#define  GEN7_OACONTROL_TIMER_ENABLE        (1<<5)
 759#define  GEN7_OACONTROL_FORMAT_A13          (0<<2)
 760#define  GEN7_OACONTROL_FORMAT_A29          (1<<2)
 761#define  GEN7_OACONTROL_FORMAT_A13_B8_C8    (2<<2)
 762#define  GEN7_OACONTROL_FORMAT_A29_B8_C8    (3<<2)
 763#define  GEN7_OACONTROL_FORMAT_B4_C8        (4<<2)
 764#define  GEN7_OACONTROL_FORMAT_A45_B8_C8    (5<<2)
 765#define  GEN7_OACONTROL_FORMAT_B4_C8_A16    (6<<2)
 766#define  GEN7_OACONTROL_FORMAT_C4_B8        (7<<2)
 767#define  GEN7_OACONTROL_FORMAT_SHIFT        2
 768#define  GEN7_OACONTROL_PER_CTX_ENABLE      (1<<1)
 769#define  GEN7_OACONTROL_ENABLE              (1<<0)
 770
 771#define GEN8_OACTXID _MMIO(0x2364)
 772
 773#define GEN8_OA_DEBUG _MMIO(0x2B04)
 774#define  GEN9_OA_DEBUG_DISABLE_CLK_RATIO_REPORTS    (1<<5)
 775#define  GEN9_OA_DEBUG_INCLUDE_CLK_RATIO            (1<<6)
 776#define  GEN9_OA_DEBUG_DISABLE_GO_1_0_REPORTS       (1<<2)
 777#define  GEN9_OA_DEBUG_DISABLE_CTX_SWITCH_REPORTS   (1<<1)
 778
 779#define GEN8_OACONTROL _MMIO(0x2B00)
 780#define  GEN8_OA_REPORT_FORMAT_A12          (0<<2)
 781#define  GEN8_OA_REPORT_FORMAT_A12_B8_C8    (2<<2)
 782#define  GEN8_OA_REPORT_FORMAT_A36_B8_C8    (5<<2)
 783#define  GEN8_OA_REPORT_FORMAT_C4_B8        (7<<2)
 784#define  GEN8_OA_REPORT_FORMAT_SHIFT        2
 785#define  GEN8_OA_SPECIFIC_CONTEXT_ENABLE    (1<<1)
 786#define  GEN8_OA_COUNTER_ENABLE             (1<<0)
 787
 788#define GEN8_OACTXCONTROL _MMIO(0x2360)
 789#define  GEN8_OA_TIMER_PERIOD_MASK          0x3F
 790#define  GEN8_OA_TIMER_PERIOD_SHIFT         2
 791#define  GEN8_OA_TIMER_ENABLE               (1<<1)
 792#define  GEN8_OA_COUNTER_RESUME             (1<<0)
 793
 794#define GEN7_OABUFFER _MMIO(0x23B0) /* R/W */
 795#define  GEN7_OABUFFER_OVERRUN_DISABLE      (1<<3)
 796#define  GEN7_OABUFFER_EDGE_TRIGGER         (1<<2)
 797#define  GEN7_OABUFFER_STOP_RESUME_ENABLE   (1<<1)
 798#define  GEN7_OABUFFER_RESUME               (1<<0)
 799
 800#define GEN8_OABUFFER_UDW _MMIO(0x23b4)
 801#define GEN8_OABUFFER _MMIO(0x2b14)
 802
 803#define GEN7_OASTATUS1 _MMIO(0x2364)
 804#define  GEN7_OASTATUS1_TAIL_MASK           0xffffffc0
 805#define  GEN7_OASTATUS1_COUNTER_OVERFLOW    (1<<2)
 806#define  GEN7_OASTATUS1_OABUFFER_OVERFLOW   (1<<1)
 807#define  GEN7_OASTATUS1_REPORT_LOST         (1<<0)
 808
 809#define GEN7_OASTATUS2 _MMIO(0x2368)
 810#define GEN7_OASTATUS2_HEAD_MASK    0xffffffc0
 811
 812#define GEN8_OASTATUS _MMIO(0x2b08)
 813#define  GEN8_OASTATUS_OVERRUN_STATUS       (1<<3)
 814#define  GEN8_OASTATUS_COUNTER_OVERFLOW     (1<<2)
 815#define  GEN8_OASTATUS_OABUFFER_OVERFLOW    (1<<1)
 816#define  GEN8_OASTATUS_REPORT_LOST          (1<<0)
 817
 818#define GEN8_OAHEADPTR _MMIO(0x2B0C)
 819#define GEN8_OAHEADPTR_MASK    0xffffffc0
 820#define GEN8_OATAILPTR _MMIO(0x2B10)
 821#define GEN8_OATAILPTR_MASK    0xffffffc0
 822
 823#define OABUFFER_SIZE_128K  (0<<3)
 824#define OABUFFER_SIZE_256K  (1<<3)
 825#define OABUFFER_SIZE_512K  (2<<3)
 826#define OABUFFER_SIZE_1M    (3<<3)
 827#define OABUFFER_SIZE_2M    (4<<3)
 828#define OABUFFER_SIZE_4M    (5<<3)
 829#define OABUFFER_SIZE_8M    (6<<3)
 830#define OABUFFER_SIZE_16M   (7<<3)
 831
 832#define OA_MEM_SELECT_GGTT  (1<<0)
 833
 834/*
 835 * Flexible, Aggregate EU Counter Registers.
 836 * Note: these aren't contiguous
 837 */
 838#define EU_PERF_CNTL0       _MMIO(0xe458)
 839#define EU_PERF_CNTL1       _MMIO(0xe558)
 840#define EU_PERF_CNTL2       _MMIO(0xe658)
 841#define EU_PERF_CNTL3       _MMIO(0xe758)
 842#define EU_PERF_CNTL4       _MMIO(0xe45c)
 843#define EU_PERF_CNTL5       _MMIO(0xe55c)
 844#define EU_PERF_CNTL6       _MMIO(0xe65c)
 845
 846/*
 847 * OA Boolean state
 848 */
 849
 850#define OASTARTTRIG1 _MMIO(0x2710)
 851#define OASTARTTRIG1_THRESHOLD_COUNT_MASK_MBZ 0xffff0000
 852#define OASTARTTRIG1_THRESHOLD_MASK           0xffff
 853
 854#define OASTARTTRIG2 _MMIO(0x2714)
 855#define OASTARTTRIG2_INVERT_A_0 (1<<0)
 856#define OASTARTTRIG2_INVERT_A_1 (1<<1)
 857#define OASTARTTRIG2_INVERT_A_2 (1<<2)
 858#define OASTARTTRIG2_INVERT_A_3 (1<<3)
 859#define OASTARTTRIG2_INVERT_A_4 (1<<4)
 860#define OASTARTTRIG2_INVERT_A_5 (1<<5)
 861#define OASTARTTRIG2_INVERT_A_6 (1<<6)
 862#define OASTARTTRIG2_INVERT_A_7 (1<<7)
 863#define OASTARTTRIG2_INVERT_A_8 (1<<8)
 864#define OASTARTTRIG2_INVERT_A_9 (1<<9)
 865#define OASTARTTRIG2_INVERT_A_10 (1<<10)
 866#define OASTARTTRIG2_INVERT_A_11 (1<<11)
 867#define OASTARTTRIG2_INVERT_A_12 (1<<12)
 868#define OASTARTTRIG2_INVERT_A_13 (1<<13)
 869#define OASTARTTRIG2_INVERT_A_14 (1<<14)
 870#define OASTARTTRIG2_INVERT_A_15 (1<<15)
 871#define OASTARTTRIG2_INVERT_B_0 (1<<16)
 872#define OASTARTTRIG2_INVERT_B_1 (1<<17)
 873#define OASTARTTRIG2_INVERT_B_2 (1<<18)
 874#define OASTARTTRIG2_INVERT_B_3 (1<<19)
 875#define OASTARTTRIG2_INVERT_C_0 (1<<20)
 876#define OASTARTTRIG2_INVERT_C_1 (1<<21)
 877#define OASTARTTRIG2_INVERT_D_0 (1<<22)
 878#define OASTARTTRIG2_THRESHOLD_ENABLE       (1<<23)
 879#define OASTARTTRIG2_START_TRIG_FLAG_MBZ    (1<<24)
 880#define OASTARTTRIG2_EVENT_SELECT_0  (1<<28)
 881#define OASTARTTRIG2_EVENT_SELECT_1  (1<<29)
 882#define OASTARTTRIG2_EVENT_SELECT_2  (1<<30)
 883#define OASTARTTRIG2_EVENT_SELECT_3  (1<<31)
 884
 885#define OASTARTTRIG3 _MMIO(0x2718)
 886#define OASTARTTRIG3_NOA_SELECT_MASK       0xf
 887#define OASTARTTRIG3_NOA_SELECT_8_SHIFT    0
 888#define OASTARTTRIG3_NOA_SELECT_9_SHIFT    4
 889#define OASTARTTRIG3_NOA_SELECT_10_SHIFT   8
 890#define OASTARTTRIG3_NOA_SELECT_11_SHIFT   12
 891#define OASTARTTRIG3_NOA_SELECT_12_SHIFT   16
 892#define OASTARTTRIG3_NOA_SELECT_13_SHIFT   20
 893#define OASTARTTRIG3_NOA_SELECT_14_SHIFT   24
 894#define OASTARTTRIG3_NOA_SELECT_15_SHIFT   28
 895
 896#define OASTARTTRIG4 _MMIO(0x271c)
 897#define OASTARTTRIG4_NOA_SELECT_MASK        0xf
 898#define OASTARTTRIG4_NOA_SELECT_0_SHIFT    0
 899#define OASTARTTRIG4_NOA_SELECT_1_SHIFT    4
 900#define OASTARTTRIG4_NOA_SELECT_2_SHIFT    8
 901#define OASTARTTRIG4_NOA_SELECT_3_SHIFT    12
 902#define OASTARTTRIG4_NOA_SELECT_4_SHIFT    16
 903#define OASTARTTRIG4_NOA_SELECT_5_SHIFT    20
 904#define OASTARTTRIG4_NOA_SELECT_6_SHIFT    24
 905#define OASTARTTRIG4_NOA_SELECT_7_SHIFT    28
 906
 907#define OASTARTTRIG5 _MMIO(0x2720)
 908#define OASTARTTRIG5_THRESHOLD_COUNT_MASK_MBZ 0xffff0000
 909#define OASTARTTRIG5_THRESHOLD_MASK           0xffff
 910
 911#define OASTARTTRIG6 _MMIO(0x2724)
 912#define OASTARTTRIG6_INVERT_A_0 (1<<0)
 913#define OASTARTTRIG6_INVERT_A_1 (1<<1)
 914#define OASTARTTRIG6_INVERT_A_2 (1<<2)
 915#define OASTARTTRIG6_INVERT_A_3 (1<<3)
 916#define OASTARTTRIG6_INVERT_A_4 (1<<4)
 917#define OASTARTTRIG6_INVERT_A_5 (1<<5)
 918#define OASTARTTRIG6_INVERT_A_6 (1<<6)
 919#define OASTARTTRIG6_INVERT_A_7 (1<<7)
 920#define OASTARTTRIG6_INVERT_A_8 (1<<8)
 921#define OASTARTTRIG6_INVERT_A_9 (1<<9)
 922#define OASTARTTRIG6_INVERT_A_10 (1<<10)
 923#define OASTARTTRIG6_INVERT_A_11 (1<<11)
 924#define OASTARTTRIG6_INVERT_A_12 (1<<12)
 925#define OASTARTTRIG6_INVERT_A_13 (1<<13)
 926#define OASTARTTRIG6_INVERT_A_14 (1<<14)
 927#define OASTARTTRIG6_INVERT_A_15 (1<<15)
 928#define OASTARTTRIG6_INVERT_B_0 (1<<16)
 929#define OASTARTTRIG6_INVERT_B_1 (1<<17)
 930#define OASTARTTRIG6_INVERT_B_2 (1<<18)
 931#define OASTARTTRIG6_INVERT_B_3 (1<<19)
 932#define OASTARTTRIG6_INVERT_C_0 (1<<20)
 933#define OASTARTTRIG6_INVERT_C_1 (1<<21)
 934#define OASTARTTRIG6_INVERT_D_0 (1<<22)
 935#define OASTARTTRIG6_THRESHOLD_ENABLE       (1<<23)
 936#define OASTARTTRIG6_START_TRIG_FLAG_MBZ    (1<<24)
 937#define OASTARTTRIG6_EVENT_SELECT_4  (1<<28)
 938#define OASTARTTRIG6_EVENT_SELECT_5  (1<<29)
 939#define OASTARTTRIG6_EVENT_SELECT_6  (1<<30)
 940#define OASTARTTRIG6_EVENT_SELECT_7  (1<<31)
 941
 942#define OASTARTTRIG7 _MMIO(0x2728)
 943#define OASTARTTRIG7_NOA_SELECT_MASK       0xf
 944#define OASTARTTRIG7_NOA_SELECT_8_SHIFT    0
 945#define OASTARTTRIG7_NOA_SELECT_9_SHIFT    4
 946#define OASTARTTRIG7_NOA_SELECT_10_SHIFT   8
 947#define OASTARTTRIG7_NOA_SELECT_11_SHIFT   12
 948#define OASTARTTRIG7_NOA_SELECT_12_SHIFT   16
 949#define OASTARTTRIG7_NOA_SELECT_13_SHIFT   20
 950#define OASTARTTRIG7_NOA_SELECT_14_SHIFT   24
 951#define OASTARTTRIG7_NOA_SELECT_15_SHIFT   28
 952
 953#define OASTARTTRIG8 _MMIO(0x272c)
 954#define OASTARTTRIG8_NOA_SELECT_MASK       0xf
 955#define OASTARTTRIG8_NOA_SELECT_0_SHIFT    0
 956#define OASTARTTRIG8_NOA_SELECT_1_SHIFT    4
 957#define OASTARTTRIG8_NOA_SELECT_2_SHIFT    8
 958#define OASTARTTRIG8_NOA_SELECT_3_SHIFT    12
 959#define OASTARTTRIG8_NOA_SELECT_4_SHIFT    16
 960#define OASTARTTRIG8_NOA_SELECT_5_SHIFT    20
 961#define OASTARTTRIG8_NOA_SELECT_6_SHIFT    24
 962#define OASTARTTRIG8_NOA_SELECT_7_SHIFT    28
 963
 964#define OAREPORTTRIG1 _MMIO(0x2740)
 965#define OAREPORTTRIG1_THRESHOLD_MASK 0xffff
 966#define OAREPORTTRIG1_EDGE_LEVEL_TRIGER_SELECT_MASK 0xffff0000 /* 0=level */
 967
 968#define OAREPORTTRIG2 _MMIO(0x2744)
 969#define OAREPORTTRIG2_INVERT_A_0  (1<<0)
 970#define OAREPORTTRIG2_INVERT_A_1  (1<<1)
 971#define OAREPORTTRIG2_INVERT_A_2  (1<<2)
 972#define OAREPORTTRIG2_INVERT_A_3  (1<<3)
 973#define OAREPORTTRIG2_INVERT_A_4  (1<<4)
 974#define OAREPORTTRIG2_INVERT_A_5  (1<<5)
 975#define OAREPORTTRIG2_INVERT_A_6  (1<<6)
 976#define OAREPORTTRIG2_INVERT_A_7  (1<<7)
 977#define OAREPORTTRIG2_INVERT_A_8  (1<<8)
 978#define OAREPORTTRIG2_INVERT_A_9  (1<<9)
 979#define OAREPORTTRIG2_INVERT_A_10 (1<<10)
 980#define OAREPORTTRIG2_INVERT_A_11 (1<<11)
 981#define OAREPORTTRIG2_INVERT_A_12 (1<<12)
 982#define OAREPORTTRIG2_INVERT_A_13 (1<<13)
 983#define OAREPORTTRIG2_INVERT_A_14 (1<<14)
 984#define OAREPORTTRIG2_INVERT_A_15 (1<<15)
 985#define OAREPORTTRIG2_INVERT_B_0  (1<<16)
 986#define OAREPORTTRIG2_INVERT_B_1  (1<<17)
 987#define OAREPORTTRIG2_INVERT_B_2  (1<<18)
 988#define OAREPORTTRIG2_INVERT_B_3  (1<<19)
 989#define OAREPORTTRIG2_INVERT_C_0  (1<<20)
 990#define OAREPORTTRIG2_INVERT_C_1  (1<<21)
 991#define OAREPORTTRIG2_INVERT_D_0  (1<<22)
 992#define OAREPORTTRIG2_THRESHOLD_ENABLE      (1<<23)
 993#define OAREPORTTRIG2_REPORT_TRIGGER_ENABLE (1<<31)
 994
 995#define OAREPORTTRIG3 _MMIO(0x2748)
 996#define OAREPORTTRIG3_NOA_SELECT_MASK       0xf
 997#define OAREPORTTRIG3_NOA_SELECT_8_SHIFT    0
 998#define OAREPORTTRIG3_NOA_SELECT_9_SHIFT    4
 999#define OAREPORTTRIG3_NOA_SELECT_10_SHIFT   8
1000#define OAREPORTTRIG3_NOA_SELECT_11_SHIFT   12
1001#define OAREPORTTRIG3_NOA_SELECT_12_SHIFT   16
1002#define OAREPORTTRIG3_NOA_SELECT_13_SHIFT   20
1003#define OAREPORTTRIG3_NOA_SELECT_14_SHIFT   24
1004#define OAREPORTTRIG3_NOA_SELECT_15_SHIFT   28
1005
1006#define OAREPORTTRIG4 _MMIO(0x274c)
1007#define OAREPORTTRIG4_NOA_SELECT_MASK       0xf
1008#define OAREPORTTRIG4_NOA_SELECT_0_SHIFT    0
1009#define OAREPORTTRIG4_NOA_SELECT_1_SHIFT    4
1010#define OAREPORTTRIG4_NOA_SELECT_2_SHIFT    8
1011#define OAREPORTTRIG4_NOA_SELECT_3_SHIFT    12
1012#define OAREPORTTRIG4_NOA_SELECT_4_SHIFT    16
1013#define OAREPORTTRIG4_NOA_SELECT_5_SHIFT    20
1014#define OAREPORTTRIG4_NOA_SELECT_6_SHIFT    24
1015#define OAREPORTTRIG4_NOA_SELECT_7_SHIFT    28
1016
1017#define OAREPORTTRIG5 _MMIO(0x2750)
1018#define OAREPORTTRIG5_THRESHOLD_MASK 0xffff
1019#define OAREPORTTRIG5_EDGE_LEVEL_TRIGER_SELECT_MASK 0xffff0000 /* 0=level */
1020
1021#define OAREPORTTRIG6 _MMIO(0x2754)
1022#define OAREPORTTRIG6_INVERT_A_0  (1<<0)
1023#define OAREPORTTRIG6_INVERT_A_1  (1<<1)
1024#define OAREPORTTRIG6_INVERT_A_2  (1<<2)
1025#define OAREPORTTRIG6_INVERT_A_3  (1<<3)
1026#define OAREPORTTRIG6_INVERT_A_4  (1<<4)
1027#define OAREPORTTRIG6_INVERT_A_5  (1<<5)
1028#define OAREPORTTRIG6_INVERT_A_6  (1<<6)
1029#define OAREPORTTRIG6_INVERT_A_7  (1<<7)
1030#define OAREPORTTRIG6_INVERT_A_8  (1<<8)
1031#define OAREPORTTRIG6_INVERT_A_9  (1<<9)
1032#define OAREPORTTRIG6_INVERT_A_10 (1<<10)
1033#define OAREPORTTRIG6_INVERT_A_11 (1<<11)
1034#define OAREPORTTRIG6_INVERT_A_12 (1<<12)
1035#define OAREPORTTRIG6_INVERT_A_13 (1<<13)
1036#define OAREPORTTRIG6_INVERT_A_14 (1<<14)
1037#define OAREPORTTRIG6_INVERT_A_15 (1<<15)
1038#define OAREPORTTRIG6_INVERT_B_0  (1<<16)
1039#define OAREPORTTRIG6_INVERT_B_1  (1<<17)
1040#define OAREPORTTRIG6_INVERT_B_2  (1<<18)
1041#define OAREPORTTRIG6_INVERT_B_3  (1<<19)
1042#define OAREPORTTRIG6_INVERT_C_0  (1<<20)
1043#define OAREPORTTRIG6_INVERT_C_1  (1<<21)
1044#define OAREPORTTRIG6_INVERT_D_0  (1<<22)
1045#define OAREPORTTRIG6_THRESHOLD_ENABLE      (1<<23)
1046#define OAREPORTTRIG6_REPORT_TRIGGER_ENABLE (1<<31)
1047
1048#define OAREPORTTRIG7 _MMIO(0x2758)
1049#define OAREPORTTRIG7_NOA_SELECT_MASK       0xf
1050#define OAREPORTTRIG7_NOA_SELECT_8_SHIFT    0
1051#define OAREPORTTRIG7_NOA_SELECT_9_SHIFT    4
1052#define OAREPORTTRIG7_NOA_SELECT_10_SHIFT   8
1053#define OAREPORTTRIG7_NOA_SELECT_11_SHIFT   12
1054#define OAREPORTTRIG7_NOA_SELECT_12_SHIFT   16
1055#define OAREPORTTRIG7_NOA_SELECT_13_SHIFT   20
1056#define OAREPORTTRIG7_NOA_SELECT_14_SHIFT   24
1057#define OAREPORTTRIG7_NOA_SELECT_15_SHIFT   28
1058
1059#define OAREPORTTRIG8 _MMIO(0x275c)
1060#define OAREPORTTRIG8_NOA_SELECT_MASK       0xf
1061#define OAREPORTTRIG8_NOA_SELECT_0_SHIFT    0
1062#define OAREPORTTRIG8_NOA_SELECT_1_SHIFT    4
1063#define OAREPORTTRIG8_NOA_SELECT_2_SHIFT    8
1064#define OAREPORTTRIG8_NOA_SELECT_3_SHIFT    12
1065#define OAREPORTTRIG8_NOA_SELECT_4_SHIFT    16
1066#define OAREPORTTRIG8_NOA_SELECT_5_SHIFT    20
1067#define OAREPORTTRIG8_NOA_SELECT_6_SHIFT    24
1068#define OAREPORTTRIG8_NOA_SELECT_7_SHIFT    28
1069
1070/* CECX_0 */
1071#define OACEC_COMPARE_LESS_OR_EQUAL     6
1072#define OACEC_COMPARE_NOT_EQUAL         5
1073#define OACEC_COMPARE_LESS_THAN         4
1074#define OACEC_COMPARE_GREATER_OR_EQUAL  3
1075#define OACEC_COMPARE_EQUAL             2
1076#define OACEC_COMPARE_GREATER_THAN      1
1077#define OACEC_COMPARE_ANY_EQUAL         0
1078
1079#define OACEC_COMPARE_VALUE_MASK    0xffff
1080#define OACEC_COMPARE_VALUE_SHIFT   3
1081
1082#define OACEC_SELECT_NOA        (0<<19)
1083#define OACEC_SELECT_PREV       (1<<19)
1084#define OACEC_SELECT_BOOLEAN    (2<<19)
1085
1086/* CECX_1 */
1087#define OACEC_MASK_MASK             0xffff
1088#define OACEC_CONSIDERATIONS_MASK   0xffff
1089#define OACEC_CONSIDERATIONS_SHIFT  16
1090
1091#define OACEC0_0 _MMIO(0x2770)
1092#define OACEC0_1 _MMIO(0x2774)
1093#define OACEC1_0 _MMIO(0x2778)
1094#define OACEC1_1 _MMIO(0x277c)
1095#define OACEC2_0 _MMIO(0x2780)
1096#define OACEC2_1 _MMIO(0x2784)
1097#define OACEC3_0 _MMIO(0x2788)
1098#define OACEC3_1 _MMIO(0x278c)
1099#define OACEC4_0 _MMIO(0x2790)
1100#define OACEC4_1 _MMIO(0x2794)
1101#define OACEC5_0 _MMIO(0x2798)
1102#define OACEC5_1 _MMIO(0x279c)
1103#define OACEC6_0 _MMIO(0x27a0)
1104#define OACEC6_1 _MMIO(0x27a4)
1105#define OACEC7_0 _MMIO(0x27a8)
1106#define OACEC7_1 _MMIO(0x27ac)
1107
1108/* OA perf counters */
1109#define OA_PERFCNT1_LO      _MMIO(0x91B8)
1110#define OA_PERFCNT1_HI      _MMIO(0x91BC)
1111#define OA_PERFCNT2_LO      _MMIO(0x91C0)
1112#define OA_PERFCNT2_HI      _MMIO(0x91C4)
1113#define OA_PERFCNT3_LO      _MMIO(0x91C8)
1114#define OA_PERFCNT3_HI      _MMIO(0x91CC)
1115#define OA_PERFCNT4_LO      _MMIO(0x91D8)
1116#define OA_PERFCNT4_HI      _MMIO(0x91DC)
1117
1118#define OA_PERFMATRIX_LO    _MMIO(0x91C8)
1119#define OA_PERFMATRIX_HI    _MMIO(0x91CC)
1120
1121/* RPM unit config (Gen8+) */
1122#define RPM_CONFIG0         _MMIO(0x0D00)
1123#define  GEN9_RPM_CONFIG0_CRYSTAL_CLOCK_FREQ_SHIFT      3
1124#define  GEN9_RPM_CONFIG0_CRYSTAL_CLOCK_FREQ_MASK       (1 << GEN9_RPM_CONFIG0_CRYSTAL_CLOCK_FREQ_SHIFT)
1125#define  GEN9_RPM_CONFIG0_CRYSTAL_CLOCK_FREQ_19_2_MHZ   0
1126#define  GEN9_RPM_CONFIG0_CRYSTAL_CLOCK_FREQ_24_MHZ     1
1127#define  GEN10_RPM_CONFIG0_CTC_SHIFT_PARAMETER_SHIFT    1
1128#define  GEN10_RPM_CONFIG0_CTC_SHIFT_PARAMETER_MASK     (0x3 << GEN10_RPM_CONFIG0_CTC_SHIFT_PARAMETER_SHIFT)
1129
1130#define RPM_CONFIG1         _MMIO(0x0D04)
1131#define  GEN10_GT_NOA_ENABLE  (1 << 9)
1132
1133/* GPM unit config (Gen9+) */
1134#define CTC_MODE                        _MMIO(0xA26C)
1135#define  CTC_SOURCE_PARAMETER_MASK 1
1136#define  CTC_SOURCE_CRYSTAL_CLOCK       0
1137#define  CTC_SOURCE_DIVIDE_LOGIC        1
1138#define  CTC_SHIFT_PARAMETER_SHIFT      1
1139#define  CTC_SHIFT_PARAMETER_MASK       (0x3 << CTC_SHIFT_PARAMETER_SHIFT)
1140
1141/* RCP unit config (Gen8+) */
1142#define RCP_CONFIG          _MMIO(0x0D08)
1143
1144/* NOA (HSW) */
1145#define HSW_MBVID2_NOA0         _MMIO(0x9E80)
1146#define HSW_MBVID2_NOA1         _MMIO(0x9E84)
1147#define HSW_MBVID2_NOA2         _MMIO(0x9E88)
1148#define HSW_MBVID2_NOA3         _MMIO(0x9E8C)
1149#define HSW_MBVID2_NOA4         _MMIO(0x9E90)
1150#define HSW_MBVID2_NOA5         _MMIO(0x9E94)
1151#define HSW_MBVID2_NOA6         _MMIO(0x9E98)
1152#define HSW_MBVID2_NOA7         _MMIO(0x9E9C)
1153#define HSW_MBVID2_NOA8         _MMIO(0x9EA0)
1154#define HSW_MBVID2_NOA9         _MMIO(0x9EA4)
1155
1156#define HSW_MBVID2_MISR0        _MMIO(0x9EC0)
1157
1158/* NOA (Gen8+) */
1159#define NOA_CONFIG(i)       _MMIO(0x0D0C + (i) * 4)
1160
1161#define MICRO_BP0_0         _MMIO(0x9800)
1162#define MICRO_BP0_2         _MMIO(0x9804)
1163#define MICRO_BP0_1         _MMIO(0x9808)
1164
1165#define MICRO_BP1_0         _MMIO(0x980C)
1166#define MICRO_BP1_2         _MMIO(0x9810)
1167#define MICRO_BP1_1         _MMIO(0x9814)
1168
1169#define MICRO_BP2_0         _MMIO(0x9818)
1170#define MICRO_BP2_2         _MMIO(0x981C)
1171#define MICRO_BP2_1         _MMIO(0x9820)
1172
1173#define MICRO_BP3_0         _MMIO(0x9824)
1174#define MICRO_BP3_2         _MMIO(0x9828)
1175#define MICRO_BP3_1         _MMIO(0x982C)
1176
1177#define MICRO_BP_TRIGGER                _MMIO(0x9830)
1178#define MICRO_BP3_COUNT_STATUS01        _MMIO(0x9834)
1179#define MICRO_BP3_COUNT_STATUS23        _MMIO(0x9838)
1180#define MICRO_BP_FIRED_ARMED            _MMIO(0x983C)
1181
1182#define GDT_CHICKEN_BITS    _MMIO(0x9840)
1183#define   GT_NOA_ENABLE     0x00000080
1184
1185#define NOA_DATA            _MMIO(0x986C)
1186#define NOA_WRITE           _MMIO(0x9888)
1187
1188#define _GEN7_PIPEA_DE_LOAD_SL  0x70068
1189#define _GEN7_PIPEB_DE_LOAD_SL  0x71068
1190#define GEN7_PIPE_DE_LOAD_SL(pipe) _MMIO_PIPE(pipe, _GEN7_PIPEA_DE_LOAD_SL, _GEN7_PIPEB_DE_LOAD_SL)
1191
1192/*
1193 * Reset registers
1194 */
1195#define DEBUG_RESET_I830                _MMIO(0x6070)
1196#define  DEBUG_RESET_FULL               (1<<7)
1197#define  DEBUG_RESET_RENDER             (1<<8)
1198#define  DEBUG_RESET_DISPLAY            (1<<9)
1199
1200/*
1201 * IOSF sideband
1202 */
1203#define VLV_IOSF_DOORBELL_REQ                   _MMIO(VLV_DISPLAY_BASE + 0x2100)
1204#define   IOSF_DEVFN_SHIFT                      24
1205#define   IOSF_OPCODE_SHIFT                     16
1206#define   IOSF_PORT_SHIFT                       8
1207#define   IOSF_BYTE_ENABLES_SHIFT               4
1208#define   IOSF_BAR_SHIFT                        1
1209#define   IOSF_SB_BUSY                          (1<<0)
1210#define   IOSF_PORT_BUNIT                       0x03
1211#define   IOSF_PORT_PUNIT                       0x04
1212#define   IOSF_PORT_NC                          0x11
1213#define   IOSF_PORT_DPIO                        0x12
1214#define   IOSF_PORT_GPIO_NC                     0x13
1215#define   IOSF_PORT_CCK                         0x14
1216#define   IOSF_PORT_DPIO_2                      0x1a
1217#define   IOSF_PORT_FLISDSI                     0x1b
1218#define   IOSF_PORT_GPIO_SC                     0x48
1219#define   IOSF_PORT_GPIO_SUS                    0xa8
1220#define   IOSF_PORT_CCU                         0xa9
1221#define   CHV_IOSF_PORT_GPIO_N                  0x13
1222#define   CHV_IOSF_PORT_GPIO_SE                 0x48
1223#define   CHV_IOSF_PORT_GPIO_E                  0xa8
1224#define   CHV_IOSF_PORT_GPIO_SW                 0xb2
1225#define VLV_IOSF_DATA                           _MMIO(VLV_DISPLAY_BASE + 0x2104)
1226#define VLV_IOSF_ADDR                           _MMIO(VLV_DISPLAY_BASE + 0x2108)
1227
1228/* See configdb bunit SB addr map */
1229#define BUNIT_REG_BISOC                         0x11
1230
1231#define PUNIT_REG_DSPFREQ                       0x36
1232#define   DSPFREQSTAT_SHIFT_CHV                 24
1233#define   DSPFREQSTAT_MASK_CHV                  (0x1f << DSPFREQSTAT_SHIFT_CHV)
1234#define   DSPFREQGUAR_SHIFT_CHV                 8
1235#define   DSPFREQGUAR_MASK_CHV                  (0x1f << DSPFREQGUAR_SHIFT_CHV)
1236#define   DSPFREQSTAT_SHIFT                     30
1237#define   DSPFREQSTAT_MASK                      (0x3 << DSPFREQSTAT_SHIFT)
1238#define   DSPFREQGUAR_SHIFT                     14
1239#define   DSPFREQGUAR_MASK                      (0x3 << DSPFREQGUAR_SHIFT)
1240#define   DSP_MAXFIFO_PM5_STATUS                (1 << 22) /* chv */
1241#define   DSP_AUTO_CDCLK_GATE_DISABLE           (1 << 7) /* chv */
1242#define   DSP_MAXFIFO_PM5_ENABLE                (1 << 6) /* chv */
1243#define   _DP_SSC(val, pipe)                    ((val) << (2 * (pipe)))
1244#define   DP_SSC_MASK(pipe)                     _DP_SSC(0x3, (pipe))
1245#define   DP_SSC_PWR_ON(pipe)                   _DP_SSC(0x0, (pipe))
1246#define   DP_SSC_CLK_GATE(pipe)                 _DP_SSC(0x1, (pipe))
1247#define   DP_SSC_RESET(pipe)                    _DP_SSC(0x2, (pipe))
1248#define   DP_SSC_PWR_GATE(pipe)                 _DP_SSC(0x3, (pipe))
1249#define   _DP_SSS(val, pipe)                    ((val) << (2 * (pipe) + 16))
1250#define   DP_SSS_MASK(pipe)                     _DP_SSS(0x3, (pipe))
1251#define   DP_SSS_PWR_ON(pipe)                   _DP_SSS(0x0, (pipe))
1252#define   DP_SSS_CLK_GATE(pipe)                 _DP_SSS(0x1, (pipe))
1253#define   DP_SSS_RESET(pipe)                    _DP_SSS(0x2, (pipe))
1254#define   DP_SSS_PWR_GATE(pipe)                 _DP_SSS(0x3, (pipe))
1255
1256/*
1257 * i915_power_well_id:
1258 *
1259 * Platform specific IDs used to look up power wells and - except for custom
1260 * power wells - to define request/status register flag bit positions. As such
1261 * the set of IDs on a given platform must be unique and except for custom
1262 * power wells their value must stay fixed.
1263 */
1264enum i915_power_well_id {
1265        /*
1266         * I830
1267         *  - custom power well
1268         */
1269        I830_DISP_PW_PIPES = 0,
1270
1271        /*
1272         * VLV/CHV
1273         *  - PUNIT_REG_PWRGT_CTRL (bit: id*2),
1274         *    PUNIT_REG_PWRGT_STATUS (bit: id*2) (PUNIT HAS v0.8)
1275         */
1276        PUNIT_POWER_WELL_RENDER                 = 0,
1277        PUNIT_POWER_WELL_MEDIA                  = 1,
1278        PUNIT_POWER_WELL_DISP2D                 = 3,
1279        PUNIT_POWER_WELL_DPIO_CMN_BC            = 5,
1280        PUNIT_POWER_WELL_DPIO_TX_B_LANES_01     = 6,
1281        PUNIT_POWER_WELL_DPIO_TX_B_LANES_23     = 7,
1282        PUNIT_POWER_WELL_DPIO_TX_C_LANES_01     = 8,
1283        PUNIT_POWER_WELL_DPIO_TX_C_LANES_23     = 9,
1284        PUNIT_POWER_WELL_DPIO_RX0               = 10,
1285        PUNIT_POWER_WELL_DPIO_RX1               = 11,
1286        PUNIT_POWER_WELL_DPIO_CMN_D             = 12,
1287        /*  - custom power well */
1288        CHV_DISP_PW_PIPE_A,                     /* 13 */
1289
1290        /*
1291         * HSW/BDW
1292         *  - HSW_PWR_WELL_CTL_DRIVER(0) (status bit: id*2, req bit: id*2+1)
1293         */
1294        HSW_DISP_PW_GLOBAL = 15,
1295
1296        /*
1297         * GEN9+
1298         *  - HSW_PWR_WELL_CTL_DRIVER(0) (status bit: id*2, req bit: id*2+1)
1299         */
1300        SKL_DISP_PW_MISC_IO = 0,
1301        SKL_DISP_PW_DDI_A_E,
1302        GLK_DISP_PW_DDI_A = SKL_DISP_PW_DDI_A_E,
1303        CNL_DISP_PW_DDI_A = SKL_DISP_PW_DDI_A_E,
1304        SKL_DISP_PW_DDI_B,
1305        SKL_DISP_PW_DDI_C,
1306        SKL_DISP_PW_DDI_D,
1307
1308        GLK_DISP_PW_AUX_A = 8,
1309        GLK_DISP_PW_AUX_B,
1310        GLK_DISP_PW_AUX_C,
1311        CNL_DISP_PW_AUX_A = GLK_DISP_PW_AUX_A,
1312        CNL_DISP_PW_AUX_B = GLK_DISP_PW_AUX_B,
1313        CNL_DISP_PW_AUX_C = GLK_DISP_PW_AUX_C,
1314        CNL_DISP_PW_AUX_D,
1315
1316        SKL_DISP_PW_1 = 14,
1317        SKL_DISP_PW_2,
1318
1319        /* - custom power wells */
1320        SKL_DISP_PW_DC_OFF,
1321        BXT_DPIO_CMN_A,
1322        BXT_DPIO_CMN_BC,
1323        GLK_DPIO_CMN_C,                 /* 19 */
1324
1325        /*
1326         * Multiple platforms.
1327         * Must start following the highest ID of any platform.
1328         * - custom power wells
1329         */
1330        I915_DISP_PW_ALWAYS_ON = 20,
1331};
1332
1333#define PUNIT_REG_PWRGT_CTRL                    0x60
1334#define PUNIT_REG_PWRGT_STATUS                  0x61
1335#define   PUNIT_PWRGT_MASK(power_well)          (3 << ((power_well) * 2))
1336#define   PUNIT_PWRGT_PWR_ON(power_well)        (0 << ((power_well) * 2))
1337#define   PUNIT_PWRGT_CLK_GATE(power_well)      (1 << ((power_well) * 2))
1338#define   PUNIT_PWRGT_RESET(power_well)         (2 << ((power_well) * 2))
1339#define   PUNIT_PWRGT_PWR_GATE(power_well)      (3 << ((power_well) * 2))
1340
1341#define PUNIT_REG_GPU_LFM                       0xd3
1342#define PUNIT_REG_GPU_FREQ_REQ                  0xd4
1343#define PUNIT_REG_GPU_FREQ_STS                  0xd8
1344#define   GPLLENABLE                            (1<<4)
1345#define   GENFREQSTATUS                         (1<<0)
1346#define PUNIT_REG_MEDIA_TURBO_FREQ_REQ          0xdc
1347#define PUNIT_REG_CZ_TIMESTAMP                  0xce
1348
1349#define PUNIT_FUSE_BUS2                         0xf6 /* bits 47:40 */
1350#define PUNIT_FUSE_BUS1                         0xf5 /* bits 55:48 */
1351
1352#define FB_GFX_FMAX_AT_VMAX_FUSE                0x136
1353#define FB_GFX_FREQ_FUSE_MASK                   0xff
1354#define FB_GFX_FMAX_AT_VMAX_2SS4EU_FUSE_SHIFT   24
1355#define FB_GFX_FMAX_AT_VMAX_2SS6EU_FUSE_SHIFT   16
1356#define FB_GFX_FMAX_AT_VMAX_2SS8EU_FUSE_SHIFT   8
1357
1358#define FB_GFX_FMIN_AT_VMIN_FUSE                0x137
1359#define FB_GFX_FMIN_AT_VMIN_FUSE_SHIFT          8
1360
1361#define PUNIT_REG_DDR_SETUP2                    0x139
1362#define   FORCE_DDR_FREQ_REQ_ACK                (1 << 8)
1363#define   FORCE_DDR_LOW_FREQ                    (1 << 1)
1364#define   FORCE_DDR_HIGH_FREQ                   (1 << 0)
1365
1366#define PUNIT_GPU_STATUS_REG                    0xdb
1367#define PUNIT_GPU_STATUS_MAX_FREQ_SHIFT 16
1368#define PUNIT_GPU_STATUS_MAX_FREQ_MASK          0xff
1369#define PUNIT_GPU_STATIS_GFX_MIN_FREQ_SHIFT     8
1370#define PUNIT_GPU_STATUS_GFX_MIN_FREQ_MASK      0xff
1371
1372#define PUNIT_GPU_DUTYCYCLE_REG         0xdf
1373#define PUNIT_GPU_DUTYCYCLE_RPE_FREQ_SHIFT      8
1374#define PUNIT_GPU_DUTYCYCLE_RPE_FREQ_MASK       0xff
1375
1376#define IOSF_NC_FB_GFX_FREQ_FUSE                0x1c
1377#define   FB_GFX_MAX_FREQ_FUSE_SHIFT            3
1378#define   FB_GFX_MAX_FREQ_FUSE_MASK             0x000007f8
1379#define   FB_GFX_FGUARANTEED_FREQ_FUSE_SHIFT    11
1380#define   FB_GFX_FGUARANTEED_FREQ_FUSE_MASK     0x0007f800
1381#define IOSF_NC_FB_GFX_FMAX_FUSE_HI             0x34
1382#define   FB_FMAX_VMIN_FREQ_HI_MASK             0x00000007
1383#define IOSF_NC_FB_GFX_FMAX_FUSE_LO             0x30
1384#define   FB_FMAX_VMIN_FREQ_LO_SHIFT            27
1385#define   FB_FMAX_VMIN_FREQ_LO_MASK             0xf8000000
1386
1387#define VLV_TURBO_SOC_OVERRIDE  0x04
1388#define         VLV_OVERRIDE_EN 1
1389#define         VLV_SOC_TDP_EN  (1 << 1)
1390#define         VLV_BIAS_CPU_125_SOC_875 (6 << 2)
1391#define         CHV_BIAS_CPU_50_SOC_50 (3 << 2)
1392
1393/* vlv2 north clock has */
1394#define CCK_FUSE_REG                            0x8
1395#define  CCK_FUSE_HPLL_FREQ_MASK                0x3
1396#define CCK_REG_DSI_PLL_FUSE                    0x44
1397#define CCK_REG_DSI_PLL_CONTROL                 0x48
1398#define  DSI_PLL_VCO_EN                         (1 << 31)
1399#define  DSI_PLL_LDO_GATE                       (1 << 30)
1400#define  DSI_PLL_P1_POST_DIV_SHIFT              17
1401#define  DSI_PLL_P1_POST_DIV_MASK               (0x1ff << 17)
1402#define  DSI_PLL_P2_MUX_DSI0_DIV2               (1 << 13)
1403#define  DSI_PLL_P3_MUX_DSI1_DIV2               (1 << 12)
1404#define  DSI_PLL_MUX_MASK                       (3 << 9)
1405#define  DSI_PLL_MUX_DSI0_DSIPLL                (0 << 10)
1406#define  DSI_PLL_MUX_DSI0_CCK                   (1 << 10)
1407#define  DSI_PLL_MUX_DSI1_DSIPLL                (0 << 9)
1408#define  DSI_PLL_MUX_DSI1_CCK                   (1 << 9)
1409#define  DSI_PLL_CLK_GATE_MASK                  (0xf << 5)
1410#define  DSI_PLL_CLK_GATE_DSI0_DSIPLL           (1 << 8)
1411#define  DSI_PLL_CLK_GATE_DSI1_DSIPLL           (1 << 7)
1412#define  DSI_PLL_CLK_GATE_DSI0_CCK              (1 << 6)
1413#define  DSI_PLL_CLK_GATE_DSI1_CCK              (1 << 5)
1414#define  DSI_PLL_LOCK                           (1 << 0)
1415#define CCK_REG_DSI_PLL_DIVIDER                 0x4c
1416#define  DSI_PLL_LFSR                           (1 << 31)
1417#define  DSI_PLL_FRACTION_EN                    (1 << 30)
1418#define  DSI_PLL_FRAC_COUNTER_SHIFT             27
1419#define  DSI_PLL_FRAC_COUNTER_MASK              (7 << 27)
1420#define  DSI_PLL_USYNC_CNT_SHIFT                18
1421#define  DSI_PLL_USYNC_CNT_MASK                 (0x1ff << 18)
1422#define  DSI_PLL_N1_DIV_SHIFT                   16
1423#define  DSI_PLL_N1_DIV_MASK                    (3 << 16)
1424#define  DSI_PLL_M1_DIV_SHIFT                   0
1425#define  DSI_PLL_M1_DIV_MASK                    (0x1ff << 0)
1426#define CCK_CZ_CLOCK_CONTROL                    0x62
1427#define CCK_GPLL_CLOCK_CONTROL                  0x67
1428#define CCK_DISPLAY_CLOCK_CONTROL               0x6b
1429#define CCK_DISPLAY_REF_CLOCK_CONTROL           0x6c
1430#define  CCK_TRUNK_FORCE_ON                     (1 << 17)
1431#define  CCK_TRUNK_FORCE_OFF                    (1 << 16)
1432#define  CCK_FREQUENCY_STATUS                   (0x1f << 8)
1433#define  CCK_FREQUENCY_STATUS_SHIFT             8
1434#define  CCK_FREQUENCY_VALUES                   (0x1f << 0)
1435
1436/* DPIO registers */
1437#define DPIO_DEVFN                      0
1438
1439#define DPIO_CTL                        _MMIO(VLV_DISPLAY_BASE + 0x2110)
1440#define  DPIO_MODSEL1                   (1<<3) /* if ref clk b == 27 */
1441#define  DPIO_MODSEL0                   (1<<2) /* if ref clk a == 27 */
1442#define  DPIO_SFR_BYPASS                (1<<1)
1443#define  DPIO_CMNRST                    (1<<0)
1444
1445#define DPIO_PHY(pipe)                  ((pipe) >> 1)
1446#define DPIO_PHY_IOSF_PORT(phy)         (dev_priv->dpio_phy_iosf_port[phy])
1447
1448/*
1449 * Per pipe/PLL DPIO regs
1450 */
1451#define _VLV_PLL_DW3_CH0                0x800c
1452#define   DPIO_POST_DIV_SHIFT           (28) /* 3 bits */
1453#define   DPIO_POST_DIV_DAC             0
1454#define   DPIO_POST_DIV_HDMIDP          1 /* DAC 225-400M rate */
1455#define   DPIO_POST_DIV_LVDS1           2
1456#define   DPIO_POST_DIV_LVDS2           3
1457#define   DPIO_K_SHIFT                  (24) /* 4 bits */
1458#define   DPIO_P1_SHIFT                 (21) /* 3 bits */
1459#define   DPIO_P2_SHIFT                 (16) /* 5 bits */
1460#define   DPIO_N_SHIFT                  (12) /* 4 bits */
1461#define   DPIO_ENABLE_CALIBRATION       (1<<11)
1462#define   DPIO_M1DIV_SHIFT              (8) /* 3 bits */
1463#define   DPIO_M2DIV_MASK               0xff
1464#define _VLV_PLL_DW3_CH1                0x802c
1465#define VLV_PLL_DW3(ch) _PIPE(ch, _VLV_PLL_DW3_CH0, _VLV_PLL_DW3_CH1)
1466
1467#define _VLV_PLL_DW5_CH0                0x8014
1468#define   DPIO_REFSEL_OVERRIDE          27
1469#define   DPIO_PLL_MODESEL_SHIFT        24 /* 3 bits */
1470#define   DPIO_BIAS_CURRENT_CTL_SHIFT   21 /* 3 bits, always 0x7 */
1471#define   DPIO_PLL_REFCLK_SEL_SHIFT     16 /* 2 bits */
1472#define   DPIO_PLL_REFCLK_SEL_MASK      3
1473#define   DPIO_DRIVER_CTL_SHIFT         12 /* always set to 0x8 */
1474#define   DPIO_CLK_BIAS_CTL_SHIFT       8 /* always set to 0x5 */
1475#define _VLV_PLL_DW5_CH1                0x8034
1476#define VLV_PLL_DW5(ch) _PIPE(ch, _VLV_PLL_DW5_CH0, _VLV_PLL_DW5_CH1)
1477
1478#define _VLV_PLL_DW7_CH0                0x801c
1479#define _VLV_PLL_DW7_CH1                0x803c
1480#define VLV_PLL_DW7(ch) _PIPE(ch, _VLV_PLL_DW7_CH0, _VLV_PLL_DW7_CH1)
1481
1482#define _VLV_PLL_DW8_CH0                0x8040
1483#define _VLV_PLL_DW8_CH1                0x8060
1484#define VLV_PLL_DW8(ch) _PIPE(ch, _VLV_PLL_DW8_CH0, _VLV_PLL_DW8_CH1)
1485
1486#define VLV_PLL_DW9_BCAST               0xc044
1487#define _VLV_PLL_DW9_CH0                0x8044
1488#define _VLV_PLL_DW9_CH1                0x8064
1489#define VLV_PLL_DW9(ch) _PIPE(ch, _VLV_PLL_DW9_CH0, _VLV_PLL_DW9_CH1)
1490
1491#define _VLV_PLL_DW10_CH0               0x8048
1492#define _VLV_PLL_DW10_CH1               0x8068
1493#define VLV_PLL_DW10(ch) _PIPE(ch, _VLV_PLL_DW10_CH0, _VLV_PLL_DW10_CH1)
1494
1495#define _VLV_PLL_DW11_CH0               0x804c
1496#define _VLV_PLL_DW11_CH1               0x806c
1497#define VLV_PLL_DW11(ch) _PIPE(ch, _VLV_PLL_DW11_CH0, _VLV_PLL_DW11_CH1)
1498
1499/* Spec for ref block start counts at DW10 */
1500#define VLV_REF_DW13                    0x80ac
1501
1502#define VLV_CMN_DW0                     0x8100
1503
1504/*
1505 * Per DDI channel DPIO regs
1506 */
1507
1508#define _VLV_PCS_DW0_CH0                0x8200
1509#define _VLV_PCS_DW0_CH1                0x8400
1510#define   DPIO_PCS_TX_LANE2_RESET       (1<<16)
1511#define   DPIO_PCS_TX_LANE1_RESET       (1<<7)
1512#define   DPIO_LEFT_TXFIFO_RST_MASTER2  (1<<4)
1513#define   DPIO_RIGHT_TXFIFO_RST_MASTER2 (1<<3)
1514#define VLV_PCS_DW0(ch) _PORT(ch, _VLV_PCS_DW0_CH0, _VLV_PCS_DW0_CH1)
1515
1516#define _VLV_PCS01_DW0_CH0              0x200
1517#define _VLV_PCS23_DW0_CH0              0x400
1518#define _VLV_PCS01_DW0_CH1              0x2600
1519#define _VLV_PCS23_DW0_CH1              0x2800
1520#define VLV_PCS01_DW0(ch) _PORT(ch, _VLV_PCS01_DW0_CH0, _VLV_PCS01_DW0_CH1)
1521#define VLV_PCS23_DW0(ch) _PORT(ch, _VLV_PCS23_DW0_CH0, _VLV_PCS23_DW0_CH1)
1522
1523#define _VLV_PCS_DW1_CH0                0x8204
1524#define _VLV_PCS_DW1_CH1                0x8404
1525#define   CHV_PCS_REQ_SOFTRESET_EN      (1<<23)
1526#define   DPIO_PCS_CLK_CRI_RXEB_EIOS_EN (1<<22)
1527#define   DPIO_PCS_CLK_CRI_RXDIGFILTSG_EN (1<<21)
1528#define   DPIO_PCS_CLK_DATAWIDTH_SHIFT  (6)
1529#define   DPIO_PCS_CLK_SOFT_RESET       (1<<5)
1530#define VLV_PCS_DW1(ch) _PORT(ch, _VLV_PCS_DW1_CH0, _VLV_PCS_DW1_CH1)
1531
1532#define _VLV_PCS01_DW1_CH0              0x204
1533#define _VLV_PCS23_DW1_CH0              0x404
1534#define _VLV_PCS01_DW1_CH1              0x2604
1535#define _VLV_PCS23_DW1_CH1              0x2804
1536#define VLV_PCS01_DW1(ch) _PORT(ch, _VLV_PCS01_DW1_CH0, _VLV_PCS01_DW1_CH1)
1537#define VLV_PCS23_DW1(ch) _PORT(ch, _VLV_PCS23_DW1_CH0, _VLV_PCS23_DW1_CH1)
1538
1539#define _VLV_PCS_DW8_CH0                0x8220
1540#define _VLV_PCS_DW8_CH1                0x8420
1541#define   CHV_PCS_USEDCLKCHANNEL_OVRRIDE        (1 << 20)
1542#define   CHV_PCS_USEDCLKCHANNEL                (1 << 21)
1543#define VLV_PCS_DW8(ch) _PORT(ch, _VLV_PCS_DW8_CH0, _VLV_PCS_DW8_CH1)
1544
1545#define _VLV_PCS01_DW8_CH0              0x0220
1546#define _VLV_PCS23_DW8_CH0              0x0420
1547#define _VLV_PCS01_DW8_CH1              0x2620
1548#define _VLV_PCS23_DW8_CH1              0x2820
1549#define VLV_PCS01_DW8(port) _PORT(port, _VLV_PCS01_DW8_CH0, _VLV_PCS01_DW8_CH1)
1550#define VLV_PCS23_DW8(port) _PORT(port, _VLV_PCS23_DW8_CH0, _VLV_PCS23_DW8_CH1)
1551
1552#define _VLV_PCS_DW9_CH0                0x8224
1553#define _VLV_PCS_DW9_CH1                0x8424
1554#define   DPIO_PCS_TX2MARGIN_MASK       (0x7<<13)
1555#define   DPIO_PCS_TX2MARGIN_000        (0<<13)
1556#define   DPIO_PCS_TX2MARGIN_101        (1<<13)
1557#define   DPIO_PCS_TX1MARGIN_MASK       (0x7<<10)
1558#define   DPIO_PCS_TX1MARGIN_000        (0<<10)
1559#define   DPIO_PCS_TX1MARGIN_101        (1<<10)
1560#define VLV_PCS_DW9(ch) _PORT(ch, _VLV_PCS_DW9_CH0, _VLV_PCS_DW9_CH1)
1561
1562#define _VLV_PCS01_DW9_CH0              0x224
1563#define _VLV_PCS23_DW9_CH0              0x424
1564#define _VLV_PCS01_DW9_CH1              0x2624
1565#define _VLV_PCS23_DW9_CH1              0x2824
1566#define VLV_PCS01_DW9(ch) _PORT(ch, _VLV_PCS01_DW9_CH0, _VLV_PCS01_DW9_CH1)
1567#define VLV_PCS23_DW9(ch) _PORT(ch, _VLV_PCS23_DW9_CH0, _VLV_PCS23_DW9_CH1)
1568
1569#define _CHV_PCS_DW10_CH0               0x8228
1570#define _CHV_PCS_DW10_CH1               0x8428
1571#define   DPIO_PCS_SWING_CALC_TX0_TX2   (1<<30)
1572#define   DPIO_PCS_SWING_CALC_TX1_TX3   (1<<31)
1573#define   DPIO_PCS_TX2DEEMP_MASK        (0xf<<24)
1574#define   DPIO_PCS_TX2DEEMP_9P5         (0<<24)
1575#define   DPIO_PCS_TX2DEEMP_6P0         (2<<24)
1576#define   DPIO_PCS_TX1DEEMP_MASK        (0xf<<16)
1577#define   DPIO_PCS_TX1DEEMP_9P5         (0<<16)
1578#define   DPIO_PCS_TX1DEEMP_6P0         (2<<16)
1579#define CHV_PCS_DW10(ch) _PORT(ch, _CHV_PCS_DW10_CH0, _CHV_PCS_DW10_CH1)
1580
1581#define _VLV_PCS01_DW10_CH0             0x0228
1582#define _VLV_PCS23_DW10_CH0             0x0428
1583#define _VLV_PCS01_DW10_CH1             0x2628
1584#define _VLV_PCS23_DW10_CH1             0x2828
1585#define VLV_PCS01_DW10(port) _PORT(port, _VLV_PCS01_DW10_CH0, _VLV_PCS01_DW10_CH1)
1586#define VLV_PCS23_DW10(port) _PORT(port, _VLV_PCS23_DW10_CH0, _VLV_PCS23_DW10_CH1)
1587
1588#define _VLV_PCS_DW11_CH0               0x822c
1589#define _VLV_PCS_DW11_CH1               0x842c
1590#define   DPIO_TX2_STAGGER_MASK(x)      ((x)<<24)
1591#define   DPIO_LANEDESKEW_STRAP_OVRD    (1<<3)
1592#define   DPIO_LEFT_TXFIFO_RST_MASTER   (1<<1)
1593#define   DPIO_RIGHT_TXFIFO_RST_MASTER  (1<<0)
1594#define VLV_PCS_DW11(ch) _PORT(ch, _VLV_PCS_DW11_CH0, _VLV_PCS_DW11_CH1)
1595
1596#define _VLV_PCS01_DW11_CH0             0x022c
1597#define _VLV_PCS23_DW11_CH0             0x042c
1598#define _VLV_PCS01_DW11_CH1             0x262c
1599#define _VLV_PCS23_DW11_CH1             0x282c
1600#define VLV_PCS01_DW11(ch) _PORT(ch, _VLV_PCS01_DW11_CH0, _VLV_PCS01_DW11_CH1)
1601#define VLV_PCS23_DW11(ch) _PORT(ch, _VLV_PCS23_DW11_CH0, _VLV_PCS23_DW11_CH1)
1602
1603#define _VLV_PCS01_DW12_CH0             0x0230
1604#define _VLV_PCS23_DW12_CH0             0x0430
1605#define _VLV_PCS01_DW12_CH1             0x2630
1606#define _VLV_PCS23_DW12_CH1             0x2830
1607#define VLV_PCS01_DW12(ch) _PORT(ch, _VLV_PCS01_DW12_CH0, _VLV_PCS01_DW12_CH1)
1608#define VLV_PCS23_DW12(ch) _PORT(ch, _VLV_PCS23_DW12_CH0, _VLV_PCS23_DW12_CH1)
1609
1610#define _VLV_PCS_DW12_CH0               0x8230
1611#define _VLV_PCS_DW12_CH1               0x8430
1612#define   DPIO_TX2_STAGGER_MULT(x)      ((x)<<20)
1613#define   DPIO_TX1_STAGGER_MULT(x)      ((x)<<16)
1614#define   DPIO_TX1_STAGGER_MASK(x)      ((x)<<8)
1615#define   DPIO_LANESTAGGER_STRAP_OVRD   (1<<6)
1616#define   DPIO_LANESTAGGER_STRAP(x)     ((x)<<0)
1617#define VLV_PCS_DW12(ch) _PORT(ch, _VLV_PCS_DW12_CH0, _VLV_PCS_DW12_CH1)
1618
1619#define _VLV_PCS_DW14_CH0               0x8238
1620#define _VLV_PCS_DW14_CH1               0x8438
1621#define VLV_PCS_DW14(ch) _PORT(ch, _VLV_PCS_DW14_CH0, _VLV_PCS_DW14_CH1)
1622
1623#define _VLV_PCS_DW23_CH0               0x825c
1624#define _VLV_PCS_DW23_CH1               0x845c
1625#define VLV_PCS_DW23(ch) _PORT(ch, _VLV_PCS_DW23_CH0, _VLV_PCS_DW23_CH1)
1626
1627#define _VLV_TX_DW2_CH0                 0x8288
1628#define _VLV_TX_DW2_CH1                 0x8488
1629#define   DPIO_SWING_MARGIN000_SHIFT    16
1630#define   DPIO_SWING_MARGIN000_MASK     (0xff << DPIO_SWING_MARGIN000_SHIFT)
1631#define   DPIO_UNIQ_TRANS_SCALE_SHIFT   8
1632#define VLV_TX_DW2(ch) _PORT(ch, _VLV_TX_DW2_CH0, _VLV_TX_DW2_CH1)
1633
1634#define _VLV_TX_DW3_CH0                 0x828c
1635#define _VLV_TX_DW3_CH1                 0x848c
1636/* The following bit for CHV phy */
1637#define   DPIO_TX_UNIQ_TRANS_SCALE_EN   (1<<27)
1638#define   DPIO_SWING_MARGIN101_SHIFT    16
1639#define   DPIO_SWING_MARGIN101_MASK     (0xff << DPIO_SWING_MARGIN101_SHIFT)
1640#define VLV_TX_DW3(ch) _PORT(ch, _VLV_TX_DW3_CH0, _VLV_TX_DW3_CH1)
1641
1642#define _VLV_TX_DW4_CH0                 0x8290
1643#define _VLV_TX_DW4_CH1                 0x8490
1644#define   DPIO_SWING_DEEMPH9P5_SHIFT    24
1645#define   DPIO_SWING_DEEMPH9P5_MASK     (0xff << DPIO_SWING_DEEMPH9P5_SHIFT)
1646#define   DPIO_SWING_DEEMPH6P0_SHIFT    16
1647#define   DPIO_SWING_DEEMPH6P0_MASK     (0xff << DPIO_SWING_DEEMPH6P0_SHIFT)
1648#define VLV_TX_DW4(ch) _PORT(ch, _VLV_TX_DW4_CH0, _VLV_TX_DW4_CH1)
1649
1650#define _VLV_TX3_DW4_CH0                0x690
1651#define _VLV_TX3_DW4_CH1                0x2a90
1652#define VLV_TX3_DW4(ch) _PORT(ch, _VLV_TX3_DW4_CH0, _VLV_TX3_DW4_CH1)
1653
1654#define _VLV_TX_DW5_CH0                 0x8294
1655#define _VLV_TX_DW5_CH1                 0x8494
1656#define   DPIO_TX_OCALINIT_EN           (1<<31)
1657#define VLV_TX_DW5(ch) _PORT(ch, _VLV_TX_DW5_CH0, _VLV_TX_DW5_CH1)
1658
1659#define _VLV_TX_DW11_CH0                0x82ac
1660#define _VLV_TX_DW11_CH1                0x84ac
1661#define VLV_TX_DW11(ch) _PORT(ch, _VLV_TX_DW11_CH0, _VLV_TX_DW11_CH1)
1662
1663#define _VLV_TX_DW14_CH0                0x82b8
1664#define _VLV_TX_DW14_CH1                0x84b8
1665#define VLV_TX_DW14(ch) _PORT(ch, _VLV_TX_DW14_CH0, _VLV_TX_DW14_CH1)
1666
1667/* CHV dpPhy registers */
1668#define _CHV_PLL_DW0_CH0                0x8000
1669#define _CHV_PLL_DW0_CH1                0x8180
1670#define CHV_PLL_DW0(ch) _PIPE(ch, _CHV_PLL_DW0_CH0, _CHV_PLL_DW0_CH1)
1671
1672#define _CHV_PLL_DW1_CH0                0x8004
1673#define _CHV_PLL_DW1_CH1                0x8184
1674#define   DPIO_CHV_N_DIV_SHIFT          8
1675#define   DPIO_CHV_M1_DIV_BY_2          (0 << 0)
1676#define CHV_PLL_DW1(ch) _PIPE(ch, _CHV_PLL_DW1_CH0, _CHV_PLL_DW1_CH1)
1677
1678#define _CHV_PLL_DW2_CH0                0x8008
1679#define _CHV_PLL_DW2_CH1                0x8188
1680#define CHV_PLL_DW2(ch) _PIPE(ch, _CHV_PLL_DW2_CH0, _CHV_PLL_DW2_CH1)
1681
1682#define _CHV_PLL_DW3_CH0                0x800c
1683#define _CHV_PLL_DW3_CH1                0x818c
1684#define  DPIO_CHV_FRAC_DIV_EN           (1 << 16)
1685#define  DPIO_CHV_FIRST_MOD             (0 << 8)
1686#define  DPIO_CHV_SECOND_MOD            (1 << 8)
1687#define  DPIO_CHV_FEEDFWD_GAIN_SHIFT    0
1688#define  DPIO_CHV_FEEDFWD_GAIN_MASK             (0xF << 0)
1689#define CHV_PLL_DW3(ch) _PIPE(ch, _CHV_PLL_DW3_CH0, _CHV_PLL_DW3_CH1)
1690
1691#define _CHV_PLL_DW6_CH0                0x8018
1692#define _CHV_PLL_DW6_CH1                0x8198
1693#define   DPIO_CHV_GAIN_CTRL_SHIFT      16
1694#define   DPIO_CHV_INT_COEFF_SHIFT      8
1695#define   DPIO_CHV_PROP_COEFF_SHIFT     0
1696#define CHV_PLL_DW6(ch) _PIPE(ch, _CHV_PLL_DW6_CH0, _CHV_PLL_DW6_CH1)
1697
1698#define _CHV_PLL_DW8_CH0                0x8020
1699#define _CHV_PLL_DW8_CH1                0x81A0
1700#define   DPIO_CHV_TDC_TARGET_CNT_SHIFT 0
1701#define   DPIO_CHV_TDC_TARGET_CNT_MASK  (0x3FF << 0)
1702#define CHV_PLL_DW8(ch) _PIPE(ch, _CHV_PLL_DW8_CH0, _CHV_PLL_DW8_CH1)
1703
1704#define _CHV_PLL_DW9_CH0                0x8024
1705#define _CHV_PLL_DW9_CH1                0x81A4
1706#define  DPIO_CHV_INT_LOCK_THRESHOLD_SHIFT              1 /* 3 bits */
1707#define  DPIO_CHV_INT_LOCK_THRESHOLD_MASK               (7 << 1)
1708#define  DPIO_CHV_INT_LOCK_THRESHOLD_SEL_COARSE 1 /* 1: coarse & 0 : fine  */
1709#define CHV_PLL_DW9(ch) _PIPE(ch, _CHV_PLL_DW9_CH0, _CHV_PLL_DW9_CH1)
1710
1711#define _CHV_CMN_DW0_CH0               0x8100
1712#define   DPIO_ALLDL_POWERDOWN_SHIFT_CH0        19
1713#define   DPIO_ANYDL_POWERDOWN_SHIFT_CH0        18
1714#define   DPIO_ALLDL_POWERDOWN                  (1 << 1)
1715#define   DPIO_ANYDL_POWERDOWN                  (1 << 0)
1716
1717#define _CHV_CMN_DW5_CH0               0x8114
1718#define   CHV_BUFRIGHTENA1_DISABLE      (0 << 20)
1719#define   CHV_BUFRIGHTENA1_NORMAL       (1 << 20)
1720#define   CHV_BUFRIGHTENA1_FORCE        (3 << 20)
1721#define   CHV_BUFRIGHTENA1_MASK         (3 << 20)
1722#define   CHV_BUFLEFTENA1_DISABLE       (0 << 22)
1723#define   CHV_BUFLEFTENA1_NORMAL        (1 << 22)
1724#define   CHV_BUFLEFTENA1_FORCE         (3 << 22)
1725#define   CHV_BUFLEFTENA1_MASK          (3 << 22)
1726
1727#define _CHV_CMN_DW13_CH0               0x8134
1728#define _CHV_CMN_DW0_CH1                0x8080
1729#define   DPIO_CHV_S1_DIV_SHIFT         21
1730#define   DPIO_CHV_P1_DIV_SHIFT         13 /* 3 bits */
1731#define   DPIO_CHV_P2_DIV_SHIFT         8  /* 5 bits */
1732#define   DPIO_CHV_K_DIV_SHIFT          4
1733#define   DPIO_PLL_FREQLOCK             (1 << 1)
1734#define   DPIO_PLL_LOCK                 (1 << 0)
1735#define CHV_CMN_DW13(ch) _PIPE(ch, _CHV_CMN_DW13_CH0, _CHV_CMN_DW0_CH1)
1736
1737#define _CHV_CMN_DW14_CH0               0x8138
1738#define _CHV_CMN_DW1_CH1                0x8084
1739#define   DPIO_AFC_RECAL                (1 << 14)
1740#define   DPIO_DCLKP_EN                 (1 << 13)
1741#define   CHV_BUFLEFTENA2_DISABLE       (0 << 17) /* CL2 DW1 only */
1742#define   CHV_BUFLEFTENA2_NORMAL        (1 << 17) /* CL2 DW1 only */
1743#define   CHV_BUFLEFTENA2_FORCE         (3 << 17) /* CL2 DW1 only */
1744#define   CHV_BUFLEFTENA2_MASK          (3 << 17) /* CL2 DW1 only */
1745#define   CHV_BUFRIGHTENA2_DISABLE      (0 << 19) /* CL2 DW1 only */
1746#define   CHV_BUFRIGHTENA2_NORMAL       (1 << 19) /* CL2 DW1 only */
1747#define   CHV_BUFRIGHTENA2_FORCE        (3 << 19) /* CL2 DW1 only */
1748#define   CHV_BUFRIGHTENA2_MASK         (3 << 19) /* CL2 DW1 only */
1749#define CHV_CMN_DW14(ch) _PIPE(ch, _CHV_CMN_DW14_CH0, _CHV_CMN_DW1_CH1)
1750
1751#define _CHV_CMN_DW19_CH0               0x814c
1752#define _CHV_CMN_DW6_CH1                0x8098
1753#define   DPIO_ALLDL_POWERDOWN_SHIFT_CH1        30 /* CL2 DW6 only */
1754#define   DPIO_ANYDL_POWERDOWN_SHIFT_CH1        29 /* CL2 DW6 only */
1755#define   DPIO_DYNPWRDOWNEN_CH1         (1 << 28) /* CL2 DW6 only */
1756#define   CHV_CMN_USEDCLKCHANNEL        (1 << 13)
1757
1758#define CHV_CMN_DW19(ch) _PIPE(ch, _CHV_CMN_DW19_CH0, _CHV_CMN_DW6_CH1)
1759
1760#define CHV_CMN_DW28                    0x8170
1761#define   DPIO_CL1POWERDOWNEN           (1 << 23)
1762#define   DPIO_DYNPWRDOWNEN_CH0         (1 << 22)
1763#define   DPIO_SUS_CLK_CONFIG_ON                (0 << 0)
1764#define   DPIO_SUS_CLK_CONFIG_CLKREQ            (1 << 0)
1765#define   DPIO_SUS_CLK_CONFIG_GATE              (2 << 0)
1766#define   DPIO_SUS_CLK_CONFIG_GATE_CLKREQ       (3 << 0)
1767
1768#define CHV_CMN_DW30                    0x8178
1769#define   DPIO_CL2_LDOFUSE_PWRENB       (1 << 6)
1770#define   DPIO_LRC_BYPASS               (1 << 3)
1771
1772#define _TXLANE(ch, lane, offset) ((ch ? 0x2400 : 0) + \
1773                                        (lane) * 0x200 + (offset))
1774
1775#define CHV_TX_DW0(ch, lane) _TXLANE(ch, lane, 0x80)
1776#define CHV_TX_DW1(ch, lane) _TXLANE(ch, lane, 0x84)
1777#define CHV_TX_DW2(ch, lane) _TXLANE(ch, lane, 0x88)
1778#define CHV_TX_DW3(ch, lane) _TXLANE(ch, lane, 0x8c)
1779#define CHV_TX_DW4(ch, lane) _TXLANE(ch, lane, 0x90)
1780#define CHV_TX_DW5(ch, lane) _TXLANE(ch, lane, 0x94)
1781#define CHV_TX_DW6(ch, lane) _TXLANE(ch, lane, 0x98)
1782#define CHV_TX_DW7(ch, lane) _TXLANE(ch, lane, 0x9c)
1783#define CHV_TX_DW8(ch, lane) _TXLANE(ch, lane, 0xa0)
1784#define CHV_TX_DW9(ch, lane) _TXLANE(ch, lane, 0xa4)
1785#define CHV_TX_DW10(ch, lane) _TXLANE(ch, lane, 0xa8)
1786#define CHV_TX_DW11(ch, lane) _TXLANE(ch, lane, 0xac)
1787#define   DPIO_FRC_LATENCY_SHFIT        8
1788#define CHV_TX_DW14(ch, lane) _TXLANE(ch, lane, 0xb8)
1789#define   DPIO_UPAR_SHIFT               30
1790
1791/* BXT PHY registers */
1792#define _BXT_PHY0_BASE                  0x6C000
1793#define _BXT_PHY1_BASE                  0x162000
1794#define _BXT_PHY2_BASE                  0x163000
1795#define BXT_PHY_BASE(phy)               _PHY3((phy), _BXT_PHY0_BASE, \
1796                                                     _BXT_PHY1_BASE, \
1797                                                     _BXT_PHY2_BASE)
1798
1799#define _BXT_PHY(phy, reg)                                              \
1800        _MMIO(BXT_PHY_BASE(phy) - _BXT_PHY0_BASE + (reg))
1801
1802#define _BXT_PHY_CH(phy, ch, reg_ch0, reg_ch1)          \
1803        (BXT_PHY_BASE(phy) + _PIPE((ch), (reg_ch0) - _BXT_PHY0_BASE,    \
1804                                         (reg_ch1) - _BXT_PHY0_BASE))
1805#define _MMIO_BXT_PHY_CH(phy, ch, reg_ch0, reg_ch1)             \
1806        _MMIO(_BXT_PHY_CH(phy, ch, reg_ch0, reg_ch1))
1807
1808#define BXT_P_CR_GT_DISP_PWRON          _MMIO(0x138090)
1809#define  MIPIO_RST_CTRL                         (1 << 2)
1810
1811#define _BXT_PHY_CTL_DDI_A              0x64C00
1812#define _BXT_PHY_CTL_DDI_B              0x64C10
1813#define _BXT_PHY_CTL_DDI_C              0x64C20
1814#define   BXT_PHY_CMNLANE_POWERDOWN_ACK (1 << 10)
1815#define   BXT_PHY_LANE_POWERDOWN_ACK    (1 << 9)
1816#define   BXT_PHY_LANE_ENABLED          (1 << 8)
1817#define BXT_PHY_CTL(port)               _MMIO_PORT(port, _BXT_PHY_CTL_DDI_A, \
1818                                                         _BXT_PHY_CTL_DDI_B)
1819
1820#define _PHY_CTL_FAMILY_EDP             0x64C80
1821#define _PHY_CTL_FAMILY_DDI             0x64C90
1822#define _PHY_CTL_FAMILY_DDI_C           0x64CA0
1823#define   COMMON_RESET_DIS              (1 << 31)
1824#define BXT_PHY_CTL_FAMILY(phy)         _MMIO_PHY3((phy), _PHY_CTL_FAMILY_DDI, \
1825                                                          _PHY_CTL_FAMILY_EDP, \
1826                                                          _PHY_CTL_FAMILY_DDI_C)
1827
1828/* BXT PHY PLL registers */
1829#define _PORT_PLL_A                     0x46074
1830#define _PORT_PLL_B                     0x46078
1831#define _PORT_PLL_C                     0x4607c
1832#define   PORT_PLL_ENABLE               (1 << 31)
1833#define   PORT_PLL_LOCK                 (1 << 30)
1834#define   PORT_PLL_REF_SEL              (1 << 27)
1835#define   PORT_PLL_POWER_ENABLE         (1 << 26)
1836#define   PORT_PLL_POWER_STATE          (1 << 25)
1837#define BXT_PORT_PLL_ENABLE(port)       _MMIO_PORT(port, _PORT_PLL_A, _PORT_PLL_B)
1838
1839#define _PORT_PLL_EBB_0_A               0x162034
1840#define _PORT_PLL_EBB_0_B               0x6C034
1841#define _PORT_PLL_EBB_0_C               0x6C340
1842#define   PORT_PLL_P1_SHIFT             13
1843#define   PORT_PLL_P1_MASK              (0x07 << PORT_PLL_P1_SHIFT)
1844#define   PORT_PLL_P1(x)                ((x)  << PORT_PLL_P1_SHIFT)
1845#define   PORT_PLL_P2_SHIFT             8
1846#define   PORT_PLL_P2_MASK              (0x1f << PORT_PLL_P2_SHIFT)
1847#define   PORT_PLL_P2(x)                ((x)  << PORT_PLL_P2_SHIFT)
1848#define BXT_PORT_PLL_EBB_0(phy, ch)     _MMIO_BXT_PHY_CH(phy, ch, \
1849                                                         _PORT_PLL_EBB_0_B, \
1850                                                         _PORT_PLL_EBB_0_C)
1851
1852#define _PORT_PLL_EBB_4_A               0x162038
1853#define _PORT_PLL_EBB_4_B               0x6C038
1854#define _PORT_PLL_EBB_4_C               0x6C344
1855#define   PORT_PLL_10BIT_CLK_ENABLE     (1 << 13)
1856#define   PORT_PLL_RECALIBRATE          (1 << 14)
1857#define BXT_PORT_PLL_EBB_4(phy, ch)     _MMIO_BXT_PHY_CH(phy, ch, \
1858                                                         _PORT_PLL_EBB_4_B, \
1859                                                         _PORT_PLL_EBB_4_C)
1860
1861#define _PORT_PLL_0_A                   0x162100
1862#define _PORT_PLL_0_B                   0x6C100
1863#define _PORT_PLL_0_C                   0x6C380
1864/* PORT_PLL_0_A */
1865#define   PORT_PLL_M2_MASK              0xFF
1866/* PORT_PLL_1_A */
1867#define   PORT_PLL_N_SHIFT              8
1868#define   PORT_PLL_N_MASK               (0x0F << PORT_PLL_N_SHIFT)
1869#define   PORT_PLL_N(x)                 ((x) << PORT_PLL_N_SHIFT)
1870/* PORT_PLL_2_A */
1871#define   PORT_PLL_M2_FRAC_MASK         0x3FFFFF
1872/* PORT_PLL_3_A */
1873#define   PORT_PLL_M2_FRAC_ENABLE       (1 << 16)
1874/* PORT_PLL_6_A */
1875#define   PORT_PLL_PROP_COEFF_MASK      0xF
1876#define   PORT_PLL_INT_COEFF_MASK       (0x1F << 8)
1877#define   PORT_PLL_INT_COEFF(x)         ((x)  << 8)
1878#define   PORT_PLL_GAIN_CTL_MASK        (0x07 << 16)
1879#define   PORT_PLL_GAIN_CTL(x)          ((x)  << 16)
1880/* PORT_PLL_8_A */
1881#define   PORT_PLL_TARGET_CNT_MASK      0x3FF
1882/* PORT_PLL_9_A */
1883#define  PORT_PLL_LOCK_THRESHOLD_SHIFT  1
1884#define  PORT_PLL_LOCK_THRESHOLD_MASK   (0x7 << PORT_PLL_LOCK_THRESHOLD_SHIFT)
1885/* PORT_PLL_10_A */
1886#define  PORT_PLL_DCO_AMP_OVR_EN_H      (1<<27)
1887#define  PORT_PLL_DCO_AMP_DEFAULT       15
1888#define  PORT_PLL_DCO_AMP_MASK          0x3c00
1889#define  PORT_PLL_DCO_AMP(x)            ((x)<<10)
1890#define _PORT_PLL_BASE(phy, ch)         _BXT_PHY_CH(phy, ch, \
1891                                                    _PORT_PLL_0_B, \
1892                                                    _PORT_PLL_0_C)
1893#define BXT_PORT_PLL(phy, ch, idx)      _MMIO(_PORT_PLL_BASE(phy, ch) + \
1894                                              (idx) * 4)
1895
1896/* BXT PHY common lane registers */
1897#define _PORT_CL1CM_DW0_A               0x162000
1898#define _PORT_CL1CM_DW0_BC              0x6C000
1899#define   PHY_POWER_GOOD                (1 << 16)
1900#define   PHY_RESERVED                  (1 << 7)
1901#define BXT_PORT_CL1CM_DW0(phy)         _BXT_PHY((phy), _PORT_CL1CM_DW0_BC)
1902
1903#define CNL_PORT_CL1CM_DW5              _MMIO(0x162014)
1904#define   CL_POWER_DOWN_ENABLE          (1 << 4)
1905#define   SUS_CLOCK_CONFIG              (3 << 0)
1906
1907#define _PORT_CL1CM_DW9_A               0x162024
1908#define _PORT_CL1CM_DW9_BC              0x6C024
1909#define   IREF0RC_OFFSET_SHIFT          8
1910#define   IREF0RC_OFFSET_MASK           (0xFF << IREF0RC_OFFSET_SHIFT)
1911#define BXT_PORT_CL1CM_DW9(phy)         _BXT_PHY((phy), _PORT_CL1CM_DW9_BC)
1912
1913#define _PORT_CL1CM_DW10_A              0x162028
1914#define _PORT_CL1CM_DW10_BC             0x6C028
1915#define   IREF1RC_OFFSET_SHIFT          8
1916#define   IREF1RC_OFFSET_MASK           (0xFF << IREF1RC_OFFSET_SHIFT)
1917#define BXT_PORT_CL1CM_DW10(phy)        _BXT_PHY((phy), _PORT_CL1CM_DW10_BC)
1918
1919#define _PORT_CL1CM_DW28_A              0x162070
1920#define _PORT_CL1CM_DW28_BC             0x6C070
1921#define   OCL1_POWER_DOWN_EN            (1 << 23)
1922#define   DW28_OLDO_DYN_PWR_DOWN_EN     (1 << 22)
1923#define   SUS_CLK_CONFIG                0x3
1924#define BXT_PORT_CL1CM_DW28(phy)        _BXT_PHY((phy), _PORT_CL1CM_DW28_BC)
1925
1926#define _PORT_CL1CM_DW30_A              0x162078
1927#define _PORT_CL1CM_DW30_BC             0x6C078
1928#define   OCL2_LDOFUSE_PWR_DIS          (1 << 6)
1929#define BXT_PORT_CL1CM_DW30(phy)        _BXT_PHY((phy), _PORT_CL1CM_DW30_BC)
1930
1931#define _CNL_PORT_PCS_DW1_GRP_AE        0x162304
1932#define _CNL_PORT_PCS_DW1_GRP_B         0x162384
1933#define _CNL_PORT_PCS_DW1_GRP_C         0x162B04
1934#define _CNL_PORT_PCS_DW1_GRP_D         0x162B84
1935#define _CNL_PORT_PCS_DW1_GRP_F         0x162A04
1936#define _CNL_PORT_PCS_DW1_LN0_AE        0x162404
1937#define _CNL_PORT_PCS_DW1_LN0_B         0x162604
1938#define _CNL_PORT_PCS_DW1_LN0_C         0x162C04
1939#define _CNL_PORT_PCS_DW1_LN0_D         0x162E04
1940#define _CNL_PORT_PCS_DW1_LN0_F         0x162804
1941#define CNL_PORT_PCS_DW1_GRP(port)      _MMIO_PORT6(port, \
1942                                                    _CNL_PORT_PCS_DW1_GRP_AE, \
1943                                                    _CNL_PORT_PCS_DW1_GRP_B, \
1944                                                    _CNL_PORT_PCS_DW1_GRP_C, \
1945                                                    _CNL_PORT_PCS_DW1_GRP_D, \
1946                                                    _CNL_PORT_PCS_DW1_GRP_AE, \
1947                                                    _CNL_PORT_PCS_DW1_GRP_F)
1948#define CNL_PORT_PCS_DW1_LN0(port)      _MMIO_PORT6(port, \
1949                                                    _CNL_PORT_PCS_DW1_LN0_AE, \
1950                                                    _CNL_PORT_PCS_DW1_LN0_B, \
1951                                                    _CNL_PORT_PCS_DW1_LN0_C, \
1952                                                    _CNL_PORT_PCS_DW1_LN0_D, \
1953                                                    _CNL_PORT_PCS_DW1_LN0_AE, \
1954                                                    _CNL_PORT_PCS_DW1_LN0_F)
1955#define   COMMON_KEEPER_EN              (1 << 26)
1956
1957#define _CNL_PORT_TX_DW2_GRP_AE         0x162348
1958#define _CNL_PORT_TX_DW2_GRP_B          0x1623C8
1959#define _CNL_PORT_TX_DW2_GRP_C          0x162B48
1960#define _CNL_PORT_TX_DW2_GRP_D          0x162BC8
1961#define _CNL_PORT_TX_DW2_GRP_F          0x162A48
1962#define _CNL_PORT_TX_DW2_LN0_AE         0x162448
1963#define _CNL_PORT_TX_DW2_LN0_B          0x162648
1964#define _CNL_PORT_TX_DW2_LN0_C          0x162C48
1965#define _CNL_PORT_TX_DW2_LN0_D          0x162E48
1966#define _CNL_PORT_TX_DW2_LN0_F          0x162A48
1967#define CNL_PORT_TX_DW2_GRP(port)       _MMIO_PORT6(port, \
1968                                                    _CNL_PORT_TX_DW2_GRP_AE, \
1969                                                    _CNL_PORT_TX_DW2_GRP_B, \
1970                                                    _CNL_PORT_TX_DW2_GRP_C, \
1971                                                    _CNL_PORT_TX_DW2_GRP_D, \
1972                                                    _CNL_PORT_TX_DW2_GRP_AE, \
1973                                                    _CNL_PORT_TX_DW2_GRP_F)
1974#define CNL_PORT_TX_DW2_LN0(port)       _MMIO_PORT6(port, \
1975                                                    _CNL_PORT_TX_DW2_LN0_AE, \
1976                                                    _CNL_PORT_TX_DW2_LN0_B, \
1977                                                    _CNL_PORT_TX_DW2_LN0_C, \
1978                                                    _CNL_PORT_TX_DW2_LN0_D, \
1979                                                    _CNL_PORT_TX_DW2_LN0_AE, \
1980                                                    _CNL_PORT_TX_DW2_LN0_F)
1981#define   SWING_SEL_UPPER(x)            ((x >> 3) << 15)
1982#define   SWING_SEL_UPPER_MASK          (1 << 15)
1983#define   SWING_SEL_LOWER(x)            ((x & 0x7) << 11)
1984#define   SWING_SEL_LOWER_MASK          (0x7 << 11)
1985#define   RCOMP_SCALAR(x)               ((x) << 0)
1986#define   RCOMP_SCALAR_MASK             (0xFF << 0)
1987
1988#define _CNL_PORT_TX_DW4_GRP_AE         0x162350
1989#define _CNL_PORT_TX_DW4_GRP_B          0x1623D0
1990#define _CNL_PORT_TX_DW4_GRP_C          0x162B50
1991#define _CNL_PORT_TX_DW4_GRP_D          0x162BD0
1992#define _CNL_PORT_TX_DW4_GRP_F          0x162A50
1993#define _CNL_PORT_TX_DW4_LN0_AE         0x162450
1994#define _CNL_PORT_TX_DW4_LN1_AE         0x1624D0
1995#define _CNL_PORT_TX_DW4_LN0_B          0x162650
1996#define _CNL_PORT_TX_DW4_LN0_C          0x162C50
1997#define _CNL_PORT_TX_DW4_LN0_D          0x162E50
1998#define _CNL_PORT_TX_DW4_LN0_F          0x162850
1999#define CNL_PORT_TX_DW4_GRP(port)       _MMIO_PORT6(port, \
2000                                                    _CNL_PORT_TX_DW4_GRP_AE, \
2001                                                    _CNL_PORT_TX_DW4_GRP_B, \
2002                                                    _CNL_PORT_TX_DW4_GRP_C, \
2003                                                    _CNL_PORT_TX_DW4_GRP_D, \
2004                                                    _CNL_PORT_TX_DW4_GRP_AE, \
2005                                                    _CNL_PORT_TX_DW4_GRP_F)
2006#define CNL_PORT_TX_DW4_LN(port, ln)       _MMIO_PORT6_LN(port, ln,     \
2007                                                    _CNL_PORT_TX_DW4_LN0_AE, \
2008                                                    _CNL_PORT_TX_DW4_LN1_AE, \
2009                                                    _CNL_PORT_TX_DW4_LN0_B, \
2010                                                    _CNL_PORT_TX_DW4_LN0_C, \
2011                                                    _CNL_PORT_TX_DW4_LN0_D, \
2012                                                    _CNL_PORT_TX_DW4_LN0_AE, \
2013                                                    _CNL_PORT_TX_DW4_LN0_F)
2014#define   LOADGEN_SELECT                (1 << 31)
2015#define   POST_CURSOR_1(x)              ((x) << 12)
2016#define   POST_CURSOR_1_MASK            (0x3F << 12)
2017#define   POST_CURSOR_2(x)              ((x) << 6)
2018#define   POST_CURSOR_2_MASK            (0x3F << 6)
2019#define   CURSOR_COEFF(x)               ((x) << 0)
2020#define   CURSOR_COEFF_MASK             (0x3F << 0)
2021
2022#define _CNL_PORT_TX_DW5_GRP_AE         0x162354
2023#define _CNL_PORT_TX_DW5_GRP_B          0x1623D4
2024#define _CNL_PORT_TX_DW5_GRP_C          0x162B54
2025#define _CNL_PORT_TX_DW5_GRP_D          0x162BD4
2026#define _CNL_PORT_TX_DW5_GRP_F          0x162A54
2027#define _CNL_PORT_TX_DW5_LN0_AE         0x162454
2028#define _CNL_PORT_TX_DW5_LN0_B          0x162654
2029#define _CNL_PORT_TX_DW5_LN0_C          0x162C54
2030#define _CNL_PORT_TX_DW5_LN0_D          0x162E54
2031#define _CNL_PORT_TX_DW5_LN0_F          0x162854
2032#define CNL_PORT_TX_DW5_GRP(port)       _MMIO_PORT6(port, \
2033                                                    _CNL_PORT_TX_DW5_GRP_AE, \
2034                                                    _CNL_PORT_TX_DW5_GRP_B, \
2035                                                    _CNL_PORT_TX_DW5_GRP_C, \
2036                                                    _CNL_PORT_TX_DW5_GRP_D, \
2037                                                    _CNL_PORT_TX_DW5_GRP_AE, \
2038                                                    _CNL_PORT_TX_DW5_GRP_F)
2039#define CNL_PORT_TX_DW5_LN0(port)       _MMIO_PORT6(port, \
2040                                                    _CNL_PORT_TX_DW5_LN0_AE, \
2041                                                    _CNL_PORT_TX_DW5_LN0_B, \
2042                                                    _CNL_PORT_TX_DW5_LN0_C, \
2043                                                    _CNL_PORT_TX_DW5_LN0_D, \
2044                                                    _CNL_PORT_TX_DW5_LN0_AE, \
2045                                                    _CNL_PORT_TX_DW5_LN0_F)
2046#define   TX_TRAINING_EN                (1 << 31)
2047#define   TAP3_DISABLE                  (1 << 29)
2048#define   SCALING_MODE_SEL(x)           ((x) << 18)
2049#define   SCALING_MODE_SEL_MASK         (0x7 << 18)
2050#define   RTERM_SELECT(x)               ((x) << 3)
2051#define   RTERM_SELECT_MASK             (0x7 << 3)
2052
2053#define _CNL_PORT_TX_DW7_GRP_AE         0x16235C
2054#define _CNL_PORT_TX_DW7_GRP_B          0x1623DC
2055#define _CNL_PORT_TX_DW7_GRP_C          0x162B5C
2056#define _CNL_PORT_TX_DW7_GRP_D          0x162BDC
2057#define _CNL_PORT_TX_DW7_GRP_F          0x162A5C
2058#define _CNL_PORT_TX_DW7_LN0_AE         0x16245C
2059#define _CNL_PORT_TX_DW7_LN0_B          0x16265C
2060#define _CNL_PORT_TX_DW7_LN0_C          0x162C5C
2061#define _CNL_PORT_TX_DW7_LN0_D          0x162E5C
2062#define _CNL_PORT_TX_DW7_LN0_F          0x16285C
2063#define CNL_PORT_TX_DW7_GRP(port)       _MMIO_PORT6(port, \
2064                                                    _CNL_PORT_TX_DW7_GRP_AE, \
2065                                                    _CNL_PORT_TX_DW7_GRP_B, \
2066                                                    _CNL_PORT_TX_DW7_GRP_C, \
2067                                                    _CNL_PORT_TX_DW7_GRP_D, \
2068                                                    _CNL_PORT_TX_DW7_GRP_AE, \
2069                                                    _CNL_PORT_TX_DW7_GRP_F)
2070#define CNL_PORT_TX_DW7_LN0(port)       _MMIO_PORT6(port, \
2071                                                    _CNL_PORT_TX_DW7_LN0_AE, \
2072                                                    _CNL_PORT_TX_DW7_LN0_B, \
2073                                                    _CNL_PORT_TX_DW7_LN0_C, \
2074                                                    _CNL_PORT_TX_DW7_LN0_D, \
2075                                                    _CNL_PORT_TX_DW7_LN0_AE, \
2076                                                    _CNL_PORT_TX_DW7_LN0_F)
2077#define   N_SCALAR(x)                   ((x) << 24)
2078#define   N_SCALAR_MASK                 (0x7F << 24)
2079
2080/* The spec defines this only for BXT PHY0, but lets assume that this
2081 * would exist for PHY1 too if it had a second channel.
2082 */
2083#define _PORT_CL2CM_DW6_A               0x162358
2084#define _PORT_CL2CM_DW6_BC              0x6C358
2085#define BXT_PORT_CL2CM_DW6(phy)         _BXT_PHY((phy), _PORT_CL2CM_DW6_BC)
2086#define   DW6_OLDO_DYN_PWR_DOWN_EN      (1 << 28)
2087
2088#define CNL_PORT_COMP_DW0               _MMIO(0x162100)
2089#define   COMP_INIT                     (1 << 31)
2090#define CNL_PORT_COMP_DW1               _MMIO(0x162104)
2091#define CNL_PORT_COMP_DW3               _MMIO(0x16210c)
2092#define   PROCESS_INFO_DOT_0            (0 << 26)
2093#define   PROCESS_INFO_DOT_1            (1 << 26)
2094#define   PROCESS_INFO_DOT_4            (2 << 26)
2095#define   PROCESS_INFO_MASK             (7 << 26)
2096#define   PROCESS_INFO_SHIFT            26
2097#define   VOLTAGE_INFO_0_85V            (0 << 24)
2098#define   VOLTAGE_INFO_0_95V            (1 << 24)
2099#define   VOLTAGE_INFO_1_05V            (2 << 24)
2100#define   VOLTAGE_INFO_MASK             (3 << 24)
2101#define   VOLTAGE_INFO_SHIFT            24
2102#define CNL_PORT_COMP_DW9               _MMIO(0x162124)
2103#define CNL_PORT_COMP_DW10              _MMIO(0x162128)
2104
2105/* BXT PHY Ref registers */
2106#define _PORT_REF_DW3_A                 0x16218C
2107#define _PORT_REF_DW3_BC                0x6C18C
2108#define   GRC_DONE                      (1 << 22)
2109#define BXT_PORT_REF_DW3(phy)           _BXT_PHY((phy), _PORT_REF_DW3_BC)
2110
2111#define _PORT_REF_DW6_A                 0x162198
2112#define _PORT_REF_DW6_BC                0x6C198
2113#define   GRC_CODE_SHIFT                24
2114#define   GRC_CODE_MASK                 (0xFF << GRC_CODE_SHIFT)
2115#define   GRC_CODE_FAST_SHIFT           16
2116#define   GRC_CODE_FAST_MASK            (0xFF << GRC_CODE_FAST_SHIFT)
2117#define   GRC_CODE_SLOW_SHIFT           8
2118#define   GRC_CODE_SLOW_MASK            (0xFF << GRC_CODE_SLOW_SHIFT)
2119#define   GRC_CODE_NOM_MASK             0xFF
2120#define BXT_PORT_REF_DW6(phy)           _BXT_PHY((phy), _PORT_REF_DW6_BC)
2121
2122#define _PORT_REF_DW8_A                 0x1621A0
2123#define _PORT_REF_DW8_BC                0x6C1A0
2124#define   GRC_DIS                       (1 << 15)
2125#define   GRC_RDY_OVRD                  (1 << 1)
2126#define BXT_PORT_REF_DW8(phy)           _BXT_PHY((phy), _PORT_REF_DW8_BC)
2127
2128/* BXT PHY PCS registers */
2129#define _PORT_PCS_DW10_LN01_A           0x162428
2130#define _PORT_PCS_DW10_LN01_B           0x6C428
2131#define _PORT_PCS_DW10_LN01_C           0x6C828
2132#define _PORT_PCS_DW10_GRP_A            0x162C28
2133#define _PORT_PCS_DW10_GRP_B            0x6CC28
2134#define _PORT_PCS_DW10_GRP_C            0x6CE28
2135#define BXT_PORT_PCS_DW10_LN01(phy, ch) _MMIO_BXT_PHY_CH(phy, ch, \
2136                                                         _PORT_PCS_DW10_LN01_B, \
2137                                                         _PORT_PCS_DW10_LN01_C)
2138#define BXT_PORT_PCS_DW10_GRP(phy, ch)  _MMIO_BXT_PHY_CH(phy, ch, \
2139                                                         _PORT_PCS_DW10_GRP_B, \
2140                                                         _PORT_PCS_DW10_GRP_C)
2141
2142#define   TX2_SWING_CALC_INIT           (1 << 31)
2143#define   TX1_SWING_CALC_INIT           (1 << 30)
2144
2145#define _PORT_PCS_DW12_LN01_A           0x162430
2146#define _PORT_PCS_DW12_LN01_B           0x6C430
2147#define _PORT_PCS_DW12_LN01_C           0x6C830
2148#define _PORT_PCS_DW12_LN23_A           0x162630
2149#define _PORT_PCS_DW12_LN23_B           0x6C630
2150#define _PORT_PCS_DW12_LN23_C           0x6CA30
2151#define _PORT_PCS_DW12_GRP_A            0x162c30
2152#define _PORT_PCS_DW12_GRP_B            0x6CC30
2153#define _PORT_PCS_DW12_GRP_C            0x6CE30
2154#define   LANESTAGGER_STRAP_OVRD        (1 << 6)
2155#define   LANE_STAGGER_MASK             0x1F
2156#define BXT_PORT_PCS_DW12_LN01(phy, ch) _MMIO_BXT_PHY_CH(phy, ch, \
2157                                                         _PORT_PCS_DW12_LN01_B, \
2158                                                         _PORT_PCS_DW12_LN01_C)
2159#define BXT_PORT_PCS_DW12_LN23(phy, ch) _MMIO_BXT_PHY_CH(phy, ch, \
2160                                                         _PORT_PCS_DW12_LN23_B, \
2161                                                         _PORT_PCS_DW12_LN23_C)
2162#define BXT_PORT_PCS_DW12_GRP(phy, ch)  _MMIO_BXT_PHY_CH(phy, ch, \
2163                                                         _PORT_PCS_DW12_GRP_B, \
2164                                                         _PORT_PCS_DW12_GRP_C)
2165
2166/* BXT PHY TX registers */
2167#define _BXT_LANE_OFFSET(lane)           (((lane) >> 1) * 0x200 +       \
2168                                          ((lane) & 1) * 0x80)
2169
2170#define _PORT_TX_DW2_LN0_A              0x162508
2171#define _PORT_TX_DW2_LN0_B              0x6C508
2172#define _PORT_TX_DW2_LN0_C              0x6C908
2173#define _PORT_TX_DW2_GRP_A              0x162D08
2174#define _PORT_TX_DW2_GRP_B              0x6CD08
2175#define _PORT_TX_DW2_GRP_C              0x6CF08
2176#define BXT_PORT_TX_DW2_LN0(phy, ch)    _MMIO_BXT_PHY_CH(phy, ch, \
2177                                                         _PORT_TX_DW2_LN0_B, \
2178                                                         _PORT_TX_DW2_LN0_C)
2179#define BXT_PORT_TX_DW2_GRP(phy, ch)    _MMIO_BXT_PHY_CH(phy, ch, \
2180                                                         _PORT_TX_DW2_GRP_B, \
2181                                                         _PORT_TX_DW2_GRP_C)
2182#define   MARGIN_000_SHIFT              16
2183#define   MARGIN_000                    (0xFF << MARGIN_000_SHIFT)
2184#define   UNIQ_TRANS_SCALE_SHIFT        8
2185#define   UNIQ_TRANS_SCALE              (0xFF << UNIQ_TRANS_SCALE_SHIFT)
2186
2187#define _PORT_TX_DW3_LN0_A              0x16250C
2188#define _PORT_TX_DW3_LN0_B              0x6C50C
2189#define _PORT_TX_DW3_LN0_C              0x6C90C
2190#define _PORT_TX_DW3_GRP_A              0x162D0C
2191#define _PORT_TX_DW3_GRP_B              0x6CD0C
2192#define _PORT_TX_DW3_GRP_C              0x6CF0C
2193#define BXT_PORT_TX_DW3_LN0(phy, ch)    _MMIO_BXT_PHY_CH(phy, ch, \
2194                                                         _PORT_TX_DW3_LN0_B, \
2195                                                         _PORT_TX_DW3_LN0_C)
2196#define BXT_PORT_TX_DW3_GRP(phy, ch)    _MMIO_BXT_PHY_CH(phy, ch, \
2197                                                         _PORT_TX_DW3_GRP_B, \
2198                                                         _PORT_TX_DW3_GRP_C)
2199#define   SCALE_DCOMP_METHOD            (1 << 26)
2200#define   UNIQUE_TRANGE_EN_METHOD       (1 << 27)
2201
2202#define _PORT_TX_DW4_LN0_A              0x162510
2203#define _PORT_TX_DW4_LN0_B              0x6C510
2204#define _PORT_TX_DW4_LN0_C              0x6C910
2205#define _PORT_TX_DW4_GRP_A              0x162D10
2206#define _PORT_TX_DW4_GRP_B              0x6CD10
2207#define _PORT_TX_DW4_GRP_C              0x6CF10
2208#define BXT_PORT_TX_DW4_LN0(phy, ch)    _MMIO_BXT_PHY_CH(phy, ch, \
2209                                                         _PORT_TX_DW4_LN0_B, \
2210                                                         _PORT_TX_DW4_LN0_C)
2211#define BXT_PORT_TX_DW4_GRP(phy, ch)    _MMIO_BXT_PHY_CH(phy, ch, \
2212                                                         _PORT_TX_DW4_GRP_B, \
2213                                                         _PORT_TX_DW4_GRP_C)
2214#define   DEEMPH_SHIFT                  24
2215#define   DE_EMPHASIS                   (0xFF << DEEMPH_SHIFT)
2216
2217#define _PORT_TX_DW5_LN0_A              0x162514
2218#define _PORT_TX_DW5_LN0_B              0x6C514
2219#define _PORT_TX_DW5_LN0_C              0x6C914
2220#define _PORT_TX_DW5_GRP_A              0x162D14
2221#define _PORT_TX_DW5_GRP_B              0x6CD14
2222#define _PORT_TX_DW5_GRP_C              0x6CF14
2223#define BXT_PORT_TX_DW5_LN0(phy, ch)    _MMIO_BXT_PHY_CH(phy, ch, \
2224                                                         _PORT_TX_DW5_LN0_B, \
2225                                                         _PORT_TX_DW5_LN0_C)
2226#define BXT_PORT_TX_DW5_GRP(phy, ch)    _MMIO_BXT_PHY_CH(phy, ch, \
2227                                                         _PORT_TX_DW5_GRP_B, \
2228                                                         _PORT_TX_DW5_GRP_C)
2229#define   DCC_DELAY_RANGE_1             (1 << 9)
2230#define   DCC_DELAY_RANGE_2             (1 << 8)
2231
2232#define _PORT_TX_DW14_LN0_A             0x162538
2233#define _PORT_TX_DW14_LN0_B             0x6C538
2234#define _PORT_TX_DW14_LN0_C             0x6C938
2235#define   LATENCY_OPTIM_SHIFT           30
2236#define   LATENCY_OPTIM                 (1 << LATENCY_OPTIM_SHIFT)
2237#define BXT_PORT_TX_DW14_LN(phy, ch, lane)                              \
2238        _MMIO(_BXT_PHY_CH(phy, ch, _PORT_TX_DW14_LN0_B,                 \
2239                                   _PORT_TX_DW14_LN0_C) +               \
2240              _BXT_LANE_OFFSET(lane))
2241
2242/* UAIMI scratch pad register 1 */
2243#define UAIMI_SPR1                      _MMIO(0x4F074)
2244/* SKL VccIO mask */
2245#define SKL_VCCIO_MASK                  0x1
2246/* SKL balance leg register */
2247#define DISPIO_CR_TX_BMU_CR0            _MMIO(0x6C00C)
2248/* I_boost values */
2249#define BALANCE_LEG_SHIFT(port)         (8+3*(port))
2250#define BALANCE_LEG_MASK(port)          (7<<(8+3*(port)))
2251/* Balance leg disable bits */
2252#define BALANCE_LEG_DISABLE_SHIFT       23
2253#define BALANCE_LEG_DISABLE(port)       (1 << (23 + (port)))
2254
2255/*
2256 * Fence registers
2257 * [0-7]  @ 0x2000 gen2,gen3
2258 * [8-15] @ 0x3000 945,g33,pnv
2259 *
2260 * [0-15] @ 0x3000 gen4,gen5
2261 *
2262 * [0-15] @ 0x100000 gen6,vlv,chv
2263 * [0-31] @ 0x100000 gen7+
2264 */
2265#define FENCE_REG(i)                    _MMIO(0x2000 + (((i) & 8) << 9) + ((i) & 7) * 4)
2266#define   I830_FENCE_START_MASK         0x07f80000
2267#define   I830_FENCE_TILING_Y_SHIFT     12
2268#define   I830_FENCE_SIZE_BITS(size)    ((ffs((size) >> 19) - 1) << 8)
2269#define   I830_FENCE_PITCH_SHIFT        4
2270#define   I830_FENCE_REG_VALID          (1<<0)
2271#define   I915_FENCE_MAX_PITCH_VAL      4
2272#define   I830_FENCE_MAX_PITCH_VAL      6
2273#define   I830_FENCE_MAX_SIZE_VAL       (1<<8)
2274
2275#define   I915_FENCE_START_MASK         0x0ff00000
2276#define   I915_FENCE_SIZE_BITS(size)    ((ffs((size) >> 20) - 1) << 8)
2277
2278#define FENCE_REG_965_LO(i)             _MMIO(0x03000 + (i) * 8)
2279#define FENCE_REG_965_HI(i)             _MMIO(0x03000 + (i) * 8 + 4)
2280#define   I965_FENCE_PITCH_SHIFT        2
2281#define   I965_FENCE_TILING_Y_SHIFT     1
2282#define   I965_FENCE_REG_VALID          (1<<0)
2283#define   I965_FENCE_MAX_PITCH_VAL      0x0400
2284
2285#define FENCE_REG_GEN6_LO(i)            _MMIO(0x100000 + (i) * 8)
2286#define FENCE_REG_GEN6_HI(i)            _MMIO(0x100000 + (i) * 8 + 4)
2287#define   GEN6_FENCE_PITCH_SHIFT        32
2288#define   GEN7_FENCE_MAX_PITCH_VAL      0x0800
2289
2290
2291/* control register for cpu gtt access */
2292#define TILECTL                         _MMIO(0x101000)
2293#define   TILECTL_SWZCTL                        (1 << 0)
2294#define   TILECTL_TLBPF                 (1 << 1)
2295#define   TILECTL_TLB_PREFETCH_DIS      (1 << 2)
2296#define   TILECTL_BACKSNOOP_DIS         (1 << 3)
2297
2298/*
2299 * Instruction and interrupt control regs
2300 */
2301#define PGTBL_CTL       _MMIO(0x02020)
2302#define   PGTBL_ADDRESS_LO_MASK 0xfffff000 /* bits [31:12] */
2303#define   PGTBL_ADDRESS_HI_MASK 0x000000f0 /* bits [35:32] (gen4) */
2304#define PGTBL_ER        _MMIO(0x02024)
2305#define PRB0_BASE       (0x2030-0x30)
2306#define PRB1_BASE       (0x2040-0x30) /* 830,gen3 */
2307#define PRB2_BASE       (0x2050-0x30) /* gen3 */
2308#define SRB0_BASE       (0x2100-0x30) /* gen2 */
2309#define SRB1_BASE       (0x2110-0x30) /* gen2 */
2310#define SRB2_BASE       (0x2120-0x30) /* 830 */
2311#define SRB3_BASE       (0x2130-0x30) /* 830 */
2312#define RENDER_RING_BASE        0x02000
2313#define BSD_RING_BASE           0x04000
2314#define GEN6_BSD_RING_BASE      0x12000
2315#define GEN8_BSD2_RING_BASE     0x1c000
2316#define VEBOX_RING_BASE         0x1a000
2317#define BLT_RING_BASE           0x22000
2318#define RING_TAIL(base)         _MMIO((base)+0x30)
2319#define RING_HEAD(base)         _MMIO((base)+0x34)
2320#define RING_START(base)        _MMIO((base)+0x38)
2321#define RING_CTL(base)          _MMIO((base)+0x3c)
2322#define   RING_CTL_SIZE(size)   ((size) - PAGE_SIZE) /* in bytes -> pages */
2323#define RING_SYNC_0(base)       _MMIO((base)+0x40)
2324#define RING_SYNC_1(base)       _MMIO((base)+0x44)
2325#define RING_SYNC_2(base)       _MMIO((base)+0x48)
2326#define GEN6_RVSYNC     (RING_SYNC_0(RENDER_RING_BASE))
2327#define GEN6_RBSYNC     (RING_SYNC_1(RENDER_RING_BASE))
2328#define GEN6_RVESYNC    (RING_SYNC_2(RENDER_RING_BASE))
2329#define GEN6_VBSYNC     (RING_SYNC_0(GEN6_BSD_RING_BASE))
2330#define GEN6_VRSYNC     (RING_SYNC_1(GEN6_BSD_RING_BASE))
2331#define GEN6_VVESYNC    (RING_SYNC_2(GEN6_BSD_RING_BASE))
2332#define GEN6_BRSYNC     (RING_SYNC_0(BLT_RING_BASE))
2333#define GEN6_BVSYNC     (RING_SYNC_1(BLT_RING_BASE))
2334#define GEN6_BVESYNC    (RING_SYNC_2(BLT_RING_BASE))
2335#define GEN6_VEBSYNC    (RING_SYNC_0(VEBOX_RING_BASE))
2336#define GEN6_VERSYNC    (RING_SYNC_1(VEBOX_RING_BASE))
2337#define GEN6_VEVSYNC    (RING_SYNC_2(VEBOX_RING_BASE))
2338#define GEN6_NOSYNC     INVALID_MMIO_REG
2339#define RING_PSMI_CTL(base)     _MMIO((base)+0x50)
2340#define RING_MAX_IDLE(base)     _MMIO((base)+0x54)
2341#define RING_HWS_PGA(base)      _MMIO((base)+0x80)
2342#define RING_HWS_PGA_GEN6(base) _MMIO((base)+0x2080)
2343#define RING_RESET_CTL(base)    _MMIO((base)+0xd0)
2344#define   RESET_CTL_REQUEST_RESET  (1 << 0)
2345#define   RESET_CTL_READY_TO_RESET (1 << 1)
2346
2347#define HSW_GTT_CACHE_EN        _MMIO(0x4024)
2348#define   GTT_CACHE_EN_ALL      0xF0007FFF
2349#define GEN7_WR_WATERMARK       _MMIO(0x4028)
2350#define GEN7_GFX_PRIO_CTRL      _MMIO(0x402C)
2351#define ARB_MODE                _MMIO(0x4030)
2352#define   ARB_MODE_SWIZZLE_SNB  (1<<4)
2353#define   ARB_MODE_SWIZZLE_IVB  (1<<5)
2354#define GEN7_GFX_PEND_TLB0      _MMIO(0x4034)
2355#define GEN7_GFX_PEND_TLB1      _MMIO(0x4038)
2356/* L3, CVS, ZTLB, RCC, CASC LRA min, max values */
2357#define GEN7_LRA_LIMITS(i)      _MMIO(0x403C + (i) * 4)
2358#define GEN7_LRA_LIMITS_REG_NUM 13
2359#define GEN7_MEDIA_MAX_REQ_COUNT        _MMIO(0x4070)
2360#define GEN7_GFX_MAX_REQ_COUNT          _MMIO(0x4074)
2361
2362#define GAMTARBMODE             _MMIO(0x04a08)
2363#define   ARB_MODE_BWGTLB_DISABLE (1<<9)
2364#define   ARB_MODE_SWIZZLE_BDW  (1<<1)
2365#define RENDER_HWS_PGA_GEN7     _MMIO(0x04080)
2366#define RING_FAULT_REG(engine)  _MMIO(0x4094 + 0x100*(engine)->hw_id)
2367#define GEN8_RING_FAULT_REG     _MMIO(0x4094)
2368#define   GEN8_RING_FAULT_ENGINE_ID(x)  (((x) >> 12) & 0x7)
2369#define   RING_FAULT_GTTSEL_MASK (1<<11)
2370#define   RING_FAULT_SRCID(x)   (((x) >> 3) & 0xff)
2371#define   RING_FAULT_FAULT_TYPE(x) (((x) >> 1) & 0x3)
2372#define   RING_FAULT_VALID      (1<<0)
2373#define DONE_REG                _MMIO(0x40b0)
2374#define GEN8_PRIVATE_PAT_LO     _MMIO(0x40e0)
2375#define GEN8_PRIVATE_PAT_HI     _MMIO(0x40e0 + 4)
2376#define GEN10_PAT_INDEX(index)  _MMIO(0x40e0 + (index)*4)
2377#define BSD_HWS_PGA_GEN7        _MMIO(0x04180)
2378#define BLT_HWS_PGA_GEN7        _MMIO(0x04280)
2379#define VEBOX_HWS_PGA_GEN7      _MMIO(0x04380)
2380#define RING_ACTHD(base)        _MMIO((base)+0x74)
2381#define RING_ACTHD_UDW(base)    _MMIO((base)+0x5c)
2382#define RING_NOPID(base)        _MMIO((base)+0x94)
2383#define RING_IMR(base)          _MMIO((base)+0xa8)
2384#define RING_HWSTAM(base)       _MMIO((base)+0x98)
2385#define RING_TIMESTAMP(base)            _MMIO((base)+0x358)
2386#define RING_TIMESTAMP_UDW(base)        _MMIO((base)+0x358 + 4)
2387#define   TAIL_ADDR             0x001FFFF8
2388#define   HEAD_WRAP_COUNT       0xFFE00000
2389#define   HEAD_WRAP_ONE         0x00200000
2390#define   HEAD_ADDR             0x001FFFFC
2391#define   RING_NR_PAGES         0x001FF000
2392#define   RING_REPORT_MASK      0x00000006
2393#define   RING_REPORT_64K       0x00000002
2394#define   RING_REPORT_128K      0x00000004
2395#define   RING_NO_REPORT        0x00000000
2396#define   RING_VALID_MASK       0x00000001
2397#define   RING_VALID            0x00000001
2398#define   RING_INVALID          0x00000000
2399#define   RING_WAIT_I8XX        (1<<0) /* gen2, PRBx_HEAD */
2400#define   RING_WAIT             (1<<11) /* gen3+, PRBx_CTL */
2401#define   RING_WAIT_SEMAPHORE   (1<<10) /* gen6+ */
2402
2403#define RING_FORCE_TO_NONPRIV(base, i) _MMIO(((base)+0x4D0) + (i)*4)
2404#define   RING_MAX_NONPRIV_SLOTS  12
2405
2406#define GEN7_TLB_RD_ADDR        _MMIO(0x4700)
2407
2408#define GEN9_GAMT_ECO_REG_RW_IA _MMIO(0x4ab0)
2409#define   GAMT_ECO_ENABLE_IN_PLACE_DECOMPRESS   (1<<18)
2410
2411#define GEN8_GAMW_ECO_DEV_RW_IA _MMIO(0x4080)
2412#define   GAMW_ECO_ENABLE_64K_IPS_FIELD 0xF
2413
2414#define GAMT_CHKN_BIT_REG       _MMIO(0x4ab8)
2415#define   GAMT_CHKN_DISABLE_DYNAMIC_CREDIT_SHARING      (1<<28)
2416#define   GAMT_CHKN_DISABLE_I2M_CYCLE_ON_WR_PORT        (1<<24)
2417
2418#if 0
2419#define PRB0_TAIL       _MMIO(0x2030)
2420#define PRB0_HEAD       _MMIO(0x2034)
2421#define PRB0_START      _MMIO(0x2038)
2422#define PRB0_CTL        _MMIO(0x203c)
2423#define PRB1_TAIL       _MMIO(0x2040) /* 915+ only */
2424#define PRB1_HEAD       _MMIO(0x2044) /* 915+ only */
2425#define PRB1_START      _MMIO(0x2048) /* 915+ only */
2426#define PRB1_CTL        _MMIO(0x204c) /* 915+ only */
2427#endif
2428#define IPEIR_I965      _MMIO(0x2064)
2429#define IPEHR_I965      _MMIO(0x2068)
2430#define GEN7_SC_INSTDONE        _MMIO(0x7100)
2431#define GEN7_SAMPLER_INSTDONE   _MMIO(0xe160)
2432#define GEN7_ROW_INSTDONE       _MMIO(0xe164)
2433#define GEN8_MCR_SELECTOR               _MMIO(0xfdc)
2434#define   GEN8_MCR_SLICE(slice)         (((slice) & 3) << 26)
2435#define   GEN8_MCR_SLICE_MASK           GEN8_MCR_SLICE(3)
2436#define   GEN8_MCR_SUBSLICE(subslice)   (((subslice) & 3) << 24)
2437#define   GEN8_MCR_SUBSLICE_MASK        GEN8_MCR_SUBSLICE(3)
2438#define RING_IPEIR(base)        _MMIO((base)+0x64)
2439#define RING_IPEHR(base)        _MMIO((base)+0x68)
2440/*
2441 * On GEN4, only the render ring INSTDONE exists and has a different
2442 * layout than the GEN7+ version.
2443 * The GEN2 counterpart of this register is GEN2_INSTDONE.
2444 */
2445#define RING_INSTDONE(base)     _MMIO((base)+0x6c)
2446#define RING_INSTPS(base)       _MMIO((base)+0x70)
2447#define RING_DMA_FADD(base)     _MMIO((base)+0x78)
2448#define RING_DMA_FADD_UDW(base) _MMIO((base)+0x60) /* gen8+ */
2449#define RING_INSTPM(base)       _MMIO((base)+0xc0)
2450#define RING_MI_MODE(base)      _MMIO((base)+0x9c)
2451#define INSTPS          _MMIO(0x2070) /* 965+ only */
2452#define GEN4_INSTDONE1  _MMIO(0x207c) /* 965+ only, aka INSTDONE_2 on SNB */
2453#define ACTHD_I965      _MMIO(0x2074)
2454#define HWS_PGA         _MMIO(0x2080)
2455#define HWS_ADDRESS_MASK        0xfffff000
2456#define HWS_START_ADDRESS_SHIFT 4
2457#define PWRCTXA         _MMIO(0x2088) /* 965GM+ only */
2458#define   PWRCTX_EN     (1<<0)
2459#define IPEIR           _MMIO(0x2088)
2460#define IPEHR           _MMIO(0x208c)
2461#define GEN2_INSTDONE   _MMIO(0x2090)
2462#define NOPID           _MMIO(0x2094)
2463#define HWSTAM          _MMIO(0x2098)
2464#define DMA_FADD_I8XX   _MMIO(0x20d0)
2465#define RING_BBSTATE(base)      _MMIO((base)+0x110)
2466#define   RING_BB_PPGTT         (1 << 5)
2467#define RING_SBBADDR(base)      _MMIO((base)+0x114) /* hsw+ */
2468#define RING_SBBSTATE(base)     _MMIO((base)+0x118) /* hsw+ */
2469#define RING_SBBADDR_UDW(base)  _MMIO((base)+0x11c) /* gen8+ */
2470#define RING_BBADDR(base)       _MMIO((base)+0x140)
2471#define RING_BBADDR_UDW(base)   _MMIO((base)+0x168) /* gen8+ */
2472#define RING_BB_PER_CTX_PTR(base)       _MMIO((base)+0x1c0) /* gen8+ */
2473#define RING_INDIRECT_CTX(base)         _MMIO((base)+0x1c4) /* gen8+ */
2474#define RING_INDIRECT_CTX_OFFSET(base)  _MMIO((base)+0x1c8) /* gen8+ */
2475#define RING_CTX_TIMESTAMP(base)        _MMIO((base)+0x3a8) /* gen8+ */
2476
2477#define ERROR_GEN6      _MMIO(0x40a0)
2478#define GEN7_ERR_INT    _MMIO(0x44040)
2479#define   ERR_INT_POISON                (1<<31)
2480#define   ERR_INT_MMIO_UNCLAIMED        (1<<13)
2481#define   ERR_INT_PIPE_CRC_DONE_C       (1<<8)
2482#define   ERR_INT_FIFO_UNDERRUN_C       (1<<6)
2483#define   ERR_INT_PIPE_CRC_DONE_B       (1<<5)
2484#define   ERR_INT_FIFO_UNDERRUN_B       (1<<3)
2485#define   ERR_INT_PIPE_CRC_DONE_A       (1<<2)
2486#define   ERR_INT_PIPE_CRC_DONE(pipe)   (1<<(2 + (pipe)*3))
2487#define   ERR_INT_FIFO_UNDERRUN_A       (1<<0)
2488#define   ERR_INT_FIFO_UNDERRUN(pipe)   (1<<((pipe)*3))
2489
2490#define GEN8_FAULT_TLB_DATA0            _MMIO(0x4b10)
2491#define GEN8_FAULT_TLB_DATA1            _MMIO(0x4b14)
2492#define   FAULT_VA_HIGH_BITS            (0xf << 0)
2493#define   FAULT_GTT_SEL                 (1 << 4)
2494
2495#define FPGA_DBG                _MMIO(0x42300)
2496#define   FPGA_DBG_RM_NOCLAIM   (1<<31)
2497
2498#define CLAIM_ER                _MMIO(VLV_DISPLAY_BASE + 0x2028)
2499#define   CLAIM_ER_CLR          (1 << 31)
2500#define   CLAIM_ER_OVERFLOW     (1 << 16)
2501#define   CLAIM_ER_CTR_MASK     0xffff
2502
2503#define DERRMR          _MMIO(0x44050)
2504/* Note that HBLANK events are reserved on bdw+ */
2505#define   DERRMR_PIPEA_SCANLINE         (1<<0)
2506#define   DERRMR_PIPEA_PRI_FLIP_DONE    (1<<1)
2507#define   DERRMR_PIPEA_SPR_FLIP_DONE    (1<<2)
2508#define   DERRMR_PIPEA_VBLANK           (1<<3)
2509#define   DERRMR_PIPEA_HBLANK           (1<<5)
2510#define   DERRMR_PIPEB_SCANLINE         (1<<8)
2511#define   DERRMR_PIPEB_PRI_FLIP_DONE    (1<<9)
2512#define   DERRMR_PIPEB_SPR_FLIP_DONE    (1<<10)
2513#define   DERRMR_PIPEB_VBLANK           (1<<11)
2514#define   DERRMR_PIPEB_HBLANK           (1<<13)
2515/* Note that PIPEC is not a simple translation of PIPEA/PIPEB */
2516#define   DERRMR_PIPEC_SCANLINE         (1<<14)
2517#define   DERRMR_PIPEC_PRI_FLIP_DONE    (1<<15)
2518#define   DERRMR_PIPEC_SPR_FLIP_DONE    (1<<20)
2519#define   DERRMR_PIPEC_VBLANK           (1<<21)
2520#define   DERRMR_PIPEC_HBLANK           (1<<22)
2521
2522
2523/* GM45+ chicken bits -- debug workaround bits that may be required
2524 * for various sorts of correct behavior.  The top 16 bits of each are
2525 * the enables for writing to the corresponding low bit.
2526 */
2527#define _3D_CHICKEN     _MMIO(0x2084)
2528#define  _3D_CHICKEN_HIZ_PLANE_DISABLE_MSAA_4X_SNB      (1 << 10)
2529#define _3D_CHICKEN2    _MMIO(0x208c)
2530/* Disables pipelining of read flushes past the SF-WIZ interface.
2531 * Required on all Ironlake steppings according to the B-Spec, but the
2532 * particular danger of not doing so is not specified.
2533 */
2534# define _3D_CHICKEN2_WM_READ_PIPELINED                 (1 << 14)
2535#define _3D_CHICKEN3    _MMIO(0x2090)
2536#define  _3D_CHICKEN_SF_DISABLE_OBJEND_CULL             (1 << 10)
2537#define  _3D_CHICKEN3_AA_LINE_QUALITY_FIX_ENABLE        (1 << 5)
2538#define  _3D_CHICKEN3_SF_DISABLE_FASTCLIP_CULL          (1 << 5)
2539#define  _3D_CHICKEN_SDE_LIMIT_FIFO_POLY_DEPTH(x)       ((x)<<1) /* gen8+ */
2540#define  _3D_CHICKEN3_SF_DISABLE_PIPELINED_ATTR_FETCH   (1 << 1) /* gen6 */
2541
2542#define MI_MODE         _MMIO(0x209c)
2543# define VS_TIMER_DISPATCH                              (1 << 6)
2544# define MI_FLUSH_ENABLE                                (1 << 12)
2545# define ASYNC_FLIP_PERF_DISABLE                        (1 << 14)
2546# define MODE_IDLE                                      (1 << 9)
2547# define STOP_RING                                      (1 << 8)
2548
2549#define GEN6_GT_MODE    _MMIO(0x20d0)
2550#define GEN7_GT_MODE    _MMIO(0x7008)
2551#define   GEN6_WIZ_HASHING(hi, lo)                      (((hi) << 9) | ((lo) << 7))
2552#define   GEN6_WIZ_HASHING_8x8                          GEN6_WIZ_HASHING(0, 0)
2553#define   GEN6_WIZ_HASHING_8x4                          GEN6_WIZ_HASHING(0, 1)
2554#define   GEN6_WIZ_HASHING_16x4                         GEN6_WIZ_HASHING(1, 0)
2555#define   GEN6_WIZ_HASHING_MASK                         GEN6_WIZ_HASHING(1, 1)
2556#define   GEN6_TD_FOUR_ROW_DISPATCH_DISABLE             (1 << 5)
2557#define   GEN9_IZ_HASHING_MASK(slice)                   (0x3 << ((slice) * 2))
2558#define   GEN9_IZ_HASHING(slice, val)                   ((val) << ((slice) * 2))
2559
2560/* chicken reg for WaConextSwitchWithConcurrentTLBInvalidate */
2561#define GEN9_CSFE_CHICKEN1_RCS _MMIO(0x20D4)
2562#define   GEN9_PREEMPT_GPGPU_SYNC_SWITCH_DISABLE (1 << 2)
2563
2564/* WaClearTdlStateAckDirtyBits */
2565#define GEN8_STATE_ACK          _MMIO(0x20F0)
2566#define GEN9_STATE_ACK_SLICE1   _MMIO(0x20F8)
2567#define GEN9_STATE_ACK_SLICE2   _MMIO(0x2100)
2568#define   GEN9_STATE_ACK_TDL0 (1 << 12)
2569#define   GEN9_STATE_ACK_TDL1 (1 << 13)
2570#define   GEN9_STATE_ACK_TDL2 (1 << 14)
2571#define   GEN9_STATE_ACK_TDL3 (1 << 15)
2572#define   GEN9_SUBSLICE_TDL_ACK_BITS \
2573        (GEN9_STATE_ACK_TDL3 | GEN9_STATE_ACK_TDL2 | \
2574         GEN9_STATE_ACK_TDL1 | GEN9_STATE_ACK_TDL0)
2575
2576#define GFX_MODE        _MMIO(0x2520)
2577#define GFX_MODE_GEN7   _MMIO(0x229c)
2578#define RING_MODE_GEN7(engine)  _MMIO((engine)->mmio_base+0x29c)
2579#define   GFX_RUN_LIST_ENABLE           (1<<15)
2580#define   GFX_INTERRUPT_STEERING        (1<<14)
2581#define   GFX_TLB_INVALIDATE_EXPLICIT   (1<<13)
2582#define   GFX_SURFACE_FAULT_ENABLE      (1<<12)
2583#define   GFX_REPLAY_MODE               (1<<11)
2584#define   GFX_PSMI_GRANULARITY          (1<<10)
2585#define   GFX_PPGTT_ENABLE              (1<<9)
2586#define   GEN8_GFX_PPGTT_48B            (1<<7)
2587
2588#define   GFX_FORWARD_VBLANK_MASK       (3<<5)
2589#define   GFX_FORWARD_VBLANK_NEVER      (0<<5)
2590#define   GFX_FORWARD_VBLANK_ALWAYS     (1<<5)
2591#define   GFX_FORWARD_VBLANK_COND       (2<<5)
2592
2593#define VLV_DISPLAY_BASE 0x180000
2594#define VLV_MIPI_BASE VLV_DISPLAY_BASE
2595#define BXT_MIPI_BASE 0x60000
2596
2597#define VLV_GU_CTL0     _MMIO(VLV_DISPLAY_BASE + 0x2030)
2598#define VLV_GU_CTL1     _MMIO(VLV_DISPLAY_BASE + 0x2034)
2599#define SCPD0           _MMIO(0x209c) /* 915+ only */
2600#define IER             _MMIO(0x20a0)
2601#define IIR             _MMIO(0x20a4)
2602#define IMR             _MMIO(0x20a8)
2603#define ISR             _MMIO(0x20ac)
2604#define VLV_GUNIT_CLOCK_GATE    _MMIO(VLV_DISPLAY_BASE + 0x2060)
2605#define   GINT_DIS              (1<<22)
2606#define   GCFG_DIS              (1<<8)
2607#define VLV_GUNIT_CLOCK_GATE2   _MMIO(VLV_DISPLAY_BASE + 0x2064)
2608#define VLV_IIR_RW      _MMIO(VLV_DISPLAY_BASE + 0x2084)
2609#define VLV_IER         _MMIO(VLV_DISPLAY_BASE + 0x20a0)
2610#define VLV_IIR         _MMIO(VLV_DISPLAY_BASE + 0x20a4)
2611#define VLV_IMR         _MMIO(VLV_DISPLAY_BASE + 0x20a8)
2612#define VLV_ISR         _MMIO(VLV_DISPLAY_BASE + 0x20ac)
2613#define VLV_PCBR        _MMIO(VLV_DISPLAY_BASE + 0x2120)
2614#define VLV_PCBR_ADDR_SHIFT     12
2615
2616#define   DISPLAY_PLANE_FLIP_PENDING(plane) (1<<(11-(plane))) /* A and B only */
2617#define EIR             _MMIO(0x20b0)
2618#define EMR             _MMIO(0x20b4)
2619#define ESR             _MMIO(0x20b8)
2620#define   GM45_ERROR_PAGE_TABLE                         (1<<5)
2621#define   GM45_ERROR_MEM_PRIV                           (1<<4)
2622#define   I915_ERROR_PAGE_TABLE                         (1<<4)
2623#define   GM45_ERROR_CP_PRIV                            (1<<3)
2624#define   I915_ERROR_MEMORY_REFRESH                     (1<<1)
2625#define   I915_ERROR_INSTRUCTION                        (1<<0)
2626#define INSTPM          _MMIO(0x20c0)
2627#define   INSTPM_SELF_EN (1<<12) /* 915GM only */
2628#define   INSTPM_AGPBUSY_INT_EN (1<<11) /* gen3: when disabled, pending interrupts
2629                                        will not assert AGPBUSY# and will only
2630                                        be delivered when out of C3. */
2631#define   INSTPM_FORCE_ORDERING                         (1<<7) /* GEN6+ */
2632#define   INSTPM_TLB_INVALIDATE (1<<9)
2633#define   INSTPM_SYNC_FLUSH     (1<<5)
2634#define ACTHD           _MMIO(0x20c8)
2635#define MEM_MODE        _MMIO(0x20cc)
2636#define   MEM_DISPLAY_B_TRICKLE_FEED_DISABLE (1<<3) /* 830 only */
2637#define   MEM_DISPLAY_A_TRICKLE_FEED_DISABLE (1<<2) /* 830/845 only */
2638#define   MEM_DISPLAY_TRICKLE_FEED_DISABLE (1<<2) /* 85x only */
2639#define FW_BLC          _MMIO(0x20d8)
2640#define FW_BLC2         _MMIO(0x20dc)
2641#define FW_BLC_SELF     _MMIO(0x20e0) /* 915+ only */
2642#define   FW_BLC_SELF_EN_MASK      (1<<31)
2643#define   FW_BLC_SELF_FIFO_MASK    (1<<16) /* 945 only */
2644#define   FW_BLC_SELF_EN           (1<<15) /* 945 only */
2645#define MM_BURST_LENGTH     0x00700000
2646#define MM_FIFO_WATERMARK   0x0001F000
2647#define LM_BURST_LENGTH     0x00000700
2648#define LM_FIFO_WATERMARK   0x0000001F
2649#define MI_ARB_STATE    _MMIO(0x20e4) /* 915+ only */
2650
2651/* Make render/texture TLB fetches lower priorty than associated data
2652 *   fetches. This is not turned on by default
2653 */
2654#define   MI_ARB_RENDER_TLB_LOW_PRIORITY        (1 << 15)
2655
2656/* Isoch request wait on GTT enable (Display A/B/C streams).
2657 * Make isoch requests stall on the TLB update. May cause
2658 * display underruns (test mode only)
2659 */
2660#define   MI_ARB_ISOCH_WAIT_GTT                 (1 << 14)
2661
2662/* Block grant count for isoch requests when block count is
2663 * set to a finite value.
2664 */
2665#define   MI_ARB_BLOCK_GRANT_MASK               (3 << 12)
2666#define   MI_ARB_BLOCK_GRANT_8                  (0 << 12)       /* for 3 display planes */
2667#define   MI_ARB_BLOCK_GRANT_4                  (1 << 12)       /* for 2 display planes */
2668#define   MI_ARB_BLOCK_GRANT_2                  (2 << 12)       /* for 1 display plane */
2669#define   MI_ARB_BLOCK_GRANT_0                  (3 << 12)       /* don't use */
2670
2671/* Enable render writes to complete in C2/C3/C4 power states.
2672 * If this isn't enabled, render writes are prevented in low
2673 * power states. That seems bad to me.
2674 */
2675#define   MI_ARB_C3_LP_WRITE_ENABLE             (1 << 11)
2676
2677/* This acknowledges an async flip immediately instead
2678 * of waiting for 2TLB fetches.
2679 */
2680#define   MI_ARB_ASYNC_FLIP_ACK_IMMEDIATE       (1 << 10)
2681
2682/* Enables non-sequential data reads through arbiter
2683 */
2684#define   MI_ARB_DUAL_DATA_PHASE_DISABLE        (1 << 9)
2685
2686/* Disable FSB snooping of cacheable write cycles from binner/render
2687 * command stream
2688 */
2689#define   MI_ARB_CACHE_SNOOP_DISABLE            (1 << 8)
2690
2691/* Arbiter time slice for non-isoch streams */
2692#define   MI_ARB_TIME_SLICE_MASK                (7 << 5)
2693#define   MI_ARB_TIME_SLICE_1                   (0 << 5)
2694#define   MI_ARB_TIME_SLICE_2                   (1 << 5)
2695#define   MI_ARB_TIME_SLICE_4                   (2 << 5)
2696#define   MI_ARB_TIME_SLICE_6                   (3 << 5)
2697#define   MI_ARB_TIME_SLICE_8                   (4 << 5)
2698#define   MI_ARB_TIME_SLICE_10                  (5 << 5)
2699#define   MI_ARB_TIME_SLICE_14                  (6 << 5)
2700#define   MI_ARB_TIME_SLICE_16                  (7 << 5)
2701
2702/* Low priority grace period page size */
2703#define   MI_ARB_LOW_PRIORITY_GRACE_4KB         (0 << 4)        /* default */
2704#define   MI_ARB_LOW_PRIORITY_GRACE_8KB         (1 << 4)
2705
2706/* Disable display A/B trickle feed */
2707#define   MI_ARB_DISPLAY_TRICKLE_FEED_DISABLE   (1 << 2)
2708
2709/* Set display plane priority */
2710#define   MI_ARB_DISPLAY_PRIORITY_A_B           (0 << 0)        /* display A > display B */
2711#define   MI_ARB_DISPLAY_PRIORITY_B_A           (1 << 0)        /* display B > display A */
2712
2713#define MI_STATE        _MMIO(0x20e4) /* gen2 only */
2714#define   MI_AGPBUSY_INT_EN                     (1 << 1) /* 85x only */
2715#define   MI_AGPBUSY_830_MODE                   (1 << 0) /* 85x only */
2716
2717#define CACHE_MODE_0    _MMIO(0x2120) /* 915+ only */
2718#define   CM0_PIPELINED_RENDER_FLUSH_DISABLE (1<<8)
2719#define   CM0_IZ_OPT_DISABLE      (1<<6)
2720#define   CM0_ZR_OPT_DISABLE      (1<<5)
2721#define   CM0_STC_EVICT_DISABLE_LRA_SNB (1<<5)
2722#define   CM0_DEPTH_EVICT_DISABLE (1<<4)
2723#define   CM0_COLOR_EVICT_DISABLE (1<<3)
2724#define   CM0_DEPTH_WRITE_DISABLE (1<<1)
2725#define   CM0_RC_OP_FLUSH_DISABLE (1<<0)
2726#define GFX_FLSH_CNTL   _MMIO(0x2170) /* 915+ only */
2727#define GFX_FLSH_CNTL_GEN6      _MMIO(0x101008)
2728#define   GFX_FLSH_CNTL_EN      (1<<0)
2729#define ECOSKPD         _MMIO(0x21d0)
2730#define   ECO_GATING_CX_ONLY    (1<<3)
2731#define   ECO_FLIP_DONE         (1<<0)
2732
2733#define CACHE_MODE_0_GEN7       _MMIO(0x7000) /* IVB+ */
2734#define RC_OP_FLUSH_ENABLE (1<<0)
2735#define   HIZ_RAW_STALL_OPT_DISABLE (1<<2)
2736#define CACHE_MODE_1            _MMIO(0x7004) /* IVB+ */
2737#define   PIXEL_SUBSPAN_COLLECT_OPT_DISABLE     (1<<6)
2738#define   GEN8_4x4_STC_OPTIMIZATION_DISABLE     (1<<6)
2739#define   GEN9_PARTIAL_RESOLVE_IN_VC_DISABLE    (1<<1)
2740
2741#define GEN6_BLITTER_ECOSKPD    _MMIO(0x221d0)
2742#define   GEN6_BLITTER_LOCK_SHIFT                       16
2743#define   GEN6_BLITTER_FBC_NOTIFY                       (1<<3)
2744
2745#define GEN6_RC_SLEEP_PSMI_CONTROL      _MMIO(0x2050)
2746#define   GEN6_PSMI_SLEEP_MSG_DISABLE   (1 << 0)
2747#define   GEN8_RC_SEMA_IDLE_MSG_DISABLE (1 << 12)
2748#define   GEN8_FF_DOP_CLOCK_GATE_DISABLE        (1<<10)
2749
2750#define GEN6_RCS_PWR_FSM _MMIO(0x22ac)
2751#define GEN9_RCS_FE_FSM2 _MMIO(0x22a4)
2752
2753/* Fuse readout registers for GT */
2754#define CHV_FUSE_GT                     _MMIO(VLV_DISPLAY_BASE + 0x2168)
2755#define   CHV_FGT_DISABLE_SS0           (1 << 10)
2756#define   CHV_FGT_DISABLE_SS1           (1 << 11)
2757#define   CHV_FGT_EU_DIS_SS0_R0_SHIFT   16
2758#define   CHV_FGT_EU_DIS_SS0_R0_MASK    (0xf << CHV_FGT_EU_DIS_SS0_R0_SHIFT)
2759#define   CHV_FGT_EU_DIS_SS0_R1_SHIFT   20
2760#define   CHV_FGT_EU_DIS_SS0_R1_MASK    (0xf << CHV_FGT_EU_DIS_SS0_R1_SHIFT)
2761#define   CHV_FGT_EU_DIS_SS1_R0_SHIFT   24
2762#define   CHV_FGT_EU_DIS_SS1_R0_MASK    (0xf << CHV_FGT_EU_DIS_SS1_R0_SHIFT)
2763#define   CHV_FGT_EU_DIS_SS1_R1_SHIFT   28
2764#define   CHV_FGT_EU_DIS_SS1_R1_MASK    (0xf << CHV_FGT_EU_DIS_SS1_R1_SHIFT)
2765
2766#define GEN8_FUSE2                      _MMIO(0x9120)
2767#define   GEN8_F2_SS_DIS_SHIFT          21
2768#define   GEN8_F2_SS_DIS_MASK           (0x7 << GEN8_F2_SS_DIS_SHIFT)
2769#define   GEN8_F2_S_ENA_SHIFT           25
2770#define   GEN8_F2_S_ENA_MASK            (0x7 << GEN8_F2_S_ENA_SHIFT)
2771
2772#define   GEN9_F2_SS_DIS_SHIFT          20
2773#define   GEN9_F2_SS_DIS_MASK           (0xf << GEN9_F2_SS_DIS_SHIFT)
2774
2775#define   GEN10_F2_S_ENA_SHIFT          22
2776#define   GEN10_F2_S_ENA_MASK           (0x3f << GEN10_F2_S_ENA_SHIFT)
2777#define   GEN10_F2_SS_DIS_SHIFT         18
2778#define   GEN10_F2_SS_DIS_MASK          (0xf << GEN10_F2_SS_DIS_SHIFT)
2779
2780#define GEN8_EU_DISABLE0                _MMIO(0x9134)
2781#define   GEN8_EU_DIS0_S0_MASK          0xffffff
2782#define   GEN8_EU_DIS0_S1_SHIFT         24
2783#define   GEN8_EU_DIS0_S1_MASK          (0xff << GEN8_EU_DIS0_S1_SHIFT)
2784
2785#define GEN8_EU_DISABLE1                _MMIO(0x9138)
2786#define   GEN8_EU_DIS1_S1_MASK          0xffff
2787#define   GEN8_EU_DIS1_S2_SHIFT         16
2788#define   GEN8_EU_DIS1_S2_MASK          (0xffff << GEN8_EU_DIS1_S2_SHIFT)
2789
2790#define GEN8_EU_DISABLE2                _MMIO(0x913c)
2791#define   GEN8_EU_DIS2_S2_MASK          0xff
2792
2793#define GEN9_EU_DISABLE(slice)          _MMIO(0x9134 + (slice)*0x4)
2794
2795#define GEN10_EU_DISABLE3               _MMIO(0x9140)
2796#define   GEN10_EU_DIS_SS_MASK          0xff
2797
2798#define GEN6_BSD_SLEEP_PSMI_CONTROL     _MMIO(0x12050)
2799#define   GEN6_BSD_SLEEP_MSG_DISABLE    (1 << 0)
2800#define   GEN6_BSD_SLEEP_FLUSH_DISABLE  (1 << 2)
2801#define   GEN6_BSD_SLEEP_INDICATOR      (1 << 3)
2802#define   GEN6_BSD_GO_INDICATOR         (1 << 4)
2803
2804/* On modern GEN architectures interrupt control consists of two sets
2805 * of registers. The first set pertains to the ring generating the
2806 * interrupt. The second control is for the functional block generating the
2807 * interrupt. These are PM, GT, DE, etc.
2808 *
2809 * Luckily *knocks on wood* all the ring interrupt bits match up with the
2810 * GT interrupt bits, so we don't need to duplicate the defines.
2811 *
2812 * These defines should cover us well from SNB->HSW with minor exceptions
2813 * it can also work on ILK.
2814 */
2815#define GT_BLT_FLUSHDW_NOTIFY_INTERRUPT         (1 << 26)
2816#define GT_BLT_CS_ERROR_INTERRUPT               (1 << 25)
2817#define GT_BLT_USER_INTERRUPT                   (1 << 22)
2818#define GT_BSD_CS_ERROR_INTERRUPT               (1 << 15)
2819#define GT_BSD_USER_INTERRUPT                   (1 << 12)
2820#define GT_RENDER_L3_PARITY_ERROR_INTERRUPT_S1  (1 << 11) /* hsw+; rsvd on snb, ivb, vlv */
2821#define GT_CONTEXT_SWITCH_INTERRUPT             (1 <<  8)
2822#define GT_RENDER_L3_PARITY_ERROR_INTERRUPT     (1 <<  5) /* !snb */
2823#define GT_RENDER_PIPECTL_NOTIFY_INTERRUPT      (1 <<  4)
2824#define GT_RENDER_CS_MASTER_ERROR_INTERRUPT     (1 <<  3)
2825#define GT_RENDER_SYNC_STATUS_INTERRUPT         (1 <<  2)
2826#define GT_RENDER_DEBUG_INTERRUPT               (1 <<  1)
2827#define GT_RENDER_USER_INTERRUPT                (1 <<  0)
2828
2829#define PM_VEBOX_CS_ERROR_INTERRUPT             (1 << 12) /* hsw+ */
2830#define PM_VEBOX_USER_INTERRUPT                 (1 << 10) /* hsw+ */
2831
2832#define GT_PARITY_ERROR(dev_priv) \
2833        (GT_RENDER_L3_PARITY_ERROR_INTERRUPT | \
2834         (IS_HASWELL(dev_priv) ? GT_RENDER_L3_PARITY_ERROR_INTERRUPT_S1 : 0))
2835
2836/* These are all the "old" interrupts */
2837#define ILK_BSD_USER_INTERRUPT                          (1<<5)
2838
2839#define I915_PM_INTERRUPT                               (1<<31)
2840#define I915_ISP_INTERRUPT                              (1<<22)
2841#define I915_LPE_PIPE_B_INTERRUPT                       (1<<21)
2842#define I915_LPE_PIPE_A_INTERRUPT                       (1<<20)
2843#define I915_MIPIC_INTERRUPT                            (1<<19)
2844#define I915_MIPIA_INTERRUPT                            (1<<18)
2845#define I915_PIPE_CONTROL_NOTIFY_INTERRUPT              (1<<18)
2846#define I915_DISPLAY_PORT_INTERRUPT                     (1<<17)
2847#define I915_DISPLAY_PIPE_C_HBLANK_INTERRUPT            (1<<16)
2848#define I915_MASTER_ERROR_INTERRUPT                     (1<<15)
2849#define I915_RENDER_COMMAND_PARSER_ERROR_INTERRUPT      (1<<15)
2850#define I915_DISPLAY_PIPE_B_HBLANK_INTERRUPT            (1<<14)
2851#define I915_GMCH_THERMAL_SENSOR_EVENT_INTERRUPT        (1<<14) /* p-state */
2852#define I915_DISPLAY_PIPE_A_HBLANK_INTERRUPT            (1<<13)
2853#define I915_HWB_OOM_INTERRUPT                          (1<<13)
2854#define I915_LPE_PIPE_C_INTERRUPT                       (1<<12)
2855#define I915_SYNC_STATUS_INTERRUPT                      (1<<12)
2856#define I915_MISC_INTERRUPT                             (1<<11)
2857#define I915_DISPLAY_PLANE_A_FLIP_PENDING_INTERRUPT     (1<<11)
2858#define I915_DISPLAY_PIPE_C_VBLANK_INTERRUPT            (1<<10)
2859#define I915_DISPLAY_PLANE_B_FLIP_PENDING_INTERRUPT     (1<<10)
2860#define I915_DISPLAY_PIPE_C_EVENT_INTERRUPT             (1<<9)
2861#define I915_OVERLAY_PLANE_FLIP_PENDING_INTERRUPT       (1<<9)
2862#define I915_DISPLAY_PIPE_C_DPBM_INTERRUPT              (1<<8)
2863#define I915_DISPLAY_PLANE_C_FLIP_PENDING_INTERRUPT     (1<<8)
2864#define I915_DISPLAY_PIPE_A_VBLANK_INTERRUPT            (1<<7)
2865#define I915_DISPLAY_PIPE_A_EVENT_INTERRUPT             (1<<6)
2866#define I915_DISPLAY_PIPE_B_VBLANK_INTERRUPT            (1<<5)
2867#define I915_DISPLAY_PIPE_B_EVENT_INTERRUPT             (1<<4)
2868#define I915_DISPLAY_PIPE_A_DPBM_INTERRUPT              (1<<3)
2869#define I915_DISPLAY_PIPE_B_DPBM_INTERRUPT              (1<<2)
2870#define I915_DEBUG_INTERRUPT                            (1<<2)
2871#define I915_WINVALID_INTERRUPT                         (1<<1)
2872#define I915_USER_INTERRUPT                             (1<<1)
2873#define I915_ASLE_INTERRUPT                             (1<<0)
2874#define I915_BSD_USER_INTERRUPT                         (1<<25)
2875
2876#define I915_HDMI_LPE_AUDIO_BASE        (VLV_DISPLAY_BASE + 0x65000)
2877#define I915_HDMI_LPE_AUDIO_SIZE        0x1000
2878
2879/* DisplayPort Audio w/ LPE */
2880#define VLV_AUD_CHICKEN_BIT_REG         _MMIO(VLV_DISPLAY_BASE + 0x62F38)
2881#define VLV_CHICKEN_BIT_DBG_ENABLE      (1 << 0)
2882
2883#define _VLV_AUD_PORT_EN_B_DBG          (VLV_DISPLAY_BASE + 0x62F20)
2884#define _VLV_AUD_PORT_EN_C_DBG          (VLV_DISPLAY_BASE + 0x62F30)
2885#define _VLV_AUD_PORT_EN_D_DBG          (VLV_DISPLAY_BASE + 0x62F34)
2886#define VLV_AUD_PORT_EN_DBG(port)       _MMIO_PORT3((port) - PORT_B,       \
2887                                                    _VLV_AUD_PORT_EN_B_DBG, \
2888                                                    _VLV_AUD_PORT_EN_C_DBG, \
2889                                                    _VLV_AUD_PORT_EN_D_DBG)
2890#define VLV_AMP_MUTE                    (1 << 1)
2891
2892#define GEN6_BSD_RNCID                  _MMIO(0x12198)
2893
2894#define GEN7_FF_THREAD_MODE             _MMIO(0x20a0)
2895#define   GEN7_FF_SCHED_MASK            0x0077070
2896#define   GEN8_FF_DS_REF_CNT_FFME       (1 << 19)
2897#define   GEN7_FF_TS_SCHED_HS1          (0x5<<16)
2898#define   GEN7_FF_TS_SCHED_HS0          (0x3<<16)
2899#define   GEN7_FF_TS_SCHED_LOAD_BALANCE (0x1<<16)
2900#define   GEN7_FF_TS_SCHED_HW           (0x0<<16) /* Default */
2901#define   GEN7_FF_VS_REF_CNT_FFME       (1 << 15)
2902#define   GEN7_FF_VS_SCHED_HS1          (0x5<<12)
2903#define   GEN7_FF_VS_SCHED_HS0          (0x3<<12)
2904#define   GEN7_FF_VS_SCHED_LOAD_BALANCE (0x1<<12) /* Default */
2905#define   GEN7_FF_VS_SCHED_HW           (0x0<<12)
2906#define   GEN7_FF_DS_SCHED_HS1          (0x5<<4)
2907#define   GEN7_FF_DS_SCHED_HS0          (0x3<<4)
2908#define   GEN7_FF_DS_SCHED_LOAD_BALANCE (0x1<<4)  /* Default */
2909#define   GEN7_FF_DS_SCHED_HW           (0x0<<4)
2910
2911/*
2912 * Framebuffer compression (915+ only)
2913 */
2914
2915#define FBC_CFB_BASE            _MMIO(0x3200) /* 4k page aligned */
2916#define FBC_LL_BASE             _MMIO(0x3204) /* 4k page aligned */
2917#define FBC_CONTROL             _MMIO(0x3208)
2918#define   FBC_CTL_EN            (1<<31)
2919#define   FBC_CTL_PERIODIC      (1<<30)
2920#define   FBC_CTL_INTERVAL_SHIFT (16)
2921#define   FBC_CTL_UNCOMPRESSIBLE (1<<14)
2922#define   FBC_CTL_C3_IDLE       (1<<13)
2923#define   FBC_CTL_STRIDE_SHIFT  (5)
2924#define   FBC_CTL_FENCENO_SHIFT (0)
2925#define FBC_COMMAND             _MMIO(0x320c)
2926#define   FBC_CMD_COMPRESS      (1<<0)
2927#define FBC_STATUS              _MMIO(0x3210)
2928#define   FBC_STAT_COMPRESSING  (1<<31)
2929#define   FBC_STAT_COMPRESSED   (1<<30)
2930#define   FBC_STAT_MODIFIED     (1<<29)
2931#define   FBC_STAT_CURRENT_LINE_SHIFT   (0)
2932#define FBC_CONTROL2            _MMIO(0x3214)
2933#define   FBC_CTL_FENCE_DBL     (0<<4)
2934#define   FBC_CTL_IDLE_IMM      (0<<2)
2935#define   FBC_CTL_IDLE_FULL     (1<<2)
2936#define   FBC_CTL_IDLE_LINE     (2<<2)
2937#define   FBC_CTL_IDLE_DEBUG    (3<<2)
2938#define   FBC_CTL_CPU_FENCE     (1<<1)
2939#define   FBC_CTL_PLANE(plane)  ((plane)<<0)
2940#define FBC_FENCE_OFF           _MMIO(0x3218) /* BSpec typo has 321Bh */
2941#define FBC_TAG(i)              _MMIO(0x3300 + (i) * 4)
2942
2943#define FBC_LL_SIZE             (1536)
2944
2945#define FBC_LLC_READ_CTRL       _MMIO(0x9044)
2946#define   FBC_LLC_FULLY_OPEN    (1<<30)
2947
2948/* Framebuffer compression for GM45+ */
2949#define DPFC_CB_BASE            _MMIO(0x3200)
2950#define DPFC_CONTROL            _MMIO(0x3208)
2951#define   DPFC_CTL_EN           (1<<31)
2952#define   DPFC_CTL_PLANE(plane) ((plane)<<30)
2953#define   IVB_DPFC_CTL_PLANE(plane)     ((plane)<<29)
2954#define   DPFC_CTL_FENCE_EN     (1<<29)
2955#define   IVB_DPFC_CTL_FENCE_EN (1<<28)
2956#define   DPFC_CTL_PERSISTENT_MODE      (1<<25)
2957#define   DPFC_SR_EN            (1<<10)
2958#define   DPFC_CTL_LIMIT_1X     (0<<6)
2959#define   DPFC_CTL_LIMIT_2X     (1<<6)
2960#define   DPFC_CTL_LIMIT_4X     (2<<6)
2961#define DPFC_RECOMP_CTL         _MMIO(0x320c)
2962#define   DPFC_RECOMP_STALL_EN  (1<<27)
2963#define   DPFC_RECOMP_STALL_WM_SHIFT (16)
2964#define   DPFC_RECOMP_STALL_WM_MASK (0x07ff0000)
2965#define   DPFC_RECOMP_TIMER_COUNT_SHIFT (0)
2966#define   DPFC_RECOMP_TIMER_COUNT_MASK (0x0000003f)
2967#define DPFC_STATUS             _MMIO(0x3210)
2968#define   DPFC_INVAL_SEG_SHIFT  (16)
2969#define   DPFC_INVAL_SEG_MASK   (0x07ff0000)
2970#define   DPFC_COMP_SEG_SHIFT   (0)
2971#define   DPFC_COMP_SEG_MASK    (0x000007ff)
2972#define DPFC_STATUS2            _MMIO(0x3214)
2973#define DPFC_FENCE_YOFF         _MMIO(0x3218)
2974#define DPFC_CHICKEN            _MMIO(0x3224)
2975#define   DPFC_HT_MODIFY        (1<<31)
2976
2977/* Framebuffer compression for Ironlake */
2978#define ILK_DPFC_CB_BASE        _MMIO(0x43200)
2979#define ILK_DPFC_CONTROL        _MMIO(0x43208)
2980#define   FBC_CTL_FALSE_COLOR   (1<<10)
2981/* The bit 28-8 is reserved */
2982#define   DPFC_RESERVED         (0x1FFFFF00)
2983#define ILK_DPFC_RECOMP_CTL     _MMIO(0x4320c)
2984#define ILK_DPFC_STATUS         _MMIO(0x43210)
2985#define  ILK_DPFC_COMP_SEG_MASK 0x7ff
2986#define IVB_FBC_STATUS2         _MMIO(0x43214)
2987#define  IVB_FBC_COMP_SEG_MASK  0x7ff
2988#define  BDW_FBC_COMP_SEG_MASK  0xfff
2989#define ILK_DPFC_FENCE_YOFF     _MMIO(0x43218)
2990#define ILK_DPFC_CHICKEN        _MMIO(0x43224)
2991#define   ILK_DPFC_DISABLE_DUMMY0 (1<<8)
2992#define   ILK_DPFC_NUKE_ON_ANY_MODIFICATION     (1<<23)
2993#define ILK_FBC_RT_BASE         _MMIO(0x2128)
2994#define   ILK_FBC_RT_VALID      (1<<0)
2995#define   SNB_FBC_FRONT_BUFFER  (1<<1)
2996
2997#define ILK_DISPLAY_CHICKEN1    _MMIO(0x42000)
2998#define   ILK_FBCQ_DIS          (1<<22)
2999#define   ILK_PABSTRETCH_DIS    (1<<21)
3000
3001
3002/*
3003 * Framebuffer compression for Sandybridge
3004 *
3005 * The following two registers are of type GTTMMADR
3006 */
3007#define SNB_DPFC_CTL_SA         _MMIO(0x100100)
3008#define   SNB_CPU_FENCE_ENABLE  (1<<29)
3009#define DPFC_CPU_FENCE_OFFSET   _MMIO(0x100104)
3010
3011/* Framebuffer compression for Ivybridge */
3012#define IVB_FBC_RT_BASE                 _MMIO(0x7020)
3013
3014#define IPS_CTL         _MMIO(0x43408)
3015#define   IPS_ENABLE    (1 << 31)
3016
3017#define MSG_FBC_REND_STATE      _MMIO(0x50380)
3018#define   FBC_REND_NUKE         (1<<2)
3019#define   FBC_REND_CACHE_CLEAN  (1<<1)
3020
3021/*
3022 * GPIO regs
3023 */
3024#define GPIOA                   _MMIO(0x5010)
3025#define GPIOB                   _MMIO(0x5014)
3026#define GPIOC                   _MMIO(0x5018)
3027#define GPIOD                   _MMIO(0x501c)
3028#define GPIOE                   _MMIO(0x5020)
3029#define GPIOF                   _MMIO(0x5024)
3030#define GPIOG                   _MMIO(0x5028)
3031#define GPIOH                   _MMIO(0x502c)
3032# define GPIO_CLOCK_DIR_MASK            (1 << 0)
3033# define GPIO_CLOCK_DIR_IN              (0 << 1)
3034# define GPIO_CLOCK_DIR_OUT             (1 << 1)
3035# define GPIO_CLOCK_VAL_MASK            (1 << 2)
3036# define GPIO_CLOCK_VAL_OUT             (1 << 3)
3037# define GPIO_CLOCK_VAL_IN              (1 << 4)
3038# define GPIO_CLOCK_PULLUP_DISABLE      (1 << 5)
3039# define GPIO_DATA_DIR_MASK             (1 << 8)
3040# define GPIO_DATA_DIR_IN               (0 << 9)
3041# define GPIO_DATA_DIR_OUT              (1 << 9)
3042# define GPIO_DATA_VAL_MASK             (1 << 10)
3043# define GPIO_DATA_VAL_OUT              (1 << 11)
3044# define GPIO_DATA_VAL_IN               (1 << 12)
3045# define GPIO_DATA_PULLUP_DISABLE       (1 << 13)
3046
3047#define GMBUS0                  _MMIO(dev_priv->gpio_mmio_base + 0x5100) /* clock/port select */
3048#define   GMBUS_RATE_100KHZ     (0<<8)
3049#define   GMBUS_RATE_50KHZ      (1<<8)
3050#define   GMBUS_RATE_400KHZ     (2<<8) /* reserved on Pineview */
3051#define   GMBUS_RATE_1MHZ       (3<<8) /* reserved on Pineview */
3052#define   GMBUS_HOLD_EXT        (1<<7) /* 300ns hold time, rsvd on Pineview */
3053#define   GMBUS_PIN_DISABLED    0
3054#define   GMBUS_PIN_SSC         1
3055#define   GMBUS_PIN_VGADDC      2
3056#define   GMBUS_PIN_PANEL       3
3057#define   GMBUS_PIN_DPD_CHV     3 /* HDMID_CHV */
3058#define   GMBUS_PIN_DPC         4 /* HDMIC */
3059#define   GMBUS_PIN_DPB         5 /* SDVO, HDMIB */
3060#define   GMBUS_PIN_DPD         6 /* HDMID */
3061#define   GMBUS_PIN_RESERVED    7 /* 7 reserved */
3062#define   GMBUS_PIN_1_BXT       1 /* BXT+ (atom) and CNP+ (big core) */
3063#define   GMBUS_PIN_2_BXT       2
3064#define   GMBUS_PIN_3_BXT       3
3065#define   GMBUS_PIN_4_CNP       4
3066#define   GMBUS_NUM_PINS        7 /* including 0 */
3067#define GMBUS1                  _MMIO(dev_priv->gpio_mmio_base + 0x5104) /* command/status */
3068#define   GMBUS_SW_CLR_INT      (1<<31)
3069#define   GMBUS_SW_RDY          (1<<30)
3070#define   GMBUS_ENT             (1<<29) /* enable timeout */
3071#define   GMBUS_CYCLE_NONE      (0<<25)
3072#define   GMBUS_CYCLE_WAIT      (1<<25)
3073#define   GMBUS_CYCLE_INDEX     (2<<25)
3074#define   GMBUS_CYCLE_STOP      (4<<25)
3075#define   GMBUS_BYTE_COUNT_SHIFT 16
3076#define   GMBUS_BYTE_COUNT_MAX   256U
3077#define   GMBUS_SLAVE_INDEX_SHIFT 8
3078#define   GMBUS_SLAVE_ADDR_SHIFT 1
3079#define   GMBUS_SLAVE_READ      (1<<0)
3080#define   GMBUS_SLAVE_WRITE     (0<<0)
3081#define GMBUS2                  _MMIO(dev_priv->gpio_mmio_base + 0x5108) /* status */
3082#define   GMBUS_INUSE           (1<<15)
3083#define   GMBUS_HW_WAIT_PHASE   (1<<14)
3084#define   GMBUS_STALL_TIMEOUT   (1<<13)
3085#define   GMBUS_INT             (1<<12)
3086#define   GMBUS_HW_RDY          (1<<11)
3087#define   GMBUS_SATOER          (1<<10)
3088#define   GMBUS_ACTIVE          (1<<9)
3089#define GMBUS3                  _MMIO(dev_priv->gpio_mmio_base + 0x510c) /* data buffer bytes 3-0 */
3090#define GMBUS4                  _MMIO(dev_priv->gpio_mmio_base + 0x5110) /* interrupt mask (Pineview+) */
3091#define   GMBUS_SLAVE_TIMEOUT_EN (1<<4)
3092#define   GMBUS_NAK_EN          (1<<3)
3093#define   GMBUS_IDLE_EN         (1<<2)
3094#define   GMBUS_HW_WAIT_EN      (1<<1)
3095#define   GMBUS_HW_RDY_EN       (1<<0)
3096#define GMBUS5                  _MMIO(dev_priv->gpio_mmio_base + 0x5120) /* byte index */
3097#define   GMBUS_2BYTE_INDEX_EN  (1<<31)
3098
3099/*
3100 * Clock control & power management
3101 */
3102#define _DPLL_A (dev_priv->info.display_mmio_offset + 0x6014)
3103#define _DPLL_B (dev_priv->info.display_mmio_offset + 0x6018)
3104#define _CHV_DPLL_C (dev_priv->info.display_mmio_offset + 0x6030)
3105#define DPLL(pipe) _MMIO_PIPE3((pipe), _DPLL_A, _DPLL_B, _CHV_DPLL_C)
3106
3107#define VGA0    _MMIO(0x6000)
3108#define VGA1    _MMIO(0x6004)
3109#define VGA_PD  _MMIO(0x6010)
3110#define   VGA0_PD_P2_DIV_4      (1 << 7)
3111#define   VGA0_PD_P1_DIV_2      (1 << 5)
3112#define   VGA0_PD_P1_SHIFT      0
3113#define   VGA0_PD_P1_MASK       (0x1f << 0)
3114#define   VGA1_PD_P2_DIV_4      (1 << 15)
3115#define   VGA1_PD_P1_DIV_2      (1 << 13)
3116#define   VGA1_PD_P1_SHIFT      8
3117#define   VGA1_PD_P1_MASK       (0x1f << 8)
3118#define   DPLL_VCO_ENABLE               (1 << 31)
3119#define   DPLL_SDVO_HIGH_SPEED          (1 << 30)
3120#define   DPLL_DVO_2X_MODE              (1 << 30)
3121#define   DPLL_EXT_BUFFER_ENABLE_VLV    (1 << 30)
3122#define   DPLL_SYNCLOCK_ENABLE          (1 << 29)
3123#define   DPLL_REF_CLK_ENABLE_VLV       (1 << 29)
3124#define   DPLL_VGA_MODE_DIS             (1 << 28)
3125#define   DPLLB_MODE_DAC_SERIAL         (1 << 26) /* i915 */
3126#define   DPLLB_MODE_LVDS               (2 << 26) /* i915 */
3127#define   DPLL_MODE_MASK                (3 << 26)
3128#define   DPLL_DAC_SERIAL_P2_CLOCK_DIV_10 (0 << 24) /* i915 */
3129#define   DPLL_DAC_SERIAL_P2_CLOCK_DIV_5 (1 << 24) /* i915 */
3130#define   DPLLB_LVDS_P2_CLOCK_DIV_14    (0 << 24) /* i915 */
3131#define   DPLLB_LVDS_P2_CLOCK_DIV_7     (1 << 24) /* i915 */
3132#define   DPLL_P2_CLOCK_DIV_MASK        0x03000000 /* i915 */
3133#define   DPLL_FPA01_P1_POST_DIV_MASK   0x00ff0000 /* i915 */
3134#define   DPLL_FPA01_P1_POST_DIV_MASK_PINEVIEW  0x00ff8000 /* Pineview */
3135#define   DPLL_LOCK_VLV                 (1<<15)
3136#define   DPLL_INTEGRATED_CRI_CLK_VLV   (1<<14)
3137#define   DPLL_INTEGRATED_REF_CLK_VLV   (1<<13)
3138#define   DPLL_SSC_REF_CLK_CHV          (1<<13)
3139#define   DPLL_PORTC_READY_MASK         (0xf << 4)
3140#define   DPLL_PORTB_READY_MASK         (0xf)
3141
3142#define   DPLL_FPA01_P1_POST_DIV_MASK_I830      0x001f0000
3143
3144/* Additional CHV pll/phy registers */
3145#define DPIO_PHY_STATUS                 _MMIO(VLV_DISPLAY_BASE + 0x6240)
3146#define   DPLL_PORTD_READY_MASK         (0xf)
3147#define DISPLAY_PHY_CONTROL _MMIO(VLV_DISPLAY_BASE + 0x60100)
3148#define   PHY_CH_POWER_DOWN_OVRD_EN(phy, ch)    (1 << (2*(phy)+(ch)+27))
3149#define   PHY_LDO_DELAY_0NS                     0x0
3150#define   PHY_LDO_DELAY_200NS                   0x1
3151#define   PHY_LDO_DELAY_600NS                   0x2
3152#define   PHY_LDO_SEQ_DELAY(delay, phy)         ((delay) << (2*(phy)+23))
3153#define   PHY_CH_POWER_DOWN_OVRD(mask, phy, ch) ((mask) << (8*(phy)+4*(ch)+11))
3154#define   PHY_CH_SU_PSR                         0x1
3155#define   PHY_CH_DEEP_PSR                       0x7
3156#define   PHY_CH_POWER_MODE(mode, phy, ch)      ((mode) << (6*(phy)+3*(ch)+2))
3157#define   PHY_COM_LANE_RESET_DEASSERT(phy)      (1 << (phy))
3158#define DISPLAY_PHY_STATUS _MMIO(VLV_DISPLAY_BASE + 0x60104)
3159#define   PHY_POWERGOOD(phy)    (((phy) == DPIO_PHY0) ? (1<<31) : (1<<30))
3160#define   PHY_STATUS_CMN_LDO(phy, ch)                   (1 << (6-(6*(phy)+3*(ch))))
3161#define   PHY_STATUS_SPLINE_LDO(phy, ch, spline)        (1 << (8-(6*(phy)+3*(ch)+(spline))))
3162
3163/*
3164 * The i830 generation, in LVDS mode, defines P1 as the bit number set within
3165 * this field (only one bit may be set).
3166 */
3167#define   DPLL_FPA01_P1_POST_DIV_MASK_I830_LVDS 0x003f0000
3168#define   DPLL_FPA01_P1_POST_DIV_SHIFT  16
3169#define   DPLL_FPA01_P1_POST_DIV_SHIFT_PINEVIEW 15
3170/* i830, required in DVO non-gang */
3171#define   PLL_P2_DIVIDE_BY_4            (1 << 23)
3172#define   PLL_P1_DIVIDE_BY_TWO          (1 << 21) /* i830 */
3173#define   PLL_REF_INPUT_DREFCLK         (0 << 13)
3174#define   PLL_REF_INPUT_TVCLKINA        (1 << 13) /* i830 */
3175#define   PLL_REF_INPUT_TVCLKINBC       (2 << 13) /* SDVO TVCLKIN */
3176#define   PLLB_REF_INPUT_SPREADSPECTRUMIN (3 << 13)
3177#define   PLL_REF_INPUT_MASK            (3 << 13)
3178#define   PLL_LOAD_PULSE_PHASE_SHIFT            9
3179/* Ironlake */
3180# define PLL_REF_SDVO_HDMI_MULTIPLIER_SHIFT     9
3181# define PLL_REF_SDVO_HDMI_MULTIPLIER_MASK      (7 << 9)
3182# define PLL_REF_SDVO_HDMI_MULTIPLIER(x)        (((x)-1) << 9)
3183# define DPLL_FPA1_P1_POST_DIV_SHIFT            0
3184# define DPLL_FPA1_P1_POST_DIV_MASK             0xff
3185
3186/*
3187 * Parallel to Serial Load Pulse phase selection.
3188 * Selects the phase for the 10X DPLL clock for the PCIe
3189 * digital display port. The range is 4 to 13; 10 or more
3190 * is just a flip delay. The default is 6
3191 */
3192#define   PLL_LOAD_PULSE_PHASE_MASK             (0xf << PLL_LOAD_PULSE_PHASE_SHIFT)
3193#define   DISPLAY_RATE_SELECT_FPA1              (1 << 8)
3194/*
3195 * SDVO multiplier for 945G/GM. Not used on 965.
3196 */
3197#define   SDVO_MULTIPLIER_MASK                  0x000000ff
3198#define   SDVO_MULTIPLIER_SHIFT_HIRES           4
3199#define   SDVO_MULTIPLIER_SHIFT_VGA             0
3200
3201#define _DPLL_A_MD (dev_priv->info.display_mmio_offset + 0x601c)
3202#define _DPLL_B_MD (dev_priv->info.display_mmio_offset + 0x6020)
3203#define _CHV_DPLL_C_MD (dev_priv->info.display_mmio_offset + 0x603c)
3204#define DPLL_MD(pipe) _MMIO_PIPE3((pipe), _DPLL_A_MD, _DPLL_B_MD, _CHV_DPLL_C_MD)
3205
3206/*
3207 * UDI pixel divider, controlling how many pixels are stuffed into a packet.
3208 *
3209 * Value is pixels minus 1.  Must be set to 1 pixel for SDVO.
3210 */
3211#define   DPLL_MD_UDI_DIVIDER_MASK              0x3f000000
3212#define   DPLL_MD_UDI_DIVIDER_SHIFT             24
3213/* UDI pixel divider for VGA, same as DPLL_MD_UDI_DIVIDER_MASK. */
3214#define   DPLL_MD_VGA_UDI_DIVIDER_MASK          0x003f0000
3215#define   DPLL_MD_VGA_UDI_DIVIDER_SHIFT         16
3216/*
3217 * SDVO/UDI pixel multiplier.
3218 *
3219 * SDVO requires that the bus clock rate be between 1 and 2 Ghz, and the bus
3220 * clock rate is 10 times the DPLL clock.  At low resolution/refresh rate
3221 * modes, the bus rate would be below the limits, so SDVO allows for stuffing
3222 * dummy bytes in the datastream at an increased clock rate, with both sides of
3223 * the link knowing how many bytes are fill.
3224 *
3225 * So, for a mode with a dotclock of 65Mhz, we would want to double the clock
3226 * rate to 130Mhz to get a bus rate of 1.30Ghz.  The DPLL clock rate would be
3227 * set to 130Mhz, and the SDVO multiplier set to 2x in this register and
3228 * through an SDVO command.
3229 *
3230 * This register field has values of multiplication factor minus 1, with
3231 * a maximum multiplier of 5 for SDVO.
3232 */
3233#define   DPLL_MD_UDI_MULTIPLIER_MASK           0x00003f00
3234#define   DPLL_MD_UDI_MULTIPLIER_SHIFT          8
3235/*
3236 * SDVO/UDI pixel multiplier for VGA, same as DPLL_MD_UDI_MULTIPLIER_MASK.
3237 * This best be set to the default value (3) or the CRT won't work. No,
3238 * I don't entirely understand what this does...
3239 */
3240#define   DPLL_MD_VGA_UDI_MULTIPLIER_MASK       0x0000003f
3241#define   DPLL_MD_VGA_UDI_MULTIPLIER_SHIFT      0
3242
3243#define RAWCLK_FREQ_VLV         _MMIO(VLV_DISPLAY_BASE + 0x6024)
3244
3245#define _FPA0   0x6040
3246#define _FPA1   0x6044
3247#define _FPB0   0x6048
3248#define _FPB1   0x604c
3249#define FP0(pipe) _MMIO_PIPE(pipe, _FPA0, _FPB0)
3250#define FP1(pipe) _MMIO_PIPE(pipe, _FPA1, _FPB1)
3251#define   FP_N_DIV_MASK         0x003f0000
3252#define   FP_N_PINEVIEW_DIV_MASK        0x00ff0000
3253#define   FP_N_DIV_SHIFT                16
3254#define   FP_M1_DIV_MASK        0x00003f00
3255#define   FP_M1_DIV_SHIFT                8
3256#define   FP_M2_DIV_MASK        0x0000003f
3257#define   FP_M2_PINEVIEW_DIV_MASK       0x000000ff
3258#define   FP_M2_DIV_SHIFT                0
3259#define DPLL_TEST       _MMIO(0x606c)
3260#define   DPLLB_TEST_SDVO_DIV_1         (0 << 22)
3261#define   DPLLB_TEST_SDVO_DIV_2         (1 << 22)
3262#define   DPLLB_TEST_SDVO_DIV_4         (2 << 22)
3263#define   DPLLB_TEST_SDVO_DIV_MASK      (3 << 22)
3264#define   DPLLB_TEST_N_BYPASS           (1 << 19)
3265#define   DPLLB_TEST_M_BYPASS           (1 << 18)
3266#define   DPLLB_INPUT_BUFFER_ENABLE     (1 << 16)
3267#define   DPLLA_TEST_N_BYPASS           (1 << 3)
3268#define   DPLLA_TEST_M_BYPASS           (1 << 2)
3269#define   DPLLA_INPUT_BUFFER_ENABLE     (1 << 0)
3270#define D_STATE         _MMIO(0x6104)
3271#define  DSTATE_GFX_RESET_I830                  (1<<6)
3272#define  DSTATE_PLL_D3_OFF                      (1<<3)
3273#define  DSTATE_GFX_CLOCK_GATING                (1<<1)
3274#define  DSTATE_DOT_CLOCK_GATING                (1<<0)
3275#define DSPCLK_GATE_D   _MMIO(dev_priv->info.display_mmio_offset + 0x6200)
3276# define DPUNIT_B_CLOCK_GATE_DISABLE            (1 << 30) /* 965 */
3277# define VSUNIT_CLOCK_GATE_DISABLE              (1 << 29) /* 965 */
3278# define VRHUNIT_CLOCK_GATE_DISABLE             (1 << 28) /* 965 */
3279# define VRDUNIT_CLOCK_GATE_DISABLE             (1 << 27) /* 965 */
3280# define AUDUNIT_CLOCK_GATE_DISABLE             (1 << 26) /* 965 */
3281# define DPUNIT_A_CLOCK_GATE_DISABLE            (1 << 25) /* 965 */
3282# define DPCUNIT_CLOCK_GATE_DISABLE             (1 << 24) /* 965 */
3283# define PNV_GMBUSUNIT_CLOCK_GATE_DISABLE       (1 << 24) /* pnv */
3284# define TVRUNIT_CLOCK_GATE_DISABLE             (1 << 23) /* 915-945 */
3285# define TVCUNIT_CLOCK_GATE_DISABLE             (1 << 22) /* 915-945 */
3286# define TVFUNIT_CLOCK_GATE_DISABLE             (1 << 21) /* 915-945 */
3287# define TVEUNIT_CLOCK_GATE_DISABLE             (1 << 20) /* 915-945 */
3288# define DVSUNIT_CLOCK_GATE_DISABLE             (1 << 19) /* 915-945 */
3289# define DSSUNIT_CLOCK_GATE_DISABLE             (1 << 18) /* 915-945 */
3290# define DDBUNIT_CLOCK_GATE_DISABLE             (1 << 17) /* 915-945 */
3291# define DPRUNIT_CLOCK_GATE_DISABLE             (1 << 16) /* 915-945 */
3292# define DPFUNIT_CLOCK_GATE_DISABLE             (1 << 15) /* 915-945 */
3293# define DPBMUNIT_CLOCK_GATE_DISABLE            (1 << 14) /* 915-945 */
3294# define DPLSUNIT_CLOCK_GATE_DISABLE            (1 << 13) /* 915-945 */
3295# define DPLUNIT_CLOCK_GATE_DISABLE             (1 << 12) /* 915-945 */
3296# define DPOUNIT_CLOCK_GATE_DISABLE             (1 << 11)
3297# define DPBUNIT_CLOCK_GATE_DISABLE             (1 << 10)
3298# define DCUNIT_CLOCK_GATE_DISABLE              (1 << 9)
3299# define DPUNIT_CLOCK_GATE_DISABLE              (1 << 8)
3300# define VRUNIT_CLOCK_GATE_DISABLE              (1 << 7) /* 915+: reserved */
3301# define OVHUNIT_CLOCK_GATE_DISABLE             (1 << 6) /* 830-865 */
3302# define DPIOUNIT_CLOCK_GATE_DISABLE            (1 << 6) /* 915-945 */
3303# define OVFUNIT_CLOCK_GATE_DISABLE             (1 << 5)
3304# define OVBUNIT_CLOCK_GATE_DISABLE             (1 << 4)
3305/*
3306 * This bit must be set on the 830 to prevent hangs when turning off the
3307 * overlay scaler.
3308 */
3309# define OVRUNIT_CLOCK_GATE_DISABLE             (1 << 3)
3310# define OVCUNIT_CLOCK_GATE_DISABLE             (1 << 2)
3311# define OVUUNIT_CLOCK_GATE_DISABLE             (1 << 1)
3312# define ZVUNIT_CLOCK_GATE_DISABLE              (1 << 0) /* 830 */
3313# define OVLUNIT_CLOCK_GATE_DISABLE             (1 << 0) /* 845,865 */
3314
3315#define RENCLK_GATE_D1          _MMIO(0x6204)
3316# define BLITTER_CLOCK_GATE_DISABLE             (1 << 13) /* 945GM only */
3317# define MPEG_CLOCK_GATE_DISABLE                (1 << 12) /* 945GM only */
3318# define PC_FE_CLOCK_GATE_DISABLE               (1 << 11)
3319# define PC_BE_CLOCK_GATE_DISABLE               (1 << 10)
3320# define WINDOWER_CLOCK_GATE_DISABLE            (1 << 9)
3321# define INTERPOLATOR_CLOCK_GATE_DISABLE        (1 << 8)
3322# define COLOR_CALCULATOR_CLOCK_GATE_DISABLE    (1 << 7)
3323# define MOTION_COMP_CLOCK_GATE_DISABLE         (1 << 6)
3324# define MAG_CLOCK_GATE_DISABLE                 (1 << 5)
3325/* This bit must be unset on 855,865 */
3326# define MECI_CLOCK_GATE_DISABLE                (1 << 4)
3327# define DCMP_CLOCK_GATE_DISABLE                (1 << 3)
3328# define MEC_CLOCK_GATE_DISABLE                 (1 << 2)
3329# define MECO_CLOCK_GATE_DISABLE                (1 << 1)
3330/* This bit must be set on 855,865. */
3331# define SV_CLOCK_GATE_DISABLE                  (1 << 0)
3332# define I915_MPEG_CLOCK_GATE_DISABLE           (1 << 16)
3333# define I915_VLD_IP_PR_CLOCK_GATE_DISABLE      (1 << 15)
3334# define I915_MOTION_COMP_CLOCK_GATE_DISABLE    (1 << 14)
3335# define I915_BD_BF_CLOCK_GATE_DISABLE          (1 << 13)
3336# define I915_SF_SE_CLOCK_GATE_DISABLE          (1 << 12)
3337# define I915_WM_CLOCK_GATE_DISABLE             (1 << 11)
3338# define I915_IZ_CLOCK_GATE_DISABLE             (1 << 10)
3339# define I915_PI_CLOCK_GATE_DISABLE             (1 << 9)
3340# define I915_DI_CLOCK_GATE_DISABLE             (1 << 8)
3341# define I915_SH_SV_CLOCK_GATE_DISABLE          (1 << 7)
3342# define I915_PL_DG_QC_FT_CLOCK_GATE_DISABLE    (1 << 6)
3343# define I915_SC_CLOCK_GATE_DISABLE             (1 << 5)
3344# define I915_FL_CLOCK_GATE_DISABLE             (1 << 4)
3345# define I915_DM_CLOCK_GATE_DISABLE             (1 << 3)
3346# define I915_PS_CLOCK_GATE_DISABLE             (1 << 2)
3347# define I915_CC_CLOCK_GATE_DISABLE             (1 << 1)
3348# define I915_BY_CLOCK_GATE_DISABLE             (1 << 0)
3349
3350# define I965_RCZ_CLOCK_GATE_DISABLE            (1 << 30)
3351/* This bit must always be set on 965G/965GM */
3352# define I965_RCC_CLOCK_GATE_DISABLE            (1 << 29)
3353# define I965_RCPB_CLOCK_GATE_DISABLE           (1 << 28)
3354# define I965_DAP_CLOCK_GATE_DISABLE            (1 << 27)
3355# define I965_ROC_CLOCK_GATE_DISABLE            (1 << 26)
3356# define I965_GW_CLOCK_GATE_DISABLE             (1 << 25)
3357# define I965_TD_CLOCK_GATE_DISABLE             (1 << 24)
3358/* This bit must always be set on 965G */
3359# define I965_ISC_CLOCK_GATE_DISABLE            (1 << 23)
3360# define I965_IC_CLOCK_GATE_DISABLE             (1 << 22)
3361# define I965_EU_CLOCK_GATE_DISABLE             (1 << 21)
3362# define I965_IF_CLOCK_GATE_DISABLE             (1 << 20)
3363# define I965_TC_CLOCK_GATE_DISABLE             (1 << 19)
3364# define I965_SO_CLOCK_GATE_DISABLE             (1 << 17)
3365# define I965_FBC_CLOCK_GATE_DISABLE            (1 << 16)
3366# define I965_MARI_CLOCK_GATE_DISABLE           (1 << 15)
3367# define I965_MASF_CLOCK_GATE_DISABLE           (1 << 14)
3368# define I965_MAWB_CLOCK_GATE_DISABLE           (1 << 13)
3369# define I965_EM_CLOCK_GATE_DISABLE             (1 << 12)
3370# define I965_UC_CLOCK_GATE_DISABLE             (1 << 11)
3371# define I965_SI_CLOCK_GATE_DISABLE             (1 << 6)
3372# define I965_MT_CLOCK_GATE_DISABLE             (1 << 5)
3373# define I965_PL_CLOCK_GATE_DISABLE             (1 << 4)
3374# define I965_DG_CLOCK_GATE_DISABLE             (1 << 3)
3375# define I965_QC_CLOCK_GATE_DISABLE             (1 << 2)
3376# define I965_FT_CLOCK_GATE_DISABLE             (1 << 1)
3377# define I965_DM_CLOCK_GATE_DISABLE             (1 << 0)
3378
3379#define RENCLK_GATE_D2          _MMIO(0x6208)
3380#define VF_UNIT_CLOCK_GATE_DISABLE              (1 << 9)
3381#define GS_UNIT_CLOCK_GATE_DISABLE              (1 << 7)
3382#define CL_UNIT_CLOCK_GATE_DISABLE              (1 << 6)
3383
3384#define VDECCLK_GATE_D          _MMIO(0x620C)           /* g4x only */
3385#define  VCP_UNIT_CLOCK_GATE_DISABLE            (1 << 4)
3386
3387#define RAMCLK_GATE_D           _MMIO(0x6210)           /* CRL only */
3388#define DEUC                    _MMIO(0x6214)          /* CRL only */
3389
3390#define FW_BLC_SELF_VLV         _MMIO(VLV_DISPLAY_BASE + 0x6500)
3391#define  FW_CSPWRDWNEN          (1<<15)
3392
3393#define MI_ARB_VLV              _MMIO(VLV_DISPLAY_BASE + 0x6504)
3394
3395#define CZCLK_CDCLK_FREQ_RATIO  _MMIO(VLV_DISPLAY_BASE + 0x6508)
3396#define   CDCLK_FREQ_SHIFT      4
3397#define   CDCLK_FREQ_MASK       (0x1f << CDCLK_FREQ_SHIFT)
3398#define   CZCLK_FREQ_MASK       0xf
3399
3400#define GCI_CONTROL             _MMIO(VLV_DISPLAY_BASE + 0x650C)
3401#define   PFI_CREDIT_63         (9 << 28)               /* chv only */
3402#define   PFI_CREDIT_31         (8 << 28)               /* chv only */
3403#define   PFI_CREDIT(x)         (((x) - 8) << 28)       /* 8-15 */
3404#define   PFI_CREDIT_RESEND     (1 << 27)
3405#define   VGA_FAST_MODE_DISABLE (1 << 14)
3406
3407#define GMBUSFREQ_VLV           _MMIO(VLV_DISPLAY_BASE + 0x6510)
3408
3409/*
3410 * Palette regs
3411 */
3412#define PALETTE_A_OFFSET 0xa000
3413#define PALETTE_B_OFFSET 0xa800
3414#define CHV_PALETTE_C_OFFSET 0xc000
3415#define PALETTE(pipe, i) _MMIO(dev_priv->info.palette_offsets[pipe] +   \
3416                              dev_priv->info.display_mmio_offset + (i) * 4)
3417
3418/* MCH MMIO space */
3419
3420/*
3421 * MCHBAR mirror.
3422 *
3423 * This mirrors the MCHBAR MMIO space whose location is determined by
3424 * device 0 function 0's pci config register 0x44 or 0x48 and matches it in
3425 * every way.  It is not accessible from the CP register read instructions.
3426 *
3427 * Starting from Haswell, you can't write registers using the MCHBAR mirror,
3428 * just read.
3429 */
3430#define MCHBAR_MIRROR_BASE      0x10000
3431
3432#define MCHBAR_MIRROR_BASE_SNB  0x140000
3433
3434#define CTG_STOLEN_RESERVED             _MMIO(MCHBAR_MIRROR_BASE + 0x34)
3435#define ELK_STOLEN_RESERVED             _MMIO(MCHBAR_MIRROR_BASE + 0x48)
3436#define G4X_STOLEN_RESERVED_ADDR1_MASK  (0xFFFF << 16)
3437#define G4X_STOLEN_RESERVED_ADDR2_MASK  (0xFFF << 4)
3438#define G4X_STOLEN_RESERVED_ENABLE      (1 << 0)
3439
3440/* Memory controller frequency in MCHBAR for Haswell (possible SNB+) */
3441#define DCLK _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x5e04)
3442
3443/* 915-945 and GM965 MCH register controlling DRAM channel access */
3444#define DCC                     _MMIO(MCHBAR_MIRROR_BASE + 0x200)
3445#define DCC_ADDRESSING_MODE_SINGLE_CHANNEL              (0 << 0)
3446#define DCC_ADDRESSING_MODE_DUAL_CHANNEL_ASYMMETRIC     (1 << 0)
3447#define DCC_ADDRESSING_MODE_DUAL_CHANNEL_INTERLEAVED    (2 << 0)
3448#define DCC_ADDRESSING_MODE_MASK                        (3 << 0)
3449#define DCC_CHANNEL_XOR_DISABLE                         (1 << 10)
3450#define DCC_CHANNEL_XOR_BIT_17                          (1 << 9)
3451#define DCC2                    _MMIO(MCHBAR_MIRROR_BASE + 0x204)
3452#define DCC2_MODIFIED_ENHANCED_DISABLE                  (1 << 20)
3453
3454/* Pineview MCH register contains DDR3 setting */
3455#define CSHRDDR3CTL            _MMIO(MCHBAR_MIRROR_BASE + 0x1a8)
3456#define CSHRDDR3CTL_DDR3       (1 << 2)
3457
3458/* 965 MCH register controlling DRAM channel configuration */
3459#define C0DRB3                  _MMIO(MCHBAR_MIRROR_BASE + 0x206)
3460#define C1DRB3                  _MMIO(MCHBAR_MIRROR_BASE + 0x606)
3461
3462/* snb MCH registers for reading the DRAM channel configuration */
3463#define MAD_DIMM_C0                     _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x5004)
3464#define MAD_DIMM_C1                     _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x5008)
3465#define MAD_DIMM_C2                     _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x500C)
3466#define   MAD_DIMM_ECC_MASK             (0x3 << 24)
3467#define   MAD_DIMM_ECC_OFF              (0x0 << 24)
3468#define   MAD_DIMM_ECC_IO_ON_LOGIC_OFF  (0x1 << 24)
3469#define   MAD_DIMM_ECC_IO_OFF_LOGIC_ON  (0x2 << 24)
3470#define   MAD_DIMM_ECC_ON               (0x3 << 24)
3471#define   MAD_DIMM_ENH_INTERLEAVE       (0x1 << 22)
3472#define   MAD_DIMM_RANK_INTERLEAVE      (0x1 << 21)
3473#define   MAD_DIMM_B_WIDTH_X16          (0x1 << 20) /* X8 chips if unset */
3474#define   MAD_DIMM_A_WIDTH_X16          (0x1 << 19) /* X8 chips if unset */
3475#define   MAD_DIMM_B_DUAL_RANK          (0x1 << 18)
3476#define   MAD_DIMM_A_DUAL_RANK          (0x1 << 17)
3477#define   MAD_DIMM_A_SELECT             (0x1 << 16)
3478/* DIMM sizes are in multiples of 256mb. */
3479#define   MAD_DIMM_B_SIZE_SHIFT         8
3480#define   MAD_DIMM_B_SIZE_MASK          (0xff << MAD_DIMM_B_SIZE_SHIFT)
3481#define   MAD_DIMM_A_SIZE_SHIFT         0
3482#define   MAD_DIMM_A_SIZE_MASK          (0xff << MAD_DIMM_A_SIZE_SHIFT)
3483
3484/* snb MCH registers for priority tuning */
3485#define MCH_SSKPD                       _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x5d10)
3486#define   MCH_SSKPD_WM0_MASK            0x3f
3487#define   MCH_SSKPD_WM0_VAL             0xc
3488
3489#define MCH_SECP_NRG_STTS               _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x592c)
3490
3491/* Clocking configuration register */
3492#define CLKCFG                  _MMIO(MCHBAR_MIRROR_BASE + 0xc00)
3493#define CLKCFG_FSB_400                                  (5 << 0)        /* hrawclk 100 */
3494#define CLKCFG_FSB_533                                  (1 << 0)        /* hrawclk 133 */
3495#define CLKCFG_FSB_667                                  (3 << 0)        /* hrawclk 166 */
3496#define CLKCFG_FSB_800                                  (2 << 0)        /* hrawclk 200 */
3497#define CLKCFG_FSB_1067                                 (6 << 0)        /* hrawclk 266 */
3498#define CLKCFG_FSB_1067_ALT                             (0 << 0)        /* hrawclk 266 */
3499#define CLKCFG_FSB_1333                                 (7 << 0)        /* hrawclk 333 */
3500/*
3501 * Note that on at least on ELK the below value is reported for both
3502 * 333 and 400 MHz BIOS FSB setting, but given that the gmch datasheet
3503 * lists only 200/266/333 MHz FSB as supported let's decode it as 333 MHz.
3504 */
3505#define CLKCFG_FSB_1333_ALT                             (4 << 0)        /* hrawclk 333 */
3506#define CLKCFG_FSB_MASK                                 (7 << 0)
3507#define CLKCFG_MEM_533                                  (1 << 4)
3508#define CLKCFG_MEM_667                                  (2 << 4)
3509#define CLKCFG_MEM_800                                  (3 << 4)
3510#define CLKCFG_MEM_MASK                                 (7 << 4)
3511
3512#define HPLLVCO                 _MMIO(MCHBAR_MIRROR_BASE + 0xc38)
3513#define HPLLVCO_MOBILE          _MMIO(MCHBAR_MIRROR_BASE + 0xc0f)
3514
3515#define TSC1                    _MMIO(0x11001)
3516#define   TSE                   (1<<0)
3517#define TR1                     _MMIO(0x11006)
3518#define TSFS                    _MMIO(0x11020)
3519#define   TSFS_SLOPE_MASK       0x0000ff00
3520#define   TSFS_SLOPE_SHIFT      8
3521#define   TSFS_INTR_MASK        0x000000ff
3522
3523#define CRSTANDVID              _MMIO(0x11100)
3524#define PXVFREQ(fstart)         _MMIO(0x11110 + (fstart) * 4)  /* P[0-15]VIDFREQ (0x1114c) (Ironlake) */
3525#define   PXVFREQ_PX_MASK       0x7f000000
3526#define   PXVFREQ_PX_SHIFT      24
3527#define VIDFREQ_BASE            _MMIO(0x11110)
3528#define VIDFREQ1                _MMIO(0x11110) /* VIDFREQ1-4 (0x1111c) (Cantiga) */
3529#define VIDFREQ2                _MMIO(0x11114)
3530#define VIDFREQ3                _MMIO(0x11118)
3531#define VIDFREQ4                _MMIO(0x1111c)
3532#define   VIDFREQ_P0_MASK       0x1f000000
3533#define   VIDFREQ_P0_SHIFT      24
3534#define   VIDFREQ_P0_CSCLK_MASK 0x00f00000
3535#define   VIDFREQ_P0_CSCLK_SHIFT 20
3536#define   VIDFREQ_P0_CRCLK_MASK 0x000f0000
3537#define   VIDFREQ_P0_CRCLK_SHIFT 16
3538#define   VIDFREQ_P1_MASK       0x00001f00
3539#define   VIDFREQ_P1_SHIFT      8
3540#define   VIDFREQ_P1_CSCLK_MASK 0x000000f0
3541#define   VIDFREQ_P1_CSCLK_SHIFT 4
3542#define   VIDFREQ_P1_CRCLK_MASK 0x0000000f
3543#define INTTOEXT_BASE_ILK       _MMIO(0x11300)
3544#define INTTOEXT_BASE           _MMIO(0x11120) /* INTTOEXT1-8 (0x1113c) */
3545#define   INTTOEXT_MAP3_SHIFT   24
3546#define   INTTOEXT_MAP3_MASK    (0x1f << INTTOEXT_MAP3_SHIFT)
3547#define   INTTOEXT_MAP2_SHIFT   16
3548#define   INTTOEXT_MAP2_MASK    (0x1f << INTTOEXT_MAP2_SHIFT)
3549#define   INTTOEXT_MAP1_SHIFT   8
3550#define   INTTOEXT_MAP1_MASK    (0x1f << INTTOEXT_MAP1_SHIFT)
3551#define   INTTOEXT_MAP0_SHIFT   0
3552#define   INTTOEXT_MAP0_MASK    (0x1f << INTTOEXT_MAP0_SHIFT)
3553#define MEMSWCTL                _MMIO(0x11170) /* Ironlake only */
3554#define   MEMCTL_CMD_MASK       0xe000
3555#define   MEMCTL_CMD_SHIFT      13
3556#define   MEMCTL_CMD_RCLK_OFF   0
3557#define   MEMCTL_CMD_RCLK_ON    1
3558#define   MEMCTL_CMD_CHFREQ     2
3559#define   MEMCTL_CMD_CHVID      3
3560#define   MEMCTL_CMD_VMMOFF     4
3561#define   MEMCTL_CMD_VMMON      5
3562#define   MEMCTL_CMD_STS        (1<<12) /* write 1 triggers command, clears
3563                                           when command complete */
3564#define   MEMCTL_FREQ_MASK      0x0f00 /* jitter, from 0-15 */
3565#define   MEMCTL_FREQ_SHIFT     8
3566#define   MEMCTL_SFCAVM         (1<<7)
3567#define   MEMCTL_TGT_VID_MASK   0x007f
3568#define MEMIHYST                _MMIO(0x1117c)
3569#define MEMINTREN               _MMIO(0x11180) /* 16 bits */
3570#define   MEMINT_RSEXIT_EN      (1<<8)
3571#define   MEMINT_CX_SUPR_EN     (1<<7)
3572#define   MEMINT_CONT_BUSY_EN   (1<<6)
3573#define   MEMINT_AVG_BUSY_EN    (1<<5)
3574#define   MEMINT_EVAL_CHG_EN    (1<<4)
3575#define   MEMINT_MON_IDLE_EN    (1<<3)
3576#define   MEMINT_UP_EVAL_EN     (1<<2)
3577#define   MEMINT_DOWN_EVAL_EN   (1<<1)
3578#define   MEMINT_SW_CMD_EN      (1<<0)
3579#define MEMINTRSTR              _MMIO(0x11182) /* 16 bits */
3580#define   MEM_RSEXIT_MASK       0xc000
3581#define   MEM_RSEXIT_SHIFT      14
3582#define   MEM_CONT_BUSY_MASK    0x3000
3583#define   MEM_CONT_BUSY_SHIFT   12
3584#define   MEM_AVG_BUSY_MASK     0x0c00
3585#define   MEM_AVG_BUSY_SHIFT    10
3586#define   MEM_EVAL_CHG_MASK     0x0300
3587#define   MEM_EVAL_BUSY_SHIFT   8
3588#define   MEM_MON_IDLE_MASK     0x00c0
3589#define   MEM_MON_IDLE_SHIFT    6
3590#define   MEM_UP_EVAL_MASK      0x0030
3591#define   MEM_UP_EVAL_SHIFT     4
3592#define   MEM_DOWN_EVAL_MASK    0x000c
3593#define   MEM_DOWN_EVAL_SHIFT   2
3594#define   MEM_SW_CMD_MASK       0x0003
3595#define   MEM_INT_STEER_GFX     0
3596#define   MEM_INT_STEER_CMR     1
3597#define   MEM_INT_STEER_SMI     2
3598#define   MEM_INT_STEER_SCI     3
3599#define MEMINTRSTS              _MMIO(0x11184)
3600#define   MEMINT_RSEXIT         (1<<7)
3601#define   MEMINT_CONT_BUSY      (1<<6)
3602#define   MEMINT_AVG_BUSY       (1<<5)
3603#define   MEMINT_EVAL_CHG       (1<<4)
3604#define   MEMINT_MON_IDLE       (1<<3)
3605#define   MEMINT_UP_EVAL        (1<<2)
3606#define   MEMINT_DOWN_EVAL      (1<<1)
3607#define   MEMINT_SW_CMD         (1<<0)
3608#define MEMMODECTL              _MMIO(0x11190)
3609#define   MEMMODE_BOOST_EN      (1<<31)
3610#define   MEMMODE_BOOST_FREQ_MASK 0x0f000000 /* jitter for boost, 0-15 */
3611#define   MEMMODE_BOOST_FREQ_SHIFT 24
3612#define   MEMMODE_IDLE_MODE_MASK 0x00030000
3613#define   MEMMODE_IDLE_MODE_SHIFT 16
3614#define   MEMMODE_IDLE_MODE_EVAL 0
3615#define   MEMMODE_IDLE_MODE_CONT 1
3616#define   MEMMODE_HWIDLE_EN     (1<<15)
3617#define   MEMMODE_SWMODE_EN     (1<<14)
3618#define   MEMMODE_RCLK_GATE     (1<<13)
3619#define   MEMMODE_HW_UPDATE     (1<<12)
3620#define   MEMMODE_FSTART_MASK   0x00000f00 /* starting jitter, 0-15 */
3621#define   MEMMODE_FSTART_SHIFT  8
3622#define   MEMMODE_FMAX_MASK     0x000000f0 /* max jitter, 0-15 */
3623#define   MEMMODE_FMAX_SHIFT    4
3624#define   MEMMODE_FMIN_MASK     0x0000000f /* min jitter, 0-15 */
3625#define RCBMAXAVG               _MMIO(0x1119c)
3626#define MEMSWCTL2               _MMIO(0x1119e) /* Cantiga only */
3627#define   SWMEMCMD_RENDER_OFF   (0 << 13)
3628#define   SWMEMCMD_RENDER_ON    (1 << 13)
3629#define   SWMEMCMD_SWFREQ       (2 << 13)
3630#define   SWMEMCMD_TARVID       (3 << 13)
3631#define   SWMEMCMD_VRM_OFF      (4 << 13)
3632#define   SWMEMCMD_VRM_ON       (5 << 13)
3633#define   CMDSTS                (1<<12)
3634#define   SFCAVM                (1<<11)
3635#define   SWFREQ_MASK           0x0380 /* P0-7 */
3636#define   SWFREQ_SHIFT          7
3637#define   TARVID_MASK           0x001f
3638#define MEMSTAT_CTG             _MMIO(0x111a0)
3639#define RCBMINAVG               _MMIO(0x111a0)
3640#define RCUPEI                  _MMIO(0x111b0)
3641#define RCDNEI                  _MMIO(0x111b4)
3642#define RSTDBYCTL               _MMIO(0x111b8)
3643#define   RS1EN                 (1<<31)
3644#define   RS2EN                 (1<<30)
3645#define   RS3EN                 (1<<29)
3646#define   D3RS3EN               (1<<28) /* Display D3 imlies RS3 */
3647#define   SWPROMORSX            (1<<27) /* RSx promotion timers ignored */
3648#define   RCWAKERW              (1<<26) /* Resetwarn from PCH causes wakeup */
3649#define   DPRSLPVREN            (1<<25) /* Fast voltage ramp enable */
3650#define   GFXTGHYST             (1<<24) /* Hysteresis to allow trunk gating */
3651#define   RCX_SW_EXIT           (1<<23) /* Leave RSx and prevent re-entry */
3652#define   RSX_STATUS_MASK       (7<<20)
3653#define   RSX_STATUS_ON         (0<<20)
3654#define   RSX_STATUS_RC1        (1<<20)
3655#define   RSX_STATUS_RC1E       (2<<20)
3656#define   RSX_STATUS_RS1        (3<<20)
3657#define   RSX_STATUS_RS2        (4<<20) /* aka rc6 */
3658#define   RSX_STATUS_RSVD       (5<<20) /* deep rc6 unsupported on ilk */
3659#define   RSX_STATUS_RS3        (6<<20) /* rs3 unsupported on ilk */
3660#define   RSX_STATUS_RSVD2      (7<<20)
3661#define   UWRCRSXE              (1<<19) /* wake counter limit prevents rsx */
3662#define   RSCRP                 (1<<18) /* rs requests control on rs1/2 reqs */
3663#define   JRSC                  (1<<17) /* rsx coupled to cpu c-state */
3664#define   RS2INC0               (1<<16) /* allow rs2 in cpu c0 */
3665#define   RS1CONTSAV_MASK       (3<<14)
3666#define   RS1CONTSAV_NO_RS1     (0<<14) /* rs1 doesn't save/restore context */
3667#define   RS1CONTSAV_RSVD       (1<<14)
3668#define   RS1CONTSAV_SAVE_RS1   (2<<14) /* rs1 saves context */
3669#define   RS1CONTSAV_FULL_RS1   (3<<14) /* rs1 saves and restores context */
3670#define   NORMSLEXLAT_MASK      (3<<12)
3671#define   SLOW_RS123            (0<<12)
3672#define   SLOW_RS23             (1<<12)
3673#define   SLOW_RS3              (2<<12)
3674#define   NORMAL_RS123          (3<<12)
3675#define   RCMODE_TIMEOUT        (1<<11) /* 0 is eval interval method */
3676#define   IMPROMOEN             (1<<10) /* promo is immediate or delayed until next idle interval (only for timeout method above) */
3677#define   RCENTSYNC             (1<<9) /* rs coupled to cpu c-state (3/6/7) */
3678#define   STATELOCK             (1<<7) /* locked to rs_cstate if 0 */
3679#define   RS_CSTATE_MASK        (3<<4)
3680#define   RS_CSTATE_C367_RS1    (0<<4)
3681#define   RS_CSTATE_C36_RS1_C7_RS2 (1<<4)
3682#define   RS_CSTATE_RSVD        (2<<4)
3683#define   RS_CSTATE_C367_RS2    (3<<4)
3684#define   REDSAVES              (1<<3) /* no context save if was idle during rs0 */
3685#define   REDRESTORES           (1<<2) /* no restore if was idle during rs0 */
3686#define VIDCTL                  _MMIO(0x111c0)
3687#define VIDSTS                  _MMIO(0x111c8)
3688#define VIDSTART                _MMIO(0x111cc) /* 8 bits */
3689#define MEMSTAT_ILK             _MMIO(0x111f8)
3690#define   MEMSTAT_VID_MASK      0x7f00
3691#define   MEMSTAT_VID_SHIFT     8
3692#define   MEMSTAT_PSTATE_MASK   0x00f8
3693#define   MEMSTAT_PSTATE_SHIFT  3
3694#define   MEMSTAT_MON_ACTV      (1<<2)
3695#define   MEMSTAT_SRC_CTL_MASK  0x0003
3696#define   MEMSTAT_SRC_CTL_CORE  0
3697#define   MEMSTAT_SRC_CTL_TRB   1
3698#define   MEMSTAT_SRC_CTL_THM   2
3699#define   MEMSTAT_SRC_CTL_STDBY 3
3700#define RCPREVBSYTUPAVG         _MMIO(0x113b8)
3701#define RCPREVBSYTDNAVG         _MMIO(0x113bc)
3702#define PMMISC                  _MMIO(0x11214)
3703#define   MCPPCE_EN             (1<<0) /* enable PM_MSG from PCH->MPC */
3704#define SDEW                    _MMIO(0x1124c)
3705#define CSIEW0                  _MMIO(0x11250)
3706#define CSIEW1                  _MMIO(0x11254)
3707#define CSIEW2                  _MMIO(0x11258)
3708#define PEW(i)                  _MMIO(0x1125c + (i) * 4) /* 5 registers */
3709#define DEW(i)                  _MMIO(0x11270 + (i) * 4) /* 3 registers */
3710#define MCHAFE                  _MMIO(0x112c0)
3711#define CSIEC                   _MMIO(0x112e0)
3712#define DMIEC                   _MMIO(0x112e4)
3713#define DDREC                   _MMIO(0x112e8)
3714#define PEG0EC                  _MMIO(0x112ec)
3715#define PEG1EC                  _MMIO(0x112f0)
3716#define GFXEC                   _MMIO(0x112f4)
3717#define RPPREVBSYTUPAVG         _MMIO(0x113b8)
3718#define RPPREVBSYTDNAVG         _MMIO(0x113bc)
3719#define ECR                     _MMIO(0x11600)
3720#define   ECR_GPFE              (1<<31)
3721#define   ECR_IMONE             (1<<30)
3722#define   ECR_CAP_MASK          0x0000001f /* Event range, 0-31 */
3723#define OGW0                    _MMIO(0x11608)
3724#define OGW1                    _MMIO(0x1160c)
3725#define EG0                     _MMIO(0x11610)
3726#define EG1                     _MMIO(0x11614)
3727#define EG2                     _MMIO(0x11618)
3728#define EG3                     _MMIO(0x1161c)
3729#define EG4                     _MMIO(0x11620)
3730#define EG5                     _MMIO(0x11624)
3731#define EG6                     _MMIO(0x11628)
3732#define EG7                     _MMIO(0x1162c)
3733#define PXW(i)                  _MMIO(0x11664 + (i) * 4) /* 4 registers */
3734#define PXWL(i)                 _MMIO(0x11680 + (i) * 8) /* 8 registers */
3735#define LCFUSE02                _MMIO(0x116c0)
3736#define   LCFUSE_HIV_MASK       0x000000ff
3737#define CSIPLL0                 _MMIO(0x12c10)
3738#define DDRMPLL1                _MMIO(0X12c20)
3739#define PEG_BAND_GAP_DATA       _MMIO(0x14d68)
3740
3741#define GEN6_GT_THREAD_STATUS_REG _MMIO(0x13805c)
3742#define GEN6_GT_THREAD_STATUS_CORE_MASK 0x7
3743
3744#define GEN6_GT_PERF_STATUS     _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x5948)
3745#define BXT_GT_PERF_STATUS      _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x7070)
3746#define GEN6_RP_STATE_LIMITS    _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x5994)
3747#define GEN6_RP_STATE_CAP       _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x5998)
3748#define BXT_RP_STATE_CAP        _MMIO(0x138170)
3749
3750/*
3751 * Make these a multiple of magic 25 to avoid SNB (eg. Dell XPS
3752 * 8300) freezing up around GPU hangs. Looks as if even
3753 * scheduling/timer interrupts start misbehaving if the RPS
3754 * EI/thresholds are "bad", leading to a very sluggish or even
3755 * frozen machine.
3756 */
3757#define INTERVAL_1_28_US(us)    roundup(((us) * 100) >> 7, 25)
3758#define INTERVAL_1_33_US(us)    (((us) * 3)   >> 2)
3759#define INTERVAL_0_833_US(us)   (((us) * 6) / 5)
3760#define GT_INTERVAL_FROM_US(dev_priv, us) (INTEL_GEN(dev_priv) >= 9 ? \
3761                                (IS_GEN9_LP(dev_priv) ? \
3762                                INTERVAL_0_833_US(us) : \
3763                                INTERVAL_1_33_US(us)) : \
3764                                INTERVAL_1_28_US(us))
3765
3766#define INTERVAL_1_28_TO_US(interval)  (((interval) << 7) / 100)
3767#define INTERVAL_1_33_TO_US(interval)  (((interval) << 2) / 3)
3768#define INTERVAL_0_833_TO_US(interval) (((interval) * 5)  / 6)
3769#define GT_PM_INTERVAL_TO_US(dev_priv, interval) (INTEL_GEN(dev_priv) >= 9 ? \
3770                           (IS_GEN9_LP(dev_priv) ? \
3771                           INTERVAL_0_833_TO_US(interval) : \
3772                           INTERVAL_1_33_TO_US(interval)) : \
3773                           INTERVAL_1_28_TO_US(interval))
3774
3775/*
3776 * Logical Context regs
3777 */
3778#define CCID                            _MMIO(0x2180)
3779#define   CCID_EN                       BIT(0)
3780#define   CCID_EXTENDED_STATE_RESTORE   BIT(2)
3781#define   CCID_EXTENDED_STATE_SAVE      BIT(3)
3782/*
3783 * Notes on SNB/IVB/VLV context size:
3784 * - Power context is saved elsewhere (LLC or stolen)
3785 * - Ring/execlist context is saved on SNB, not on IVB
3786 * - Extended context size already includes render context size
3787 * - We always need to follow the extended context size.
3788 *   SNB BSpec has comments indicating that we should use the
3789 *   render context size instead if execlists are disabled, but
3790 *   based on empirical testing that's just nonsense.
3791 * - Pipelined/VF state is saved on SNB/IVB respectively
3792 * - GT1 size just indicates how much of render context
3793 *   doesn't need saving on GT1
3794 */
3795#define CXT_SIZE                _MMIO(0x21a0)
3796#define GEN6_CXT_POWER_SIZE(cxt_reg)    (((cxt_reg) >> 24) & 0x3f)
3797#define GEN6_CXT_RING_SIZE(cxt_reg)     (((cxt_reg) >> 18) & 0x3f)
3798#define GEN6_CXT_RENDER_SIZE(cxt_reg)   (((cxt_reg) >> 12) & 0x3f)
3799#define GEN6_CXT_EXTENDED_SIZE(cxt_reg) (((cxt_reg) >> 6) & 0x3f)
3800#define GEN6_CXT_PIPELINE_SIZE(cxt_reg) (((cxt_reg) >> 0) & 0x3f)
3801#define GEN6_CXT_TOTAL_SIZE(cxt_reg)    (GEN6_CXT_RING_SIZE(cxt_reg) + \
3802                                        GEN6_CXT_EXTENDED_SIZE(cxt_reg) + \
3803                                        GEN6_CXT_PIPELINE_SIZE(cxt_reg))
3804#define GEN7_CXT_SIZE           _MMIO(0x21a8)
3805#define GEN7_CXT_POWER_SIZE(ctx_reg)    (((ctx_reg) >> 25) & 0x7f)
3806#define GEN7_CXT_RING_SIZE(ctx_reg)     (((ctx_reg) >> 22) & 0x7)
3807#define GEN7_CXT_RENDER_SIZE(ctx_reg)   (((ctx_reg) >> 16) & 0x3f)
3808#define GEN7_CXT_EXTENDED_SIZE(ctx_reg) (((ctx_reg) >> 9) & 0x7f)
3809#define GEN7_CXT_GT1_SIZE(ctx_reg)      (((ctx_reg) >> 6) & 0x7)
3810#define GEN7_CXT_VFSTATE_SIZE(ctx_reg)  (((ctx_reg) >> 0) & 0x3f)
3811#define GEN7_CXT_TOTAL_SIZE(ctx_reg)    (GEN7_CXT_EXTENDED_SIZE(ctx_reg) + \
3812                                         GEN7_CXT_VFSTATE_SIZE(ctx_reg))
3813
3814enum {
3815        INTEL_ADVANCED_CONTEXT = 0,
3816        INTEL_LEGACY_32B_CONTEXT,
3817        INTEL_ADVANCED_AD_CONTEXT,
3818        INTEL_LEGACY_64B_CONTEXT
3819};
3820
3821enum {
3822        FAULT_AND_HANG = 0,
3823        FAULT_AND_HALT, /* Debug only */
3824        FAULT_AND_STREAM,
3825        FAULT_AND_CONTINUE /* Unsupported */
3826};
3827
3828#define GEN8_CTX_VALID (1<<0)
3829#define GEN8_CTX_FORCE_PD_RESTORE (1<<1)
3830#define GEN8_CTX_FORCE_RESTORE (1<<2)
3831#define GEN8_CTX_L3LLC_COHERENT (1<<5)
3832#define GEN8_CTX_PRIVILEGE (1<<8)
3833#define GEN8_CTX_ADDRESSING_MODE_SHIFT 3
3834
3835#define GEN8_CTX_ID_SHIFT 32
3836#define GEN8_CTX_ID_WIDTH 21
3837
3838#define CHV_CLK_CTL1                    _MMIO(0x101100)
3839#define VLV_CLK_CTL2                    _MMIO(0x101104)
3840#define   CLK_CTL2_CZCOUNT_30NS_SHIFT   28
3841
3842/*
3843 * Overlay regs
3844 */
3845
3846#define OVADD                   _MMIO(0x30000)
3847#define DOVSTA                  _MMIO(0x30008)
3848#define OC_BUF                  (0x3<<20)
3849#define OGAMC5                  _MMIO(0x30010)
3850#define OGAMC4                  _MMIO(0x30014)
3851#define OGAMC3                  _MMIO(0x30018)
3852#define OGAMC2                  _MMIO(0x3001c)
3853#define OGAMC1                  _MMIO(0x30020)
3854#define OGAMC0                  _MMIO(0x30024)
3855
3856/*
3857 * GEN9 clock gating regs
3858 */
3859#define GEN9_CLKGATE_DIS_0              _MMIO(0x46530)
3860#define   DARBF_GATING_DIS              (1 << 27)
3861#define   PWM2_GATING_DIS               (1 << 14)
3862#define   PWM1_GATING_DIS               (1 << 13)
3863
3864#define GEN9_CLKGATE_DIS_4              _MMIO(0x4653C)
3865#define   BXT_GMBUS_GATING_DIS          (1 << 14)
3866
3867#define _CLKGATE_DIS_PSL_A              0x46520
3868#define _CLKGATE_DIS_PSL_B              0x46524
3869#define _CLKGATE_DIS_PSL_C              0x46528
3870#define   DPF_GATING_DIS                (1 << 10)
3871#define   DPF_RAM_GATING_DIS            (1 << 9)
3872#define   DPFR_GATING_DIS               (1 << 8)
3873
3874#define CLKGATE_DIS_PSL(pipe) \
3875        _MMIO_PIPE(pipe, _CLKGATE_DIS_PSL_A, _CLKGATE_DIS_PSL_B)
3876
3877/*
3878 * GEN10 clock gating regs
3879 */
3880#define SLICE_UNIT_LEVEL_CLKGATE        _MMIO(0x94d4)
3881#define  SARBUNIT_CLKGATE_DIS           (1 << 5)
3882#define  RCCUNIT_CLKGATE_DIS            (1 << 7)
3883
3884#define UNSLICE_UNIT_LEVEL_CLKGATE      _MMIO(0x9434)
3885#define  VFUNIT_CLKGATE_DIS             (1 << 20)
3886
3887/*
3888 * Display engine regs
3889 */
3890
3891/* Pipe A CRC regs */
3892#define _PIPE_CRC_CTL_A                 0x60050
3893#define   PIPE_CRC_ENABLE               (1 << 31)
3894/* ivb+ source selection */
3895#define   PIPE_CRC_SOURCE_PRIMARY_IVB   (0 << 29)
3896#define   PIPE_CRC_SOURCE_SPRITE_IVB    (1 << 29)
3897#define   PIPE_CRC_SOURCE_PF_IVB        (2 << 29)
3898/* ilk+ source selection */
3899#define   PIPE_CRC_SOURCE_PRIMARY_ILK   (0 << 28)
3900#define   PIPE_CRC_SOURCE_SPRITE_ILK    (1 << 28)
3901#define   PIPE_CRC_SOURCE_PIPE_ILK      (2 << 28)
3902/* embedded DP port on the north display block, reserved on ivb */
3903#define   PIPE_CRC_SOURCE_PORT_A_ILK    (4 << 28)
3904#define   PIPE_CRC_SOURCE_FDI_ILK       (5 << 28) /* reserved on ivb */
3905/* vlv source selection */
3906#define   PIPE_CRC_SOURCE_PIPE_VLV      (0 << 27)
3907#define   PIPE_CRC_SOURCE_HDMIB_VLV     (1 << 27)
3908#define   PIPE_CRC_SOURCE_HDMIC_VLV     (2 << 27)
3909/* with DP port the pipe source is invalid */
3910#define   PIPE_CRC_SOURCE_DP_D_VLV      (3 << 27)
3911#define   PIPE_CRC_SOURCE_DP_B_VLV      (6 << 27)
3912#define   PIPE_CRC_SOURCE_DP_C_VLV      (7 << 27)
3913/* gen3+ source selection */
3914#define   PIPE_CRC_SOURCE_PIPE_I9XX     (0 << 28)
3915#define   PIPE_CRC_SOURCE_SDVOB_I9XX    (1 << 28)
3916#define   PIPE_CRC_SOURCE_SDVOC_I9XX    (2 << 28)
3917/* with DP/TV port the pipe source is invalid */
3918#define   PIPE_CRC_SOURCE_DP_D_G4X      (3 << 28)
3919#define   PIPE_CRC_SOURCE_TV_PRE        (4 << 28)
3920#define   PIPE_CRC_SOURCE_TV_POST       (5 << 28)
3921#define   PIPE_CRC_SOURCE_DP_B_G4X      (6 << 28)
3922#define   PIPE_CRC_SOURCE_DP_C_G4X      (7 << 28)
3923/* gen2 doesn't have source selection bits */
3924#define   PIPE_CRC_INCLUDE_BORDER_I8XX  (1 << 30)
3925
3926#define _PIPE_CRC_RES_1_A_IVB           0x60064
3927#define _PIPE_CRC_RES_2_A_IVB           0x60068
3928#define _PIPE_CRC_RES_3_A_IVB           0x6006c
3929#define _PIPE_CRC_RES_4_A_IVB           0x60070
3930#define _PIPE_CRC_RES_5_A_IVB           0x60074
3931
3932#define _PIPE_CRC_RES_RED_A             0x60060
3933#define _PIPE_CRC_RES_GREEN_A           0x60064
3934#define _PIPE_CRC_RES_BLUE_A            0x60068
3935#define _PIPE_CRC_RES_RES1_A_I915       0x6006c
3936#define _PIPE_CRC_RES_RES2_A_G4X        0x60080
3937
3938/* Pipe B CRC regs */
3939#define _PIPE_CRC_RES_1_B_IVB           0x61064
3940#define _PIPE_CRC_RES_2_B_IVB           0x61068
3941#define _PIPE_CRC_RES_3_B_IVB           0x6106c
3942#define _PIPE_CRC_RES_4_B_IVB           0x61070
3943#define _PIPE_CRC_RES_5_B_IVB           0x61074
3944
3945#define PIPE_CRC_CTL(pipe)              _MMIO_TRANS2(pipe, _PIPE_CRC_CTL_A)
3946#define PIPE_CRC_RES_1_IVB(pipe)        _MMIO_TRANS2(pipe, _PIPE_CRC_RES_1_A_IVB)
3947#define PIPE_CRC_RES_2_IVB(pipe)        _MMIO_TRANS2(pipe, _PIPE_CRC_RES_2_A_IVB)
3948#define PIPE_CRC_RES_3_IVB(pipe)        _MMIO_TRANS2(pipe, _PIPE_CRC_RES_3_A_IVB)
3949#define PIPE_CRC_RES_4_IVB(pipe)        _MMIO_TRANS2(pipe, _PIPE_CRC_RES_4_A_IVB)
3950#define PIPE_CRC_RES_5_IVB(pipe)        _MMIO_TRANS2(pipe, _PIPE_CRC_RES_5_A_IVB)
3951
3952#define PIPE_CRC_RES_RED(pipe)          _MMIO_TRANS2(pipe, _PIPE_CRC_RES_RED_A)
3953#define PIPE_CRC_RES_GREEN(pipe)        _MMIO_TRANS2(pipe, _PIPE_CRC_RES_GREEN_A)
3954#define PIPE_CRC_RES_BLUE(pipe)         _MMIO_TRANS2(pipe, _PIPE_CRC_RES_BLUE_A)
3955#define PIPE_CRC_RES_RES1_I915(pipe)    _MMIO_TRANS2(pipe, _PIPE_CRC_RES_RES1_A_I915)
3956#define PIPE_CRC_RES_RES2_G4X(pipe)     _MMIO_TRANS2(pipe, _PIPE_CRC_RES_RES2_A_G4X)
3957
3958/* Pipe A timing regs */
3959#define _HTOTAL_A       0x60000
3960#define _HBLANK_A       0x60004
3961#define _HSYNC_A        0x60008
3962#define _VTOTAL_A       0x6000c
3963#define _VBLANK_A       0x60010
3964#define _VSYNC_A        0x60014
3965#define _PIPEASRC       0x6001c
3966#define _BCLRPAT_A      0x60020
3967#define _VSYNCSHIFT_A   0x60028
3968#define _PIPE_MULT_A    0x6002c
3969
3970/* Pipe B timing regs */
3971#define _HTOTAL_B       0x61000
3972#define _HBLANK_B       0x61004
3973#define _HSYNC_B        0x61008
3974#define _VTOTAL_B       0x6100c
3975#define _VBLANK_B       0x61010
3976#define _VSYNC_B        0x61014
3977#define _PIPEBSRC       0x6101c
3978#define _BCLRPAT_B      0x61020
3979#define _VSYNCSHIFT_B   0x61028
3980#define _PIPE_MULT_B    0x6102c
3981
3982#define TRANSCODER_A_OFFSET 0x60000
3983#define TRANSCODER_B_OFFSET 0x61000
3984#define TRANSCODER_C_OFFSET 0x62000
3985#define CHV_TRANSCODER_C_OFFSET 0x63000
3986#define TRANSCODER_EDP_OFFSET 0x6f000
3987
3988#define _MMIO_TRANS2(pipe, reg) _MMIO(dev_priv->info.trans_offsets[(pipe)] - \
3989        dev_priv->info.trans_offsets[TRANSCODER_A] + (reg) + \
3990        dev_priv->info.display_mmio_offset)
3991
3992#define HTOTAL(trans)           _MMIO_TRANS2(trans, _HTOTAL_A)
3993#define HBLANK(trans)           _MMIO_TRANS2(trans, _HBLANK_A)
3994#define HSYNC(trans)            _MMIO_TRANS2(trans, _HSYNC_A)
3995#define VTOTAL(trans)           _MMIO_TRANS2(trans, _VTOTAL_A)
3996#define VBLANK(trans)           _MMIO_TRANS2(trans, _VBLANK_A)
3997#define VSYNC(trans)            _MMIO_TRANS2(trans, _VSYNC_A)
3998#define BCLRPAT(trans)          _MMIO_TRANS2(trans, _BCLRPAT_A)
3999#define VSYNCSHIFT(trans)       _MMIO_TRANS2(trans, _VSYNCSHIFT_A)
4000#define PIPESRC(trans)          _MMIO_TRANS2(trans, _PIPEASRC)
4001#define PIPE_MULT(trans)        _MMIO_TRANS2(trans, _PIPE_MULT_A)
4002
4003/* VLV eDP PSR registers */
4004#define _PSRCTLA                                (VLV_DISPLAY_BASE + 0x60090)
4005#define _PSRCTLB                                (VLV_DISPLAY_BASE + 0x61090)
4006#define  VLV_EDP_PSR_ENABLE                     (1<<0)
4007#define  VLV_EDP_PSR_RESET                      (1<<1)
4008#define  VLV_EDP_PSR_MODE_MASK                  (7<<2)
4009#define  VLV_EDP_PSR_MODE_HW_TIMER              (1<<3)
4010#define  VLV_EDP_PSR_MODE_SW_TIMER              (1<<2)
4011#define  VLV_EDP_PSR_SINGLE_FRAME_UPDATE        (1<<7)
4012#define  VLV_EDP_PSR_ACTIVE_ENTRY               (1<<8)
4013#define  VLV_EDP_PSR_SRC_TRANSMITTER_STATE      (1<<9)
4014#define  VLV_EDP_PSR_DBL_FRAME                  (1<<10)
4015#define  VLV_EDP_PSR_FRAME_COUNT_MASK           (0xff<<16)
4016#define  VLV_EDP_PSR_IDLE_FRAME_SHIFT           16
4017#define VLV_PSRCTL(pipe)        _MMIO_PIPE(pipe, _PSRCTLA, _PSRCTLB)
4018
4019#define _VSCSDPA                        (VLV_DISPLAY_BASE + 0x600a0)
4020#define _VSCSDPB                        (VLV_DISPLAY_BASE + 0x610a0)
4021#define  VLV_EDP_PSR_SDP_FREQ_MASK      (3<<30)
4022#define  VLV_EDP_PSR_SDP_FREQ_ONCE      (1<<31)
4023#define  VLV_EDP_PSR_SDP_FREQ_EVFRAME   (1<<30)
4024#define VLV_VSCSDP(pipe)        _MMIO_PIPE(pipe, _VSCSDPA, _VSCSDPB)
4025
4026#define _PSRSTATA                       (VLV_DISPLAY_BASE + 0x60094)
4027#define _PSRSTATB                       (VLV_DISPLAY_BASE + 0x61094)
4028#define  VLV_EDP_PSR_LAST_STATE_MASK    (7<<3)
4029#define  VLV_EDP_PSR_CURR_STATE_MASK    7
4030#define  VLV_EDP_PSR_DISABLED           (0<<0)
4031#define  VLV_EDP_PSR_INACTIVE           (1<<0)
4032#define  VLV_EDP_PSR_IN_TRANS_TO_ACTIVE (2<<0)
4033#define  VLV_EDP_PSR_ACTIVE_NORFB_UP    (3<<0)
4034#define  VLV_EDP_PSR_ACTIVE_SF_UPDATE   (4<<0)
4035#define  VLV_EDP_PSR_EXIT               (5<<0)
4036#define  VLV_EDP_PSR_IN_TRANS           (1<<7)
4037#define VLV_PSRSTAT(pipe)       _MMIO_PIPE(pipe, _PSRSTATA, _PSRSTATB)
4038
4039/* HSW+ eDP PSR registers */
4040#define HSW_EDP_PSR_BASE        0x64800
4041#define BDW_EDP_PSR_BASE        0x6f800
4042#define EDP_PSR_CTL                             _MMIO(dev_priv->psr_mmio_base + 0)
4043#define   EDP_PSR_ENABLE                        (1<<31)
4044#define   BDW_PSR_SINGLE_FRAME                  (1<<30)
4045#define   EDP_PSR_RESTORE_PSR_ACTIVE_CTX_MASK   (1<<29) /* SW can't modify */
4046#define   EDP_PSR_LINK_STANDBY                  (1<<27)
4047#define   EDP_PSR_MIN_LINK_ENTRY_TIME_MASK      (3<<25)
4048#define   EDP_PSR_MIN_LINK_ENTRY_TIME_8_LINES   (0<<25)
4049#define   EDP_PSR_MIN_LINK_ENTRY_TIME_4_LINES   (1<<25)
4050#define   EDP_PSR_MIN_LINK_ENTRY_TIME_2_LINES   (2<<25)
4051#define   EDP_PSR_MIN_LINK_ENTRY_TIME_0_LINES   (3<<25)
4052#define   EDP_PSR_MAX_SLEEP_TIME_SHIFT          20
4053#define   EDP_PSR_SKIP_AUX_EXIT                 (1<<12)
4054#define   EDP_PSR_TP1_TP2_SEL                   (0<<11)
4055#define   EDP_PSR_TP1_TP3_SEL                   (1<<11)
4056#define   EDP_PSR_TP2_TP3_TIME_500us            (0<<8)
4057#define   EDP_PSR_TP2_TP3_TIME_100us            (1<<8)
4058#define   EDP_PSR_TP2_TP3_TIME_2500us           (2<<8)
4059#define   EDP_PSR_TP2_TP3_TIME_0us              (3<<8)
4060#define   EDP_PSR_TP1_TIME_500us                (0<<4)
4061#define   EDP_PSR_TP1_TIME_100us                (1<<4)
4062#define   EDP_PSR_TP1_TIME_2500us               (2<<4)
4063#define   EDP_PSR_TP1_TIME_0us                  (3<<4)
4064#define   EDP_PSR_IDLE_FRAME_SHIFT              0
4065
4066#define EDP_PSR_AUX_CTL                         _MMIO(dev_priv->psr_mmio_base + 0x10)
4067#define EDP_PSR_AUX_DATA(i)                     _MMIO(dev_priv->psr_mmio_base + 0x14 + (i) * 4) /* 5 registers */
4068
4069#define EDP_PSR_STATUS_CTL                      _MMIO(dev_priv->psr_mmio_base + 0x40)
4070#define   EDP_PSR_STATUS_STATE_MASK             (7<<29)
4071#define   EDP_PSR_STATUS_STATE_IDLE             (0<<29)
4072#define   EDP_PSR_STATUS_STATE_SRDONACK         (1<<29)
4073#define   EDP_PSR_STATUS_STATE_SRDENT           (2<<29)
4074#define   EDP_PSR_STATUS_STATE_BUFOFF           (3<<29)
4075#define   EDP_PSR_STATUS_STATE_BUFON            (4<<29)
4076#define   EDP_PSR_STATUS_STATE_AUXACK           (5<<29)
4077#define   EDP_PSR_STATUS_STATE_SRDOFFACK        (6<<29)
4078#define   EDP_PSR_STATUS_LINK_MASK              (3<<26)
4079#define   EDP_PSR_STATUS_LINK_FULL_OFF          (0<<26)
4080#define   EDP_PSR_STATUS_LINK_FULL_ON           (1<<26)
4081#define   EDP_PSR_STATUS_LINK_STANDBY           (2<<26)
4082#define   EDP_PSR_STATUS_MAX_SLEEP_TIMER_SHIFT  20
4083#define   EDP_PSR_STATUS_MAX_SLEEP_TIMER_MASK   0x1f
4084#define   EDP_PSR_STATUS_COUNT_SHIFT            16
4085#define   EDP_PSR_STATUS_COUNT_MASK             0xf
4086#define   EDP_PSR_STATUS_AUX_ERROR              (1<<15)
4087#define   EDP_PSR_STATUS_AUX_SENDING            (1<<12)
4088#define   EDP_PSR_STATUS_SENDING_IDLE           (1<<9)
4089#define   EDP_PSR_STATUS_SENDING_TP2_TP3        (1<<8)
4090#define   EDP_PSR_STATUS_SENDING_TP1            (1<<4)
4091#define   EDP_PSR_STATUS_IDLE_MASK              0xf
4092
4093#define EDP_PSR_PERF_CNT                _MMIO(dev_priv->psr_mmio_base + 0x44)
4094#define   EDP_PSR_PERF_CNT_MASK         0xffffff
4095
4096#define EDP_PSR_DEBUG_CTL               _MMIO(dev_priv->psr_mmio_base + 0x60)
4097#define   EDP_PSR_DEBUG_MASK_MAX_SLEEP         (1<<28)
4098#define   EDP_PSR_DEBUG_MASK_LPSP              (1<<27)
4099#define   EDP_PSR_DEBUG_MASK_MEMUP             (1<<26)
4100#define   EDP_PSR_DEBUG_MASK_HPD               (1<<25)
4101#define   EDP_PSR_DEBUG_MASK_DISP_REG_WRITE    (1<<16)
4102#define   EDP_PSR_DEBUG_EXIT_ON_PIXEL_UNDERRUN (1<<15)
4103
4104#define EDP_PSR2_CTL                    _MMIO(0x6f900)
4105#define   EDP_PSR2_ENABLE               (1<<31)
4106#define   EDP_SU_TRACK_ENABLE           (1<<30)
4107#define   EDP_MAX_SU_DISABLE_TIME(t)    ((t)<<20)
4108#define   EDP_MAX_SU_DISABLE_TIME_MASK  (0x1f<<20)
4109#define   EDP_PSR2_TP2_TIME_500         (0<<8)
4110#define   EDP_PSR2_TP2_TIME_100         (1<<8)
4111#define   EDP_PSR2_TP2_TIME_2500        (2<<8)
4112#define   EDP_PSR2_TP2_TIME_50          (3<<8)
4113#define   EDP_PSR2_TP2_TIME_MASK        (3<<8)
4114#define   EDP_PSR2_FRAME_BEFORE_SU_SHIFT 4
4115#define   EDP_PSR2_FRAME_BEFORE_SU_MASK (0xf<<4)
4116#define   EDP_PSR2_IDLE_MASK            0xf
4117#define   EDP_PSR2_FRAME_BEFORE_SU(a)   ((a)<<4)
4118
4119#define EDP_PSR2_STATUS_CTL            _MMIO(0x6f940)
4120#define EDP_PSR2_STATUS_STATE_MASK     (0xf<<28)
4121#define EDP_PSR2_STATUS_STATE_SHIFT    28
4122
4123/* VGA port control */
4124#define ADPA                    _MMIO(0x61100)
4125#define PCH_ADPA                _MMIO(0xe1100)
4126#define VLV_ADPA                _MMIO(VLV_DISPLAY_BASE + 0x61100)
4127
4128#define   ADPA_DAC_ENABLE       (1<<31)
4129#define   ADPA_DAC_DISABLE      0
4130#define   ADPA_PIPE_SELECT_MASK (1<<30)
4131#define   ADPA_PIPE_A_SELECT    0
4132#define   ADPA_PIPE_B_SELECT    (1<<30)
4133#define   ADPA_PIPE_SELECT(pipe) ((pipe) << 30)
4134/* CPT uses bits 29:30 for pch transcoder select */
4135#define   ADPA_CRT_HOTPLUG_MASK  0x03ff0000 /* bit 25-16 */
4136#define   ADPA_CRT_HOTPLUG_MONITOR_NONE  (0<<24)
4137#define   ADPA_CRT_HOTPLUG_MONITOR_MASK  (3<<24)
4138#define   ADPA_CRT_HOTPLUG_MONITOR_COLOR (3<<24)
4139#define   ADPA_CRT_HOTPLUG_MONITOR_MONO  (2<<24)
4140#define   ADPA_CRT_HOTPLUG_ENABLE        (1<<23)
4141#define   ADPA_CRT_HOTPLUG_PERIOD_64     (0<<22)
4142#define   ADPA_CRT_HOTPLUG_PERIOD_128    (1<<22)
4143#define   ADPA_CRT_HOTPLUG_WARMUP_5MS    (0<<21)
4144#define   ADPA_CRT_HOTPLUG_WARMUP_10MS   (1<<21)
4145#define   ADPA_CRT_HOTPLUG_SAMPLE_2S     (0<<20)
4146#define   ADPA_CRT_HOTPLUG_SAMPLE_4S     (1<<20)
4147#define   ADPA_CRT_HOTPLUG_VOLTAGE_40    (0<<18)
4148#define   ADPA_CRT_HOTPLUG_VOLTAGE_50    (1<<18)
4149#define   ADPA_CRT_HOTPLUG_VOLTAGE_60    (2<<18)
4150#define   ADPA_CRT_HOTPLUG_VOLTAGE_70    (3<<18)
4151#define   ADPA_CRT_HOTPLUG_VOLREF_325MV  (0<<17)
4152#define   ADPA_CRT_HOTPLUG_VOLREF_475MV  (1<<17)
4153#define   ADPA_CRT_HOTPLUG_FORCE_TRIGGER (1<<16)
4154#define   ADPA_USE_VGA_HVPOLARITY (1<<15)
4155#define   ADPA_SETS_HVPOLARITY  0
4156#define   ADPA_VSYNC_CNTL_DISABLE (1<<10)
4157#define   ADPA_VSYNC_CNTL_ENABLE 0
4158#define   ADPA_HSYNC_CNTL_DISABLE (1<<11)
4159#define   ADPA_HSYNC_CNTL_ENABLE 0
4160#define   ADPA_VSYNC_ACTIVE_HIGH (1<<4)
4161#define   ADPA_VSYNC_ACTIVE_LOW 0
4162#define   ADPA_HSYNC_ACTIVE_HIGH (1<<3)
4163#define   ADPA_HSYNC_ACTIVE_LOW 0
4164#define   ADPA_DPMS_MASK        (~(3<<10))
4165#define   ADPA_DPMS_ON          (0<<10)
4166#define   ADPA_DPMS_SUSPEND     (1<<10)
4167#define   ADPA_DPMS_STANDBY     (2<<10)
4168#define   ADPA_DPMS_OFF         (3<<10)
4169
4170
4171/* Hotplug control (945+ only) */
4172#define PORT_HOTPLUG_EN         _MMIO(dev_priv->info.display_mmio_offset + 0x61110)
4173#define   PORTB_HOTPLUG_INT_EN                  (1 << 29)
4174#define   PORTC_HOTPLUG_INT_EN                  (1 << 28)
4175#define   PORTD_HOTPLUG_INT_EN                  (1 << 27)
4176#define   SDVOB_HOTPLUG_INT_EN                  (1 << 26)
4177#define   SDVOC_HOTPLUG_INT_EN                  (1 << 25)
4178#define   TV_HOTPLUG_INT_EN                     (1 << 18)
4179#define   CRT_HOTPLUG_INT_EN                    (1 << 9)
4180#define HOTPLUG_INT_EN_MASK                     (PORTB_HOTPLUG_INT_EN | \
4181                                                 PORTC_HOTPLUG_INT_EN | \
4182                                                 PORTD_HOTPLUG_INT_EN | \
4183                                                 SDVOC_HOTPLUG_INT_EN | \
4184                                                 SDVOB_HOTPLUG_INT_EN | \
4185                                                 CRT_HOTPLUG_INT_EN)
4186#define   CRT_HOTPLUG_FORCE_DETECT              (1 << 3)
4187#define CRT_HOTPLUG_ACTIVATION_PERIOD_32        (0 << 8)
4188/* must use period 64 on GM45 according to docs */
4189#define CRT_HOTPLUG_ACTIVATION_PERIOD_64        (1 << 8)
4190#define CRT_HOTPLUG_DAC_ON_TIME_2M              (0 << 7)
4191#define CRT_HOTPLUG_DAC_ON_TIME_4M              (1 << 7)
4192#define CRT_HOTPLUG_VOLTAGE_COMPARE_40          (0 << 5)
4193#define CRT_HOTPLUG_VOLTAGE_COMPARE_50          (1 << 5)
4194#define CRT_HOTPLUG_VOLTAGE_COMPARE_60          (2 << 5)
4195#define CRT_HOTPLUG_VOLTAGE_COMPARE_70          (3 << 5)
4196#define CRT_HOTPLUG_VOLTAGE_COMPARE_MASK        (3 << 5)
4197#define CRT_HOTPLUG_DETECT_DELAY_1G             (0 << 4)
4198#define CRT_HOTPLUG_DETECT_DELAY_2G             (1 << 4)
4199#define CRT_HOTPLUG_DETECT_VOLTAGE_325MV        (0 << 2)
4200#define CRT_HOTPLUG_DETECT_VOLTAGE_475MV        (1 << 2)
4201
4202#define PORT_HOTPLUG_STAT       _MMIO(dev_priv->info.display_mmio_offset + 0x61114)
4203/*
4204 * HDMI/DP bits are g4x+
4205 *
4206 * WARNING: Bspec for hpd status bits on gen4 seems to be completely confused.
4207 * Please check the detailed lore in the commit message for for experimental
4208 * evidence.
4209 */
4210/* Bspec says GM45 should match G4X/VLV/CHV, but reality disagrees */
4211#define   PORTD_HOTPLUG_LIVE_STATUS_GM45        (1 << 29)
4212#define   PORTC_HOTPLUG_LIVE_STATUS_GM45        (1 << 28)
4213#define   PORTB_HOTPLUG_LIVE_STATUS_GM45        (1 << 27)
4214/* G4X/VLV/CHV DP/HDMI bits again match Bspec */
4215#define   PORTD_HOTPLUG_LIVE_STATUS_G4X         (1 << 27)
4216#define   PORTC_HOTPLUG_LIVE_STATUS_G4X         (1 << 28)
4217#define   PORTB_HOTPLUG_LIVE_STATUS_G4X         (1 << 29)
4218#define   PORTD_HOTPLUG_INT_STATUS              (3 << 21)
4219#define   PORTD_HOTPLUG_INT_LONG_PULSE          (2 << 21)
4220#define   PORTD_HOTPLUG_INT_SHORT_PULSE         (1 << 21)
4221#define   PORTC_HOTPLUG_INT_STATUS              (3 << 19)
4222#define   PORTC_HOTPLUG_INT_LONG_PULSE          (2 << 19)
4223#define   PORTC_HOTPLUG_INT_SHORT_PULSE         (1 << 19)
4224#define   PORTB_HOTPLUG_INT_STATUS              (3 << 17)
4225#define   PORTB_HOTPLUG_INT_LONG_PULSE          (2 << 17)
4226#define   PORTB_HOTPLUG_INT_SHORT_PLUSE         (1 << 17)
4227/* CRT/TV common between gen3+ */
4228#define   CRT_HOTPLUG_INT_STATUS                (1 << 11)
4229#define   TV_HOTPLUG_INT_STATUS                 (1 << 10)
4230#define   CRT_HOTPLUG_MONITOR_MASK              (3 << 8)
4231#define   CRT_HOTPLUG_MONITOR_COLOR             (3 << 8)
4232#define   CRT_HOTPLUG_MONITOR_MONO              (2 << 8)
4233#define   CRT_HOTPLUG_MONITOR_NONE              (0 << 8)
4234#define   DP_AUX_CHANNEL_D_INT_STATUS_G4X       (1 << 6)
4235#define   DP_AUX_CHANNEL_C_INT_STATUS_G4X       (1 << 5)
4236#define   DP_AUX_CHANNEL_B_INT_STATUS_G4X       (1 << 4)
4237#define   DP_AUX_CHANNEL_MASK_INT_STATUS_G4X    (7 << 4)
4238
4239/* SDVO is different across gen3/4 */
4240#define   SDVOC_HOTPLUG_INT_STATUS_G4X          (1 << 3)
4241#define   SDVOB_HOTPLUG_INT_STATUS_G4X          (1 << 2)
4242/*
4243 * Bspec seems to be seriously misleaded about the SDVO hpd bits on i965g/gm,
4244 * since reality corrobates that they're the same as on gen3. But keep these
4245 * bits here (and the comment!) to help any other lost wanderers back onto the
4246 * right tracks.
4247 */
4248#define   SDVOC_HOTPLUG_INT_STATUS_I965         (3 << 4)
4249#define   SDVOB_HOTPLUG_INT_STATUS_I965         (3 << 2)
4250#define   SDVOC_HOTPLUG_INT_STATUS_I915         (1 << 7)
4251#define   SDVOB_HOTPLUG_INT_STATUS_I915         (1 << 6)
4252#define   HOTPLUG_INT_STATUS_G4X                (CRT_HOTPLUG_INT_STATUS | \
4253                                                 SDVOB_HOTPLUG_INT_STATUS_G4X | \
4254                                                 SDVOC_HOTPLUG_INT_STATUS_G4X | \
4255                                                 PORTB_HOTPLUG_INT_STATUS | \
4256                                                 PORTC_HOTPLUG_INT_STATUS | \
4257                                                 PORTD_HOTPLUG_INT_STATUS)
4258
4259#define HOTPLUG_INT_STATUS_I915                 (CRT_HOTPLUG_INT_STATUS | \
4260                                                 SDVOB_HOTPLUG_INT_STATUS_I915 | \
4261                                                 SDVOC_HOTPLUG_INT_STATUS_I915 | \
4262                                                 PORTB_HOTPLUG_INT_STATUS | \
4263                                                 PORTC_HOTPLUG_INT_STATUS | \
4264                                                 PORTD_HOTPLUG_INT_STATUS)
4265
4266/* SDVO and HDMI port control.
4267 * The same register may be used for SDVO or HDMI */
4268#define _GEN3_SDVOB     0x61140
4269#define _GEN3_SDVOC     0x61160
4270#define GEN3_SDVOB      _MMIO(_GEN3_SDVOB)
4271#define GEN3_SDVOC      _MMIO(_GEN3_SDVOC)
4272#define GEN4_HDMIB      GEN3_SDVOB
4273#define GEN4_HDMIC      GEN3_SDVOC
4274#define VLV_HDMIB       _MMIO(VLV_DISPLAY_BASE + 0x61140)
4275#define VLV_HDMIC       _MMIO(VLV_DISPLAY_BASE + 0x61160)
4276#define CHV_HDMID       _MMIO(VLV_DISPLAY_BASE + 0x6116C)
4277#define PCH_SDVOB       _MMIO(0xe1140)
4278#define PCH_HDMIB       PCH_SDVOB
4279#define PCH_HDMIC       _MMIO(0xe1150)
4280#define PCH_HDMID       _MMIO(0xe1160)
4281
4282#define PORT_DFT_I9XX                           _MMIO(0x61150)
4283#define   DC_BALANCE_RESET                      (1 << 25)
4284#define PORT_DFT2_G4X           _MMIO(dev_priv->info.display_mmio_offset + 0x61154)
4285#define   DC_BALANCE_RESET_VLV                  (1 << 31)
4286#define   PIPE_SCRAMBLE_RESET_MASK              ((1 << 14) | (0x3 << 0))
4287#define   PIPE_C_SCRAMBLE_RESET                 (1 << 14) /* chv */
4288#define   PIPE_B_SCRAMBLE_RESET                 (1 << 1)
4289#define   PIPE_A_SCRAMBLE_RESET                 (1 << 0)
4290
4291/* Gen 3 SDVO bits: */
4292#define   SDVO_ENABLE                           (1 << 31)
4293#define   SDVO_PIPE_SEL(pipe)                   ((pipe) << 30)
4294#define   SDVO_PIPE_SEL_MASK                    (1 << 30)
4295#define   SDVO_PIPE_B_SELECT                    (1 << 30)
4296#define   SDVO_STALL_SELECT                     (1 << 29)
4297#define   SDVO_INTERRUPT_ENABLE                 (1 << 26)
4298/*
4299 * 915G/GM SDVO pixel multiplier.
4300 * Programmed value is multiplier - 1, up to 5x.
4301 * \sa DPLL_MD_UDI_MULTIPLIER_MASK
4302 */
4303#define   SDVO_PORT_MULTIPLY_MASK               (7 << 23)
4304#define   SDVO_PORT_MULTIPLY_SHIFT              23
4305#define   SDVO_PHASE_SELECT_MASK                (15 << 19)
4306#define   SDVO_PHASE_SELECT_DEFAULT             (6 << 19)
4307#define   SDVO_CLOCK_OUTPUT_INVERT              (1 << 18)
4308#define   SDVOC_GANG_MODE                       (1 << 16) /* Port C only */
4309#define   SDVO_BORDER_ENABLE                    (1 << 7) /* SDVO only */
4310#define   SDVOB_PCIE_CONCURRENCY                (1 << 3) /* Port B only */
4311#define   SDVO_DETECTED                         (1 << 2)
4312/* Bits to be preserved when writing */
4313#define   SDVOB_PRESERVE_MASK ((1 << 17) | (1 << 16) | (1 << 14) | \
4314                               SDVO_INTERRUPT_ENABLE)
4315#define   SDVOC_PRESERVE_MASK ((1 << 17) | SDVO_INTERRUPT_ENABLE)
4316
4317/* Gen 4 SDVO/HDMI bits: */
4318#define   SDVO_COLOR_FORMAT_8bpc                (0 << 26)
4319#define   SDVO_COLOR_FORMAT_MASK                (7 << 26)
4320#define   SDVO_ENCODING_SDVO                    (0 << 10)
4321#define   SDVO_ENCODING_HDMI                    (2 << 10)
4322#define   HDMI_MODE_SELECT_HDMI                 (1 << 9) /* HDMI only */
4323#define   HDMI_MODE_SELECT_DVI                  (0 << 9) /* HDMI only */
4324#define   HDMI_COLOR_RANGE_16_235               (1 << 8) /* HDMI only */
4325#define   SDVO_AUDIO_ENABLE                     (1 << 6)
4326/* VSYNC/HSYNC bits new with 965, default is to be set */
4327#define   SDVO_VSYNC_ACTIVE_HIGH                (1 << 4)
4328#define   SDVO_HSYNC_ACTIVE_HIGH                (1 << 3)
4329
4330/* Gen 5 (IBX) SDVO/HDMI bits: */
4331#define   HDMI_COLOR_FORMAT_12bpc               (3 << 26) /* HDMI only */
4332#define   SDVOB_HOTPLUG_ENABLE                  (1 << 23) /* SDVO only */
4333
4334/* Gen 6 (CPT) SDVO/HDMI bits: */
4335#define   SDVO_PIPE_SEL_CPT(pipe)               ((pipe) << 29)
4336#define   SDVO_PIPE_SEL_MASK_CPT                (3 << 29)
4337
4338/* CHV SDVO/HDMI bits: */
4339#define   SDVO_PIPE_SEL_CHV(pipe)               ((pipe) << 24)
4340#define   SDVO_PIPE_SEL_MASK_CHV                (3 << 24)
4341
4342
4343/* DVO port control */
4344#define _DVOA                   0x61120
4345#define DVOA                    _MMIO(_DVOA)
4346#define _DVOB                   0x61140
4347#define DVOB                    _MMIO(_DVOB)
4348#define _DVOC                   0x61160
4349#define DVOC                    _MMIO(_DVOC)
4350#define   DVO_ENABLE                    (1 << 31)
4351#define   DVO_PIPE_B_SELECT             (1 << 30)
4352#define   DVO_PIPE_STALL_UNUSED         (0 << 28)
4353#define   DVO_PIPE_STALL                (1 << 28)
4354#define   DVO_PIPE_STALL_TV             (2 << 28)
4355#define   DVO_PIPE_STALL_MASK           (3 << 28)
4356#define   DVO_USE_VGA_SYNC              (1 << 15)
4357#define   DVO_DATA_ORDER_I740           (0 << 14)
4358#define   DVO_DATA_ORDER_FP             (1 << 14)
4359#define   DVO_VSYNC_DISABLE             (1 << 11)
4360#define   DVO_HSYNC_DISABLE             (1 << 10)
4361#define   DVO_VSYNC_TRISTATE            (1 << 9)
4362#define   DVO_HSYNC_TRISTATE            (1 << 8)
4363#define   DVO_BORDER_ENABLE             (1 << 7)
4364#define   DVO_DATA_ORDER_GBRG           (1 << 6)
4365#define   DVO_DATA_ORDER_RGGB           (0 << 6)
4366#define   DVO_DATA_ORDER_GBRG_ERRATA    (0 << 6)
4367#define   DVO_DATA_ORDER_RGGB_ERRATA    (1 << 6)
4368#define   DVO_VSYNC_ACTIVE_HIGH         (1 << 4)
4369#define   DVO_HSYNC_ACTIVE_HIGH         (1 << 3)
4370#define   DVO_BLANK_ACTIVE_HIGH         (1 << 2)
4371#define   DVO_OUTPUT_CSTATE_PIXELS      (1 << 1)        /* SDG only */
4372#define   DVO_OUTPUT_SOURCE_SIZE_PIXELS (1 << 0)        /* SDG only */
4373#define   DVO_PRESERVE_MASK             (0x7<<24)
4374#define DVOA_SRCDIM             _MMIO(0x61124)
4375#define DVOB_SRCDIM             _MMIO(0x61144)
4376#define DVOC_SRCDIM             _MMIO(0x61164)
4377#define   DVO_SRCDIM_HORIZONTAL_SHIFT   12
4378#define   DVO_SRCDIM_VERTICAL_SHIFT     0
4379
4380/* LVDS port control */
4381#define LVDS                    _MMIO(0x61180)
4382/*
4383 * Enables the LVDS port.  This bit must be set before DPLLs are enabled, as
4384 * the DPLL semantics change when the LVDS is assigned to that pipe.
4385 */
4386#define   LVDS_PORT_EN                  (1 << 31)
4387/* Selects pipe B for LVDS data.  Must be set on pre-965. */
4388#define   LVDS_PIPEB_SELECT             (1 << 30)
4389#define   LVDS_PIPE_MASK                (1 << 30)
4390#define   LVDS_PIPE(pipe)               ((pipe) << 30)
4391/* LVDS dithering flag on 965/g4x platform */
4392#define   LVDS_ENABLE_DITHER            (1 << 25)
4393/* LVDS sync polarity flags. Set to invert (i.e. negative) */
4394#define   LVDS_VSYNC_POLARITY           (1 << 21)
4395#define   LVDS_HSYNC_POLARITY           (1 << 20)
4396
4397/* Enable border for unscaled (or aspect-scaled) display */
4398#define   LVDS_BORDER_ENABLE            (1 << 15)
4399/*
4400 * Enables the A0-A2 data pairs and CLKA, containing 18 bits of color data per
4401 * pixel.
4402 */
4403#define   LVDS_A0A2_CLKA_POWER_MASK     (3 << 8)
4404#define   LVDS_A0A2_CLKA_POWER_DOWN     (0 << 8)
4405#define   LVDS_A0A2_CLKA_POWER_UP       (3 << 8)
4406/*
4407 * Controls the A3 data pair, which contains the additional LSBs for 24 bit
4408 * mode.  Only enabled if LVDS_A0A2_CLKA_POWER_UP also indicates it should be
4409 * on.
4410 */
4411#define   LVDS_A3_POWER_MASK            (3 << 6)
4412#define   LVDS_A3_POWER_DOWN            (0 << 6)
4413#define   LVDS_A3_POWER_UP              (3 << 6)
4414/*
4415 * Controls the CLKB pair.  This should only be set when LVDS_B0B3_POWER_UP
4416 * is set.
4417 */
4418#define   LVDS_CLKB_POWER_MASK          (3 << 4)
4419#define   LVDS_CLKB_POWER_DOWN          (0 << 4)
4420#define   LVDS_CLKB_POWER_UP            (3 << 4)
4421/*
4422 * Controls the B0-B3 data pairs.  This must be set to match the DPLL p2
4423 * setting for whether we are in dual-channel mode.  The B3 pair will
4424 * additionally only be powered up when LVDS_A3_POWER_UP is set.
4425 */
4426#define   LVDS_B0B3_POWER_MASK          (3 << 2)
4427#define   LVDS_B0B3_POWER_DOWN          (0 << 2)
4428#define   LVDS_B0B3_POWER_UP            (3 << 2)
4429
4430/* Video Data Island Packet control */
4431#define VIDEO_DIP_DATA          _MMIO(0x61178)
4432/* Read the description of VIDEO_DIP_DATA (before Haswell) or VIDEO_DIP_ECC
4433 * (Haswell and newer) to see which VIDEO_DIP_DATA byte corresponds to each byte
4434 * of the infoframe structure specified by CEA-861. */
4435#define   VIDEO_DIP_DATA_SIZE   32
4436#define   VIDEO_DIP_VSC_DATA_SIZE       36
4437#define VIDEO_DIP_CTL           _MMIO(0x61170)
4438/* Pre HSW: */
4439#define   VIDEO_DIP_ENABLE              (1 << 31)
4440#define   VIDEO_DIP_PORT(port)          ((port) << 29)
4441#define   VIDEO_DIP_PORT_MASK           (3 << 29)
4442#define   VIDEO_DIP_ENABLE_GCP          (1 << 25)
4443#define   VIDEO_DIP_ENABLE_AVI          (1 << 21)
4444#define   VIDEO_DIP_ENABLE_VENDOR       (2 << 21)
4445#define   VIDEO_DIP_ENABLE_GAMUT        (4 << 21)
4446#define   VIDEO_DIP_ENABLE_SPD          (8 << 21)
4447#define   VIDEO_DIP_SELECT_AVI          (0 << 19)
4448#define   VIDEO_DIP_SELECT_VENDOR       (1 << 19)
4449#define   VIDEO_DIP_SELECT_SPD          (3 << 19)
4450#define   VIDEO_DIP_SELECT_MASK         (3 << 19)
4451#define   VIDEO_DIP_FREQ_ONCE           (0 << 16)
4452#define   VIDEO_DIP_FREQ_VSYNC          (1 << 16)
4453#define   VIDEO_DIP_FREQ_2VSYNC         (2 << 16)
4454#define   VIDEO_DIP_FREQ_MASK           (3 << 16)
4455/* HSW and later: */
4456#define   VIDEO_DIP_ENABLE_VSC_HSW      (1 << 20)
4457#define   VIDEO_DIP_ENABLE_GCP_HSW      (1 << 16)
4458#define   VIDEO_DIP_ENABLE_AVI_HSW      (1 << 12)
4459#define   VIDEO_DIP_ENABLE_VS_HSW       (1 << 8)
4460#define   VIDEO_DIP_ENABLE_GMP_HSW      (1 << 4)
4461#define   VIDEO_DIP_ENABLE_SPD_HSW      (1 << 0)
4462
4463/* Panel power sequencing */
4464#define PPS_BASE                        0x61200
4465#define VLV_PPS_BASE                    (VLV_DISPLAY_BASE + PPS_BASE)
4466#define PCH_PPS_BASE                    0xC7200
4467
4468#define _MMIO_PPS(pps_idx, reg)         _MMIO(dev_priv->pps_mmio_base - \
4469                                              PPS_BASE + (reg) +        \
4470                                              (pps_idx) * 0x100)
4471
4472#define _PP_STATUS                      0x61200
4473#define PP_STATUS(pps_idx)              _MMIO_PPS(pps_idx, _PP_STATUS)
4474#define   PP_ON                         (1 << 31)
4475/*
4476 * Indicates that all dependencies of the panel are on:
4477 *
4478 * - PLL enabled
4479 * - pipe enabled
4480 * - LVDS/DVOB/DVOC on
4481 */
4482#define   PP_READY                      (1 << 30)
4483#define   PP_SEQUENCE_NONE              (0 << 28)
4484#define   PP_SEQUENCE_POWER_UP          (1 << 28)
4485#define   PP_SEQUENCE_POWER_DOWN        (2 << 28)
4486#define   PP_SEQUENCE_MASK              (3 << 28)
4487#define   PP_SEQUENCE_SHIFT             28
4488#define   PP_CYCLE_DELAY_ACTIVE         (1 << 27)
4489#define   PP_SEQUENCE_STATE_MASK        0x0000000f
4490#define   PP_SEQUENCE_STATE_OFF_IDLE    (0x0 << 0)
4491#define   PP_SEQUENCE_STATE_OFF_S0_1    (0x1 << 0)
4492#define   PP_SEQUENCE_STATE_OFF_S0_2    (0x2 << 0)
4493#define   PP_SEQUENCE_STATE_OFF_S0_3    (0x3 << 0)
4494#define   PP_SEQUENCE_STATE_ON_IDLE     (0x8 << 0)
4495#define   PP_SEQUENCE_STATE_ON_S1_0     (0x9 << 0)
4496#define   PP_SEQUENCE_STATE_ON_S1_2     (0xa << 0)
4497#define   PP_SEQUENCE_STATE_ON_S1_3     (0xb << 0)
4498#define   PP_SEQUENCE_STATE_RESET       (0xf << 0)
4499
4500#define _PP_CONTROL                     0x61204
4501#define PP_CONTROL(pps_idx)             _MMIO_PPS(pps_idx, _PP_CONTROL)
4502#define  PANEL_UNLOCK_REGS              (0xabcd << 16)
4503#define  PANEL_UNLOCK_MASK              (0xffff << 16)
4504#define  BXT_POWER_CYCLE_DELAY_MASK     0x1f0
4505#define  BXT_POWER_CYCLE_DELAY_SHIFT    4
4506#define  EDP_FORCE_VDD                  (1 << 3)
4507#define  EDP_BLC_ENABLE                 (1 << 2)
4508#define  PANEL_POWER_RESET              (1 << 1)
4509#define  PANEL_POWER_OFF                (0 << 0)
4510#define  PANEL_POWER_ON                 (1 << 0)
4511
4512#define _PP_ON_DELAYS                   0x61208
4513#define PP_ON_DELAYS(pps_idx)           _MMIO_PPS(pps_idx, _PP_ON_DELAYS)
4514#define  PANEL_PORT_SELECT_SHIFT        30
4515#define  PANEL_PORT_SELECT_MASK         (3 << 30)
4516#define  PANEL_PORT_SELECT_LVDS         (0 << 30)
4517#define  PANEL_PORT_SELECT_DPA          (1 << 30)
4518#define  PANEL_PORT_SELECT_DPC          (2 << 30)
4519#define  PANEL_PORT_SELECT_DPD          (3 << 30)
4520#define  PANEL_PORT_SELECT_VLV(port)    ((port) << 30)
4521#define  PANEL_POWER_UP_DELAY_MASK      0x1fff0000
4522#define  PANEL_POWER_UP_DELAY_SHIFT     16
4523#define  PANEL_LIGHT_ON_DELAY_MASK      0x1fff
4524#define  PANEL_LIGHT_ON_DELAY_SHIFT     0
4525
4526#define _PP_OFF_DELAYS                  0x6120C
4527#define PP_OFF_DELAYS(pps_idx)          _MMIO_PPS(pps_idx, _PP_OFF_DELAYS)
4528#define  PANEL_POWER_DOWN_DELAY_MASK    0x1fff0000
4529#define  PANEL_POWER_DOWN_DELAY_SHIFT   16
4530#define  PANEL_LIGHT_OFF_DELAY_MASK     0x1fff
4531#define  PANEL_LIGHT_OFF_DELAY_SHIFT    0
4532
4533#define _PP_DIVISOR                     0x61210
4534#define PP_DIVISOR(pps_idx)             _MMIO_PPS(pps_idx, _PP_DIVISOR)
4535#define  PP_REFERENCE_DIVIDER_MASK      0xffffff00
4536#define  PP_REFERENCE_DIVIDER_SHIFT     8
4537#define  PANEL_POWER_CYCLE_DELAY_MASK   0x1f
4538#define  PANEL_POWER_CYCLE_DELAY_SHIFT  0
4539
4540/* Panel fitting */
4541#define PFIT_CONTROL    _MMIO(dev_priv->info.display_mmio_offset + 0x61230)
4542#define   PFIT_ENABLE           (1 << 31)
4543#define   PFIT_PIPE_MASK        (3 << 29)
4544#define   PFIT_PIPE_SHIFT       29
4545#define   VERT_INTERP_DISABLE   (0 << 10)
4546#define   VERT_INTERP_BILINEAR  (1 << 10)
4547#define   VERT_INTERP_MASK      (3 << 10)
4548#define   VERT_AUTO_SCALE       (1 << 9)
4549#define   HORIZ_INTERP_DISABLE  (0 << 6)
4550#define   HORIZ_INTERP_BILINEAR (1 << 6)
4551#define   HORIZ_INTERP_MASK     (3 << 6)
4552#define   HORIZ_AUTO_SCALE      (1 << 5)
4553#define   PANEL_8TO6_DITHER_ENABLE (1 << 3)
4554#define   PFIT_FILTER_FUZZY     (0 << 24)
4555#define   PFIT_SCALING_AUTO     (0 << 26)
4556#define   PFIT_SCALING_PROGRAMMED (1 << 26)
4557#define   PFIT_SCALING_PILLAR   (2 << 26)
4558#define   PFIT_SCALING_LETTER   (3 << 26)
4559#define PFIT_PGM_RATIOS _MMIO(dev_priv->info.display_mmio_offset + 0x61234)
4560/* Pre-965 */
4561#define         PFIT_VERT_SCALE_SHIFT           20
4562#define         PFIT_VERT_SCALE_MASK            0xfff00000
4563#define         PFIT_HORIZ_SCALE_SHIFT          4
4564#define         PFIT_HORIZ_SCALE_MASK           0x0000fff0
4565/* 965+ */
4566#define         PFIT_VERT_SCALE_SHIFT_965       16
4567#define         PFIT_VERT_SCALE_MASK_965        0x1fff0000
4568#define         PFIT_HORIZ_SCALE_SHIFT_965      0
4569#define         PFIT_HORIZ_SCALE_MASK_965       0x00001fff
4570
4571#define PFIT_AUTO_RATIOS _MMIO(dev_priv->info.display_mmio_offset + 0x61238)
4572
4573#define _VLV_BLC_PWM_CTL2_A (dev_priv->info.display_mmio_offset + 0x61250)
4574#define _VLV_BLC_PWM_CTL2_B (dev_priv->info.display_mmio_offset + 0x61350)
4575#define VLV_BLC_PWM_CTL2(pipe) _MMIO_PIPE(pipe, _VLV_BLC_PWM_CTL2_A, \
4576                                         _VLV_BLC_PWM_CTL2_B)
4577
4578#define _VLV_BLC_PWM_CTL_A (dev_priv->info.display_mmio_offset + 0x61254)
4579#define _VLV_BLC_PWM_CTL_B (dev_priv->info.display_mmio_offset + 0x61354)
4580#define VLV_BLC_PWM_CTL(pipe) _MMIO_PIPE(pipe, _VLV_BLC_PWM_CTL_A, \
4581                                        _VLV_BLC_PWM_CTL_B)
4582
4583#define _VLV_BLC_HIST_CTL_A (dev_priv->info.display_mmio_offset + 0x61260)
4584#define _VLV_BLC_HIST_CTL_B (dev_priv->info.display_mmio_offset + 0x61360)
4585#define VLV_BLC_HIST_CTL(pipe) _MMIO_PIPE(pipe, _VLV_BLC_HIST_CTL_A, \
4586                                         _VLV_BLC_HIST_CTL_B)
4587
4588/* Backlight control */
4589#define BLC_PWM_CTL2    _MMIO(dev_priv->info.display_mmio_offset + 0x61250) /* 965+ only */
4590#define   BLM_PWM_ENABLE                (1 << 31)
4591#define   BLM_COMBINATION_MODE          (1 << 30) /* gen4 only */
4592#define   BLM_PIPE_SELECT               (1 << 29)
4593#define   BLM_PIPE_SELECT_IVB           (3 << 29)
4594#define   BLM_PIPE_A                    (0 << 29)
4595#define   BLM_PIPE_B                    (1 << 29)
4596#define   BLM_PIPE_C                    (2 << 29) /* ivb + */
4597#define   BLM_TRANSCODER_A              BLM_PIPE_A /* hsw */
4598#define   BLM_TRANSCODER_B              BLM_PIPE_B
4599#define   BLM_TRANSCODER_C              BLM_PIPE_C
4600#define   BLM_TRANSCODER_EDP            (3 << 29)
4601#define   BLM_PIPE(pipe)                ((pipe) << 29)
4602#define   BLM_POLARITY_I965             (1 << 28) /* gen4 only */
4603#define   BLM_PHASE_IN_INTERUPT_STATUS  (1 << 26)
4604#define   BLM_PHASE_IN_ENABLE           (1 << 25)
4605#define   BLM_PHASE_IN_INTERUPT_ENABL   (1 << 24)
4606#define   BLM_PHASE_IN_TIME_BASE_SHIFT  (16)
4607#define   BLM_PHASE_IN_TIME_BASE_MASK   (0xff << 16)
4608#define   BLM_PHASE_IN_COUNT_SHIFT      (8)
4609#define   BLM_PHASE_IN_COUNT_MASK       (0xff << 8)
4610#define   BLM_PHASE_IN_INCR_SHIFT       (0)
4611#define   BLM_PHASE_IN_INCR_MASK        (0xff << 0)
4612#define BLC_PWM_CTL     _MMIO(dev_priv->info.display_mmio_offset + 0x61254)
4613/*
4614 * This is the most significant 15 bits of the number of backlight cycles in a
4615 * complete cycle of the modulated backlight control.
4616 *
4617 * The actual value is this field multiplied by two.
4618 */
4619#define   BACKLIGHT_MODULATION_FREQ_SHIFT       (17)
4620#define   BACKLIGHT_MODULATION_FREQ_MASK        (0x7fff << 17)
4621#define   BLM_LEGACY_MODE                       (1 << 16) /* gen2 only */
4622/*
4623 * This is the number of cycles out of the backlight modulation cycle for which
4624 * the backlight is on.
4625 *
4626 * This field must be no greater than the number of cycles in the complete
4627 * backlight modulation cycle.
4628 */
4629#define   BACKLIGHT_DUTY_CYCLE_SHIFT            (0)
4630#define   BACKLIGHT_DUTY_CYCLE_MASK             (0xffff)
4631#define   BACKLIGHT_DUTY_CYCLE_MASK_PNV         (0xfffe)
4632#define   BLM_POLARITY_PNV                      (1 << 0) /* pnv only */
4633
4634#define BLC_HIST_CTL    _MMIO(dev_priv->info.display_mmio_offset + 0x61260)
4635#define  BLM_HISTOGRAM_ENABLE                   (1 << 31)
4636
4637/* New registers for PCH-split platforms. Safe where new bits show up, the
4638 * register layout machtes with gen4 BLC_PWM_CTL[12]. */
4639#define BLC_PWM_CPU_CTL2        _MMIO(0x48250)
4640#define BLC_PWM_CPU_CTL         _MMIO(0x48254)
4641
4642#define HSW_BLC_PWM2_CTL        _MMIO(0x48350)
4643
4644/* PCH CTL1 is totally different, all but the below bits are reserved. CTL2 is
4645 * like the normal CTL from gen4 and earlier. Hooray for confusing naming. */
4646#define BLC_PWM_PCH_CTL1        _MMIO(0xc8250)
4647#define   BLM_PCH_PWM_ENABLE                    (1 << 31)
4648#define   BLM_PCH_OVERRIDE_ENABLE               (1 << 30)
4649#define   BLM_PCH_POLARITY                      (1 << 29)
4650#define BLC_PWM_PCH_CTL2        _MMIO(0xc8254)
4651
4652#define UTIL_PIN_CTL            _MMIO(0x48400)
4653#define   UTIL_PIN_ENABLE       (1 << 31)
4654
4655#define   UTIL_PIN_PIPE(x)     ((x) << 29)
4656#define   UTIL_PIN_PIPE_MASK   (3 << 29)
4657#define   UTIL_PIN_MODE_PWM    (1 << 24)
4658#define   UTIL_PIN_MODE_MASK   (0xf << 24)
4659#define   UTIL_PIN_POLARITY    (1 << 22)
4660
4661/* BXT backlight register definition. */
4662#define _BXT_BLC_PWM_CTL1                       0xC8250
4663#define   BXT_BLC_PWM_ENABLE                    (1 << 31)
4664#define   BXT_BLC_PWM_POLARITY                  (1 << 29)
4665#define _BXT_BLC_PWM_FREQ1                      0xC8254
4666#define _BXT_BLC_PWM_DUTY1                      0xC8258
4667
4668#define _BXT_BLC_PWM_CTL2                       0xC8350
4669#define _BXT_BLC_PWM_FREQ2                      0xC8354
4670#define _BXT_BLC_PWM_DUTY2                      0xC8358
4671
4672#define BXT_BLC_PWM_CTL(controller)    _MMIO_PIPE(controller,           \
4673                                        _BXT_BLC_PWM_CTL1, _BXT_BLC_PWM_CTL2)
4674#define BXT_BLC_PWM_FREQ(controller)   _MMIO_PIPE(controller, \
4675                                        _BXT_BLC_PWM_FREQ1, _BXT_BLC_PWM_FREQ2)
4676#define BXT_BLC_PWM_DUTY(controller)   _MMIO_PIPE(controller, \
4677                                        _BXT_BLC_PWM_DUTY1, _BXT_BLC_PWM_DUTY2)
4678
4679#define PCH_GTC_CTL             _MMIO(0xe7000)
4680#define   PCH_GTC_ENABLE        (1 << 31)
4681
4682/* TV port control */
4683#define TV_CTL                  _MMIO(0x68000)
4684/* Enables the TV encoder */
4685# define TV_ENC_ENABLE                  (1 << 31)
4686/* Sources the TV encoder input from pipe B instead of A. */
4687# define TV_ENC_PIPEB_SELECT            (1 << 30)
4688/* Outputs composite video (DAC A only) */
4689# define TV_ENC_OUTPUT_COMPOSITE        (0 << 28)
4690/* Outputs SVideo video (DAC B/C) */
4691# define TV_ENC_OUTPUT_SVIDEO           (1 << 28)
4692/* Outputs Component video (DAC A/B/C) */
4693# define TV_ENC_OUTPUT_COMPONENT        (2 << 28)
4694/* Outputs Composite and SVideo (DAC A/B/C) */
4695# define TV_ENC_OUTPUT_SVIDEO_COMPOSITE (3 << 28)
4696# define TV_TRILEVEL_SYNC               (1 << 21)
4697/* Enables slow sync generation (945GM only) */
4698# define TV_SLOW_SYNC                   (1 << 20)
4699/* Selects 4x oversampling for 480i and 576p */
4700# define TV_OVERSAMPLE_4X               (0 << 18)
4701/* Selects 2x oversampling for 720p and 1080i */
4702# define TV_OVERSAMPLE_2X               (1 << 18)
4703/* Selects no oversampling for 1080p */
4704# define TV_OVERSAMPLE_NONE             (2 << 18)
4705/* Selects 8x oversampling */
4706# define TV_OVERSAMPLE_8X               (3 << 18)
4707/* Selects progressive mode rather than interlaced */
4708# define TV_PROGRESSIVE                 (1 << 17)
4709/* Sets the colorburst to PAL mode.  Required for non-M PAL modes. */
4710# define TV_PAL_BURST                   (1 << 16)
4711/* Field for setting delay of Y compared to C */
4712# define TV_YC_SKEW_MASK                (7 << 12)
4713/* Enables a fix for 480p/576p standard definition modes on the 915GM only */
4714# define TV_ENC_SDP_FIX                 (1 << 11)
4715/*
4716 * Enables a fix for the 915GM only.
4717 *
4718 * Not sure what it does.
4719 */
4720# define TV_ENC_C0_FIX                  (1 << 10)
4721/* Bits that must be preserved by software */
4722# define TV_CTL_SAVE                    ((1 << 11) | (3 << 9) | (7 << 6) | 0xf)
4723# define TV_FUSE_STATE_MASK             (3 << 4)
4724/* Read-only state that reports all features enabled */
4725# define TV_FUSE_STATE_ENABLED          (0 << 4)
4726/* Read-only state that reports that Macrovision is disabled in hardware*/
4727# define TV_FUSE_STATE_NO_MACROVISION   (1 << 4)
4728/* Read-only state that reports that TV-out is disabled in hardware. */
4729# define TV_FUSE_STATE_DISABLED         (2 << 4)
4730/* Normal operation */
4731# define TV_TEST_MODE_NORMAL            (0 << 0)
4732/* Encoder test pattern 1 - combo pattern */
4733# define TV_TEST_MODE_PATTERN_1         (1 << 0)
4734/* Encoder test pattern 2 - full screen vertical 75% color bars */
4735# define TV_TEST_MODE_PATTERN_2         (2 << 0)
4736/* Encoder test pattern 3 - full screen horizontal 75% color bars */
4737# define TV_TEST_MODE_PATTERN_3         (3 << 0)
4738/* Encoder test pattern 4 - random noise */
4739# define TV_TEST_MODE_PATTERN_4         (4 << 0)
4740/* Encoder test pattern 5 - linear color ramps */
4741# define TV_TEST_MODE_PATTERN_5         (5 << 0)
4742/*
4743 * This test mode forces the DACs to 50% of full output.
4744 *
4745 * This is used for load detection in combination with TVDAC_SENSE_MASK
4746 */
4747# define TV_TEST_MODE_MONITOR_DETECT    (7 << 0)
4748# define TV_TEST_MODE_MASK              (7 << 0)
4749
4750#define TV_DAC                  _MMIO(0x68004)
4751# define TV_DAC_SAVE            0x00ffff00
4752/*
4753 * Reports that DAC state change logic has reported change (RO).
4754 *
4755 * This gets cleared when TV_DAC_STATE_EN is cleared
4756*/
4757# define TVDAC_STATE_CHG                (1 << 31)
4758# define TVDAC_SENSE_MASK               (7 << 28)
4759/* Reports that DAC A voltage is above the detect threshold */
4760# define TVDAC_A_SENSE                  (1 << 30)
4761/* Reports that DAC B voltage is above the detect threshold */
4762# define TVDAC_B_SENSE                  (1 << 29)
4763/* Reports that DAC C voltage is above the detect threshold */
4764# define TVDAC_C_SENSE                  (1 << 28)
4765/*
4766 * Enables DAC state detection logic, for load-based TV detection.
4767 *
4768 * The PLL of the chosen pipe (in TV_CTL) must be running, and the encoder set
4769 * to off, for load detection to work.
4770 */
4771# define TVDAC_STATE_CHG_EN             (1 << 27)
4772/* Sets the DAC A sense value to high */
4773# define TVDAC_A_SENSE_CTL              (1 << 26)
4774/* Sets the DAC B sense value to high */
4775# define TVDAC_B_SENSE_CTL              (1 << 25)
4776/* Sets the DAC C sense value to high */
4777# define TVDAC_C_SENSE_CTL              (1 << 24)
4778/* Overrides the ENC_ENABLE and DAC voltage levels */
4779# define DAC_CTL_OVERRIDE               (1 << 7)
4780/* Sets the slew rate.  Must be preserved in software */
4781# define ENC_TVDAC_SLEW_FAST            (1 << 6)
4782# define DAC_A_1_3_V                    (0 << 4)
4783# define DAC_A_1_1_V                    (1 << 4)
4784# define DAC_A_0_7_V                    (2 << 4)
4785# define DAC_A_MASK                     (3 << 4)
4786# define DAC_B_1_3_V                    (0 << 2)
4787# define DAC_B_1_1_V                    (1 << 2)
4788# define DAC_B_0_7_V                    (2 << 2)
4789# define DAC_B_MASK                     (3 << 2)
4790# define DAC_C_1_3_V                    (0 << 0)
4791# define DAC_C_1_1_V                    (1 << 0)
4792# define DAC_C_0_7_V                    (2 << 0)
4793# define DAC_C_MASK                     (3 << 0)
4794
4795/*
4796 * CSC coefficients are stored in a floating point format with 9 bits of
4797 * mantissa and 2 or 3 bits of exponent.  The exponent is represented as 2**-n,
4798 * where 2-bit exponents are unsigned n, and 3-bit exponents are signed n with
4799 * -1 (0x3) being the only legal negative value.
4800 */
4801#define TV_CSC_Y                _MMIO(0x68010)
4802# define TV_RY_MASK                     0x07ff0000
4803# define TV_RY_SHIFT                    16
4804# define TV_GY_MASK                     0x00000fff
4805# define TV_GY_SHIFT                    0
4806
4807#define TV_CSC_Y2               _MMIO(0x68014)
4808# define TV_BY_MASK                     0x07ff0000
4809# define TV_BY_SHIFT                    16
4810/*
4811 * Y attenuation for component video.
4812 *
4813 * Stored in 1.9 fixed point.
4814 */
4815# define TV_AY_MASK                     0x000003ff
4816# define TV_AY_SHIFT                    0
4817
4818#define TV_CSC_U                _MMIO(0x68018)
4819# define TV_RU_MASK                     0x07ff0000
4820# define TV_RU_SHIFT                    16
4821# define TV_GU_MASK                     0x000007ff
4822# define TV_GU_SHIFT                    0
4823
4824#define TV_CSC_U2               _MMIO(0x6801c)
4825# define TV_BU_MASK                     0x07ff0000
4826# define TV_BU_SHIFT                    16
4827/*
4828 * U attenuation for component video.
4829 *
4830 * Stored in 1.9 fixed point.
4831 */
4832# define TV_AU_MASK                     0x000003ff
4833# define TV_AU_SHIFT                    0
4834
4835#define TV_CSC_V                _MMIO(0x68020)
4836# define TV_RV_MASK                     0x0fff0000
4837# define TV_RV_SHIFT                    16
4838# define TV_GV_MASK                     0x000007ff
4839# define TV_GV_SHIFT                    0
4840
4841#define TV_CSC_V2               _MMIO(0x68024)
4842# define TV_BV_MASK                     0x07ff0000
4843# define TV_BV_SHIFT                    16
4844/*
4845 * V attenuation for component video.
4846 *
4847 * Stored in 1.9 fixed point.
4848 */
4849# define TV_AV_MASK                     0x000007ff
4850# define TV_AV_SHIFT                    0
4851
4852#define TV_CLR_KNOBS            _MMIO(0x68028)
4853/* 2s-complement brightness adjustment */
4854# define TV_BRIGHTNESS_MASK             0xff000000
4855# define TV_BRIGHTNESS_SHIFT            24
4856/* Contrast adjustment, as a 2.6 unsigned floating point number */
4857# define TV_CONTRAST_MASK               0x00ff0000
4858# define TV_CONTRAST_SHIFT              16
4859/* Saturation adjustment, as a 2.6 unsigned floating point number */
4860# define TV_SATURATION_MASK             0x0000ff00
4861# define TV_SATURATION_SHIFT            8
4862/* Hue adjustment, as an integer phase angle in degrees */
4863# define TV_HUE_MASK                    0x000000ff
4864# define TV_HUE_SHIFT                   0
4865
4866#define TV_CLR_LEVEL            _MMIO(0x6802c)
4867/* Controls the DAC level for black */
4868# define TV_BLACK_LEVEL_MASK            0x01ff0000
4869# define TV_BLACK_LEVEL_SHIFT           16
4870/* Controls the DAC level for blanking */
4871# define TV_BLANK_LEVEL_MASK            0x000001ff
4872# define TV_BLANK_LEVEL_SHIFT           0
4873
4874#define TV_H_CTL_1              _MMIO(0x68030)
4875/* Number of pixels in the hsync. */
4876# define TV_HSYNC_END_MASK              0x1fff0000
4877# define TV_HSYNC_END_SHIFT             16
4878/* Total number of pixels minus one in the line (display and blanking). */
4879# define TV_HTOTAL_MASK                 0x00001fff
4880# define TV_HTOTAL_SHIFT                0
4881
4882#define TV_H_CTL_2              _MMIO(0x68034)
4883/* Enables the colorburst (needed for non-component color) */
4884# define TV_BURST_ENA                   (1 << 31)
4885/* Offset of the colorburst from the start of hsync, in pixels minus one. */
4886# define TV_HBURST_START_SHIFT          16
4887# define TV_HBURST_START_MASK           0x1fff0000
4888/* Length of the colorburst */
4889# define TV_HBURST_LEN_SHIFT            0
4890# define TV_HBURST_LEN_MASK             0x0001fff
4891
4892#define TV_H_CTL_3              _MMIO(0x68038)
4893/* End of hblank, measured in pixels minus one from start of hsync */
4894# define TV_HBLANK_END_SHIFT            16
4895# define TV_HBLANK_END_MASK             0x1fff0000
4896/* Start of hblank, measured in pixels minus one from start of hsync */
4897# define TV_HBLANK_START_SHIFT          0
4898# define TV_HBLANK_START_MASK           0x0001fff
4899
4900#define TV_V_CTL_1              _MMIO(0x6803c)
4901/* XXX */
4902# define TV_NBR_END_SHIFT               16
4903# define TV_NBR_END_MASK                0x07ff0000
4904/* XXX */
4905# define TV_VI_END_F1_SHIFT             8
4906# define TV_VI_END_F1_MASK              0x00003f00
4907/* XXX */
4908# define TV_VI_END_F2_SHIFT             0
4909# define TV_VI_END_F2_MASK              0x0000003f
4910
4911#define TV_V_CTL_2              _MMIO(0x68040)
4912/* Length of vsync, in half lines */
4913# define TV_VSYNC_LEN_MASK              0x07ff0000
4914# define TV_VSYNC_LEN_SHIFT             16
4915/* Offset of the start of vsync in field 1, measured in one less than the
4916 * number of half lines.
4917 */
4918# define TV_VSYNC_START_F1_MASK         0x00007f00
4919# define TV_VSYNC_START_F1_SHIFT        8
4920/*
4921 * Offset of the start of vsync in field 2, measured in one less than the
4922 * number of half lines.
4923 */
4924# define TV_VSYNC_START_F2_MASK         0x0000007f
4925# define TV_VSYNC_START_F2_SHIFT        0
4926
4927#define TV_V_CTL_3              _MMIO(0x68044)
4928/* Enables generation of the equalization signal */
4929# define TV_EQUAL_ENA                   (1 << 31)
4930/* Length of vsync, in half lines */
4931# define TV_VEQ_LEN_MASK                0x007f0000
4932# define TV_VEQ_LEN_SHIFT               16
4933/* Offset of the start of equalization in field 1, measured in one less than
4934 * the number of half lines.
4935 */
4936# define TV_VEQ_START_F1_MASK           0x0007f00
4937# define TV_VEQ_START_F1_SHIFT          8
4938/*
4939 * Offset of the start of equalization in field 2, measured in one less than
4940 * the number of half lines.
4941 */
4942# define TV_VEQ_START_F2_MASK           0x000007f
4943# define TV_VEQ_START_F2_SHIFT          0
4944
4945#define TV_V_CTL_4              _MMIO(0x68048)
4946/*
4947 * Offset to start of vertical colorburst, measured in one less than the
4948 * number of lines from vertical start.
4949 */
4950# define TV_VBURST_START_F1_MASK        0x003f0000
4951# define TV_VBURST_START_F1_SHIFT       16
4952/*
4953 * Offset to the end of vertical colorburst, measured in one less than the
4954 * number of lines from the start of NBR.
4955 */
4956# define TV_VBURST_END_F1_MASK          0x000000ff
4957# define TV_VBURST_END_F1_SHIFT         0
4958
4959#define TV_V_CTL_5              _MMIO(0x6804c)
4960/*
4961 * Offset to start of vertical colorburst, measured in one less than the
4962 * number of lines from vertical start.
4963 */
4964# define TV_VBURST_START_F2_MASK        0x003f0000
4965# define TV_VBURST_START_F2_SHIFT       16
4966/*
4967 * Offset to the end of vertical colorburst, measured in one less than the
4968 * number of lines from the start of NBR.
4969 */
4970# define TV_VBURST_END_F2_MASK          0x000000ff
4971# define TV_VBURST_END_F2_SHIFT         0
4972
4973#define TV_V_CTL_6              _MMIO(0x68050)
4974/*
4975 * Offset to start of vertical colorburst, measured in one less than the
4976 * number of lines from vertical start.
4977 */
4978# define TV_VBURST_START_F3_MASK        0x003f0000
4979# define TV_VBURST_START_F3_SHIFT       16
4980/*
4981 * Offset to the end of vertical colorburst, measured in one less than the
4982 * number of lines from the start of NBR.
4983 */
4984# define TV_VBURST_END_F3_MASK          0x000000ff
4985# define TV_VBURST_END_F3_SHIFT         0
4986
4987#define TV_V_CTL_7              _MMIO(0x68054)
4988/*
4989 * Offset to start of vertical colorburst, measured in one less than the
4990 * number of lines from vertical start.
4991 */
4992# define TV_VBURST_START_F4_MASK        0x003f0000
4993# define TV_VBURST_START_F4_SHIFT       16
4994/*
4995 * Offset to the end of vertical colorburst, measured in one less than the
4996 * number of lines from the start of NBR.
4997 */
4998# define TV_VBURST_END_F4_MASK          0x000000ff
4999# define TV_VBURST_END_F4_SHIFT         0
5000
5001#define TV_SC_CTL_1             _MMIO(0x68060)
5002/* Turns on the first subcarrier phase generation DDA */
5003# define TV_SC_DDA1_EN                  (1 << 31)
5004/* Turns on the first subcarrier phase generation DDA */
5005# define TV_SC_DDA2_EN                  (1 << 30)
5006/* Turns on the first subcarrier phase generation DDA */
5007# define TV_SC_DDA3_EN                  (1 << 29)
5008/* Sets the subcarrier DDA to reset frequency every other field */
5009# define TV_SC_RESET_EVERY_2            (0 << 24)
5010/* Sets the subcarrier DDA to reset frequency every fourth field */
5011# define TV_SC_RESET_EVERY_4            (1 << 24)
5012/* Sets the subcarrier DDA to reset frequency every eighth field */
5013# define TV_SC_RESET_EVERY_8            (2 << 24)
5014/* Sets the subcarrier DDA to never reset the frequency */
5015# define TV_SC_RESET_NEVER              (3 << 24)
5016/* Sets the peak amplitude of the colorburst.*/
5017# define TV_BURST_LEVEL_MASK            0x00ff0000
5018# define TV_BURST_LEVEL_SHIFT           16
5019/* Sets the increment of the first subcarrier phase generation DDA */
5020# define TV_SCDDA1_INC_MASK             0x00000fff
5021# define TV_SCDDA1_INC_SHIFT            0
5022
5023#define TV_SC_CTL_2             _MMIO(0x68064)
5024/* Sets the rollover for the second subcarrier phase generation DDA */
5025# define TV_SCDDA2_SIZE_MASK            0x7fff0000
5026# define TV_SCDDA2_SIZE_SHIFT           16
5027/* Sets the increent of the second subcarrier phase generation DDA */
5028# define TV_SCDDA2_INC_MASK             0x00007fff
5029# define TV_SCDDA2_INC_SHIFT            0
5030
5031#define TV_SC_CTL_3             _MMIO(0x68068)
5032/* Sets the rollover for the third subcarrier phase generation DDA */
5033# define TV_SCDDA3_SIZE_MASK            0x7fff0000
5034# define TV_SCDDA3_SIZE_SHIFT           16
5035/* Sets the increent of the third subcarrier phase generation DDA */
5036# define TV_SCDDA3_INC_MASK             0x00007fff
5037# define TV_SCDDA3_INC_SHIFT            0
5038
5039#define TV_WIN_POS              _MMIO(0x68070)
5040/* X coordinate of the display from the start of horizontal active */
5041# define TV_XPOS_MASK                   0x1fff0000
5042# define TV_XPOS_SHIFT                  16
5043/* Y coordinate of the display from the start of vertical active (NBR) */
5044# define TV_YPOS_MASK                   0x00000fff
5045# define TV_YPOS_SHIFT                  0
5046
5047#define TV_WIN_SIZE             _MMIO(0x68074)
5048/* Horizontal size of the display window, measured in pixels*/
5049# define TV_XSIZE_MASK                  0x1fff0000
5050# define TV_XSIZE_SHIFT                 16
5051/*
5052 * Vertical size of the display window, measured in pixels.
5053 *
5054 * Must be even for interlaced modes.
5055 */
5056# define TV_YSIZE_MASK                  0x00000fff
5057# define TV_YSIZE_SHIFT                 0
5058
5059#define TV_FILTER_CTL_1         _MMIO(0x68080)
5060/*
5061 * Enables automatic scaling calculation.
5062 *
5063 * If set, the rest of the registers are ignored, and the calculated values can
5064 * be read back from the register.
5065 */
5066# define TV_AUTO_SCALE                  (1 << 31)
5067/*
5068 * Disables the vertical filter.
5069 *
5070 * This is required on modes more than 1024 pixels wide */
5071# define TV_V_FILTER_BYPASS             (1 << 29)
5072/* Enables adaptive vertical filtering */
5073# define TV_VADAPT                      (1 << 28)
5074# define TV_VADAPT_MODE_MASK            (3 << 26)
5075/* Selects the least adaptive vertical filtering mode */
5076# define TV_VADAPT_MODE_LEAST           (0 << 26)
5077/* Selects the moderately adaptive vertical filtering mode */
5078# define TV_VADAPT_MODE_MODERATE        (1 << 26)
5079/* Selects the most adaptive vertical filtering mode */
5080# define TV_VADAPT_MODE_MOST            (3 << 26)
5081/*
5082 * Sets the horizontal scaling factor.
5083 *
5084 * This should be the fractional part of the horizontal scaling factor divided
5085 * by the oversampling rate.  TV_HSCALE should be less than 1, and set to:
5086 *
5087 * (src width - 1) / ((oversample * dest width) - 1)
5088 */
5089# define TV_HSCALE_FRAC_MASK            0x00003fff
5090# define TV_HSCALE_FRAC_SHIFT           0
5091
5092#define TV_FILTER_CTL_2         _MMIO(0x68084)
5093/*
5094 * Sets the integer part of the 3.15 fixed-point vertical scaling factor.
5095 *
5096 * TV_VSCALE should be (src height - 1) / ((interlace * dest height) - 1)
5097 */
5098# define TV_VSCALE_INT_MASK             0x00038000
5099# define TV_VSCALE_INT_SHIFT            15
5100/*
5101 * Sets the fractional part of the 3.15 fixed-point vertical scaling factor.
5102 *
5103 * \sa TV_VSCALE_INT_MASK
5104 */
5105# define TV_VSCALE_FRAC_MASK            0x00007fff
5106# define TV_VSCALE_FRAC_SHIFT           0
5107
5108#define TV_FILTER_CTL_3         _MMIO(0x68088)
5109/*
5110 * Sets the integer part of the 3.15 fixed-point vertical scaling factor.
5111 *
5112 * TV_VSCALE should be (src height - 1) / (1/4 * (dest height - 1))
5113 *
5114 * For progressive modes, TV_VSCALE_IP_INT should be set to zeroes.
5115 */
5116# define TV_VSCALE_IP_INT_MASK          0x00038000
5117# define TV_VSCALE_IP_INT_SHIFT         15
5118/*
5119 * Sets the fractional part of the 3.15 fixed-point vertical scaling factor.
5120 *
5121 * For progressive modes, TV_VSCALE_IP_INT should be set to zeroes.
5122 *
5123 * \sa TV_VSCALE_IP_INT_MASK
5124 */
5125# define TV_VSCALE_IP_FRAC_MASK         0x00007fff
5126# define TV_VSCALE_IP_FRAC_SHIFT                0
5127
5128#define TV_CC_CONTROL           _MMIO(0x68090)
5129# define TV_CC_ENABLE                   (1 << 31)
5130/*
5131 * Specifies which field to send the CC data in.
5132 *
5133 * CC data is usually sent in field 0.
5134 */
5135# define TV_CC_FID_MASK                 (1 << 27)
5136# define TV_CC_FID_SHIFT                27
5137/* Sets the horizontal position of the CC data.  Usually 135. */
5138# define TV_CC_HOFF_MASK                0x03ff0000
5139# define TV_CC_HOFF_SHIFT               16
5140/* Sets the vertical position of the CC data.  Usually 21 */
5141# define TV_CC_LINE_MASK                0x0000003f
5142# define TV_CC_LINE_SHIFT               0
5143
5144#define TV_CC_DATA              _MMIO(0x68094)
5145# define TV_CC_RDY                      (1 << 31)
5146/* Second word of CC data to be transmitted. */
5147# define TV_CC_DATA_2_MASK              0x007f0000
5148# define TV_CC_DATA_2_SHIFT             16
5149/* First word of CC data to be transmitted. */
5150# define TV_CC_DATA_1_MASK              0x0000007f
5151# define TV_CC_DATA_1_SHIFT             0
5152
5153#define TV_H_LUMA(i)            _MMIO(0x68100 + (i) * 4) /* 60 registers */
5154#define TV_H_CHROMA(i)          _MMIO(0x68200 + (i) * 4) /* 60 registers */
5155#define TV_V_LUMA(i)            _MMIO(0x68300 + (i) * 4) /* 43 registers */
5156#define TV_V_CHROMA(i)          _MMIO(0x68400 + (i) * 4) /* 43 registers */
5157
5158/* Display Port */
5159#define DP_A                    _MMIO(0x64000) /* eDP */
5160#define DP_B                    _MMIO(0x64100)
5161#define DP_C                    _MMIO(0x64200)
5162#define DP_D                    _MMIO(0x64300)
5163
5164#define VLV_DP_B                _MMIO(VLV_DISPLAY_BASE + 0x64100)
5165#define VLV_DP_C                _MMIO(VLV_DISPLAY_BASE + 0x64200)
5166#define CHV_DP_D                _MMIO(VLV_DISPLAY_BASE + 0x64300)
5167
5168#define   DP_PORT_EN                    (1 << 31)
5169#define   DP_PIPEB_SELECT               (1 << 30)
5170#define   DP_PIPE_MASK                  (1 << 30)
5171#define   DP_PIPE_SELECT_CHV(pipe)      ((pipe) << 16)
5172#define   DP_PIPE_MASK_CHV              (3 << 16)
5173
5174/* Link training mode - select a suitable mode for each stage */
5175#define   DP_LINK_TRAIN_PAT_1           (0 << 28)
5176#define   DP_LINK_TRAIN_PAT_2           (1 << 28)
5177#define   DP_LINK_TRAIN_PAT_IDLE        (2 << 28)
5178#define   DP_LINK_TRAIN_OFF             (3 << 28)
5179#define   DP_LINK_TRAIN_MASK            (3 << 28)
5180#define   DP_LINK_TRAIN_SHIFT           28
5181#define   DP_LINK_TRAIN_PAT_3_CHV       (1 << 14)
5182#define   DP_LINK_TRAIN_MASK_CHV        ((3 << 28)|(1<<14))
5183
5184/* CPT Link training mode */
5185#define   DP_LINK_TRAIN_PAT_1_CPT       (0 << 8)
5186#define   DP_LINK_TRAIN_PAT_2_CPT       (1 << 8)
5187#define   DP_LINK_TRAIN_PAT_IDLE_CPT    (2 << 8)
5188#define   DP_LINK_TRAIN_OFF_CPT         (3 << 8)
5189#define   DP_LINK_TRAIN_MASK_CPT        (7 << 8)
5190#define   DP_LINK_TRAIN_SHIFT_CPT       8
5191
5192/* Signal voltages. These are mostly controlled by the other end */
5193#define   DP_VOLTAGE_0_4                (0 << 25)
5194#define   DP_VOLTAGE_0_6                (1 << 25)
5195#define   DP_VOLTAGE_0_8                (2 << 25)
5196#define   DP_VOLTAGE_1_2                (3 << 25)
5197#define   DP_VOLTAGE_MASK               (7 << 25)
5198#define   DP_VOLTAGE_SHIFT              25
5199
5200/* Signal pre-emphasis levels, like voltages, the other end tells us what
5201 * they want
5202 */
5203#define   DP_PRE_EMPHASIS_0             (0 << 22)
5204#define   DP_PRE_EMPHASIS_3_5           (1 << 22)
5205#define   DP_PRE_EMPHASIS_6             (2 << 22)
5206#define   DP_PRE_EMPHASIS_9_5           (3 << 22)
5207#define   DP_PRE_EMPHASIS_MASK          (7 << 22)
5208#define   DP_PRE_EMPHASIS_SHIFT         22
5209
5210/* How many wires to use. I guess 3 was too hard */
5211#define   DP_PORT_WIDTH(width)          (((width) - 1) << 19)
5212#define   DP_PORT_WIDTH_MASK            (7 << 19)
5213#define   DP_PORT_WIDTH_SHIFT           19
5214
5215/* Mystic DPCD version 1.1 special mode */
5216#define   DP_ENHANCED_FRAMING           (1 << 18)
5217
5218/* eDP */
5219#define   DP_PLL_FREQ_270MHZ            (0 << 16)
5220#define   DP_PLL_FREQ_162MHZ            (1 << 16)
5221#define   DP_PLL_FREQ_MASK              (3 << 16)
5222
5223/* locked once port is enabled */
5224#define   DP_PORT_REVERSAL              (1 << 15)
5225
5226/* eDP */
5227#define   DP_PLL_ENABLE                 (1 << 14)
5228
5229/* sends the clock on lane 15 of the PEG for debug */
5230#define   DP_CLOCK_OUTPUT_ENABLE        (1 << 13)
5231
5232#define   DP_SCRAMBLING_DISABLE         (1 << 12)
5233#define   DP_SCRAMBLING_DISABLE_IRONLAKE        (1 << 7)
5234
5235/* limit RGB values to avoid confusing TVs */
5236#define   DP_COLOR_RANGE_16_235         (1 << 8)
5237
5238/* Turn on the audio link */
5239#define   DP_AUDIO_OUTPUT_ENABLE        (1 << 6)
5240
5241/* vs and hs sync polarity */
5242#define   DP_SYNC_VS_HIGH               (1 << 4)
5243#define   DP_SYNC_HS_HIGH               (1 << 3)
5244
5245/* A fantasy */
5246#define   DP_DETECTED                   (1 << 2)
5247
5248/* The aux channel provides a way to talk to the
5249 * signal sink for DDC etc. Max packet size supported
5250 * is 20 bytes in each direction, hence the 5 fixed
5251 * data registers
5252 */
5253#define _DPA_AUX_CH_CTL         (dev_priv->info.display_mmio_offset + 0x64010)
5254#define _DPA_AUX_CH_DATA1       (dev_priv->info.display_mmio_offset + 0x64014)
5255#define _DPA_AUX_CH_DATA2       (dev_priv->info.display_mmio_offset + 0x64018)
5256#define _DPA_AUX_CH_DATA3       (dev_priv->info.display_mmio_offset + 0x6401c)
5257#define _DPA_AUX_CH_DATA4       (dev_priv->info.display_mmio_offset + 0x64020)
5258#define _DPA_AUX_CH_DATA5       (dev_priv->info.display_mmio_offset + 0x64024)
5259
5260#define _DPB_AUX_CH_CTL         (dev_priv->info.display_mmio_offset + 0x64110)
5261#define _DPB_AUX_CH_DATA1       (dev_priv->info.display_mmio_offset + 0x64114)
5262#define _DPB_AUX_CH_DATA2       (dev_priv->info.display_mmio_offset + 0x64118)
5263#define _DPB_AUX_CH_DATA3       (dev_priv->info.display_mmio_offset + 0x6411c)
5264#define _DPB_AUX_CH_DATA4       (dev_priv->info.display_mmio_offset + 0x64120)
5265#define _DPB_AUX_CH_DATA5       (dev_priv->info.display_mmio_offset + 0x64124)
5266
5267#define _DPC_AUX_CH_CTL         (dev_priv->info.display_mmio_offset + 0x64210)
5268#define _DPC_AUX_CH_DATA1       (dev_priv->info.display_mmio_offset + 0x64214)
5269#define _DPC_AUX_CH_DATA2       (dev_priv->info.display_mmio_offset + 0x64218)
5270#define _DPC_AUX_CH_DATA3       (dev_priv->info.display_mmio_offset + 0x6421c)
5271#define _DPC_AUX_CH_DATA4       (dev_priv->info.display_mmio_offset + 0x64220)
5272#define _DPC_AUX_CH_DATA5       (dev_priv->info.display_mmio_offset + 0x64224)
5273
5274#define _DPD_AUX_CH_CTL         (dev_priv->info.display_mmio_offset + 0x64310)
5275#define _DPD_AUX_CH_DATA1       (dev_priv->info.display_mmio_offset + 0x64314)
5276#define _DPD_AUX_CH_DATA2       (dev_priv->info.display_mmio_offset + 0x64318)
5277#define _DPD_AUX_CH_DATA3       (dev_priv->info.display_mmio_offset + 0x6431c)
5278#define _DPD_AUX_CH_DATA4       (dev_priv->info.display_mmio_offset + 0x64320)
5279#define _DPD_AUX_CH_DATA5       (dev_priv->info.display_mmio_offset + 0x64324)
5280
5281#define DP_AUX_CH_CTL(port)     _MMIO_PORT(port, _DPA_AUX_CH_CTL, _DPB_AUX_CH_CTL)
5282#define DP_AUX_CH_DATA(port, i) _MMIO(_PORT(port, _DPA_AUX_CH_DATA1, _DPB_AUX_CH_DATA1) + (i) * 4) /* 5 registers */
5283
5284#define   DP_AUX_CH_CTL_SEND_BUSY           (1 << 31)
5285#define   DP_AUX_CH_CTL_DONE                (1 << 30)
5286#define   DP_AUX_CH_CTL_INTERRUPT           (1 << 29)
5287#define   DP_AUX_CH_CTL_TIME_OUT_ERROR      (1 << 28)
5288#define   DP_AUX_CH_CTL_TIME_OUT_400us      (0 << 26)
5289#define   DP_AUX_CH_CTL_TIME_OUT_600us      (1 << 26)
5290#define   DP_AUX_CH_CTL_TIME_OUT_800us      (2 << 26)
5291#define   DP_AUX_CH_CTL_TIME_OUT_MAX        (3 << 26) /* Varies per platform */
5292#define   DP_AUX_CH_CTL_TIME_OUT_MASK       (3 << 26)
5293#define   DP_AUX_CH_CTL_RECEIVE_ERROR       (1 << 25)
5294#define   DP_AUX_CH_CTL_MESSAGE_SIZE_MASK    (0x1f << 20)
5295#define   DP_AUX_CH_CTL_MESSAGE_SIZE_SHIFT   20
5296#define   DP_AUX_CH_CTL_PRECHARGE_2US_MASK   (0xf << 16)
5297#define   DP_AUX_CH_CTL_PRECHARGE_2US_SHIFT  16
5298#define   DP_AUX_CH_CTL_AUX_AKSV_SELECT     (1 << 15)
5299#define   DP_AUX_CH_CTL_MANCHESTER_TEST     (1 << 14)
5300#define   DP_AUX_CH_CTL_SYNC_TEST           (1 << 13)
5301#define   DP_AUX_CH_CTL_DEGLITCH_TEST       (1 << 12)
5302#define   DP_AUX_CH_CTL_PRECHARGE_TEST      (1 << 11)
5303#define   DP_AUX_CH_CTL_BIT_CLOCK_2X_MASK    (0x7ff)
5304#define   DP_AUX_CH_CTL_BIT_CLOCK_2X_SHIFT   0
5305#define   DP_AUX_CH_CTL_PSR_DATA_AUX_REG_SKL    (1 << 14)
5306#define   DP_AUX_CH_CTL_FS_DATA_AUX_REG_SKL     (1 << 13)
5307#define   DP_AUX_CH_CTL_GTC_DATA_AUX_REG_SKL    (1 << 12)
5308#define   DP_AUX_CH_CTL_FW_SYNC_PULSE_SKL_MASK (0x1f << 5)
5309#define   DP_AUX_CH_CTL_FW_SYNC_PULSE_SKL(c) (((c) - 1) << 5)
5310#define   DP_AUX_CH_CTL_SYNC_PULSE_SKL(c)   ((c) - 1)
5311
5312/*
5313 * Computing GMCH M and N values for the Display Port link
5314 *
5315 * GMCH M/N = dot clock * bytes per pixel / ls_clk * # of lanes
5316 *
5317 * ls_clk (we assume) is the DP link clock (1.62 or 2.7 GHz)
5318 *
5319 * The GMCH value is used internally
5320 *
5321 * bytes_per_pixel is the number of bytes coming out of the plane,
5322 * which is after the LUTs, so we want the bytes for our color format.
5323 * For our current usage, this is always 3, one byte for R, G and B.
5324 */
5325#define _PIPEA_DATA_M_G4X       0x70050
5326#define _PIPEB_DATA_M_G4X       0x71050
5327
5328/* Transfer unit size for display port - 1, default is 0x3f (for TU size 64) */
5329#define  TU_SIZE(x)             (((x)-1) << 25) /* default size 64 */
5330#define  TU_SIZE_SHIFT          25
5331#define  TU_SIZE_MASK           (0x3f << 25)
5332
5333#define  DATA_LINK_M_N_MASK     (0xffffff)
5334#define  DATA_LINK_N_MAX        (0x800000)
5335
5336#define _PIPEA_DATA_N_G4X       0x70054
5337#define _PIPEB_DATA_N_G4X       0x71054
5338#define   PIPE_GMCH_DATA_N_MASK                 (0xffffff)
5339
5340/*
5341 * Computing Link M and N values for the Display Port link
5342 *
5343 * Link M / N = pixel_clock / ls_clk
5344 *
5345 * (the DP spec calls pixel_clock the 'strm_clk')
5346 *
5347 * The Link value is transmitted in the Main Stream
5348 * Attributes and VB-ID.
5349 */
5350
5351#define _PIPEA_LINK_M_G4X       0x70060
5352#define _PIPEB_LINK_M_G4X       0x71060
5353#define   PIPEA_DP_LINK_M_MASK                  (0xffffff)
5354
5355#define _PIPEA_LINK_N_G4X       0x70064
5356#define _PIPEB_LINK_N_G4X       0x71064
5357#define   PIPEA_DP_LINK_N_MASK                  (0xffffff)
5358
5359#define PIPE_DATA_M_G4X(pipe) _MMIO_PIPE(pipe, _PIPEA_DATA_M_G4X, _PIPEB_DATA_M_G4X)
5360#define PIPE_DATA_N_G4X(pipe) _MMIO_PIPE(pipe, _PIPEA_DATA_N_G4X, _PIPEB_DATA_N_G4X)
5361#define PIPE_LINK_M_G4X(pipe) _MMIO_PIPE(pipe, _PIPEA_LINK_M_G4X, _PIPEB_LINK_M_G4X)
5362#define PIPE_LINK_N_G4X(pipe) _MMIO_PIPE(pipe, _PIPEA_LINK_N_G4X, _PIPEB_LINK_N_G4X)
5363
5364/* Display & cursor control */
5365
5366/* Pipe A */
5367#define _PIPEADSL               0x70000
5368#define   DSL_LINEMASK_GEN2     0x00000fff
5369#define   DSL_LINEMASK_GEN3     0x00001fff
5370#define _PIPEACONF              0x70008
5371#define   PIPECONF_ENABLE       (1<<31)
5372#define   PIPECONF_DISABLE      0
5373#define   PIPECONF_DOUBLE_WIDE  (1<<30)
5374#define   I965_PIPECONF_ACTIVE  (1<<30)
5375#define   PIPECONF_DSI_PLL_LOCKED       (1<<29) /* vlv & pipe A only */
5376#define   PIPECONF_FRAME_START_DELAY_MASK (3<<27)
5377#define   PIPECONF_SINGLE_WIDE  0
5378#define   PIPECONF_PIPE_UNLOCKED 0
5379#define   PIPECONF_PIPE_LOCKED  (1<<25)
5380#define   PIPECONF_PALETTE      0
5381#define   PIPECONF_GAMMA                (1<<24)
5382#define   PIPECONF_FORCE_BORDER (1<<25)
5383#define   PIPECONF_INTERLACE_MASK       (7 << 21)
5384#define   PIPECONF_INTERLACE_MASK_HSW   (3 << 21)
5385/* Note that pre-gen3 does not support interlaced display directly. Panel
5386 * fitting must be disabled on pre-ilk for interlaced. */
5387#define   PIPECONF_PROGRESSIVE                  (0 << 21)
5388#define   PIPECONF_INTERLACE_W_SYNC_SHIFT_PANEL (4 << 21) /* gen4 only */
5389#define   PIPECONF_INTERLACE_W_SYNC_SHIFT       (5 << 21) /* gen4 only */
5390#define   PIPECONF_INTERLACE_W_FIELD_INDICATION (6 << 21)
5391#define   PIPECONF_INTERLACE_FIELD_0_ONLY       (7 << 21) /* gen3 only */
5392/* Ironlake and later have a complete new set of values for interlaced. PFIT
5393 * means panel fitter required, PF means progressive fetch, DBL means power
5394 * saving pixel doubling. */
5395#define   PIPECONF_PFIT_PF_INTERLACED_ILK       (1 << 21)
5396#define   PIPECONF_INTERLACED_ILK               (3 << 21)
5397#define   PIPECONF_INTERLACED_DBL_ILK           (4 << 21) /* ilk/snb only */
5398#define   PIPECONF_PFIT_PF_INTERLACED_DBL_ILK   (5 << 21) /* ilk/snb only */
5399#define   PIPECONF_INTERLACE_MODE_MASK          (7 << 21)
5400#define   PIPECONF_EDP_RR_MODE_SWITCH           (1 << 20)
5401#define   PIPECONF_CXSR_DOWNCLOCK       (1<<16)
5402#define   PIPECONF_EDP_RR_MODE_SWITCH_VLV       (1 << 14)
5403#define   PIPECONF_COLOR_RANGE_SELECT   (1 << 13)
5404#define   PIPECONF_BPC_MASK     (0x7 << 5)
5405#define   PIPECONF_8BPC         (0<<5)
5406#define   PIPECONF_10BPC        (1<<5)
5407#define   PIPECONF_6BPC         (2<<5)
5408#define   PIPECONF_12BPC        (3<<5)
5409#define   PIPECONF_DITHER_EN    (1<<4)
5410#define   PIPECONF_DITHER_TYPE_MASK (0x0000000c)
5411#define   PIPECONF_DITHER_TYPE_SP (0<<2)
5412#define   PIPECONF_DITHER_TYPE_ST1 (1<<2)
5413#define   PIPECONF_DITHER_TYPE_ST2 (2<<2)
5414#define   PIPECONF_DITHER_TYPE_TEMP (3<<2)
5415#define _PIPEASTAT              0x70024
5416#define   PIPE_FIFO_UNDERRUN_STATUS             (1UL<<31)
5417#define   SPRITE1_FLIP_DONE_INT_EN_VLV          (1UL<<30)
5418#define   PIPE_CRC_ERROR_ENABLE                 (1UL<<29)
5419#define   PIPE_CRC_DONE_ENABLE                  (1UL<<28)
5420#define   PERF_COUNTER2_INTERRUPT_EN            (1UL<<27)
5421#define   PIPE_GMBUS_EVENT_ENABLE               (1UL<<27)
5422#define   PLANE_FLIP_DONE_INT_EN_VLV            (1UL<<26)
5423#define   PIPE_HOTPLUG_INTERRUPT_ENABLE         (1UL<<26)
5424#define   PIPE_VSYNC_INTERRUPT_ENABLE           (1UL<<25)
5425#define   PIPE_DISPLAY_LINE_COMPARE_ENABLE      (1UL<<24)
5426#define   PIPE_DPST_EVENT_ENABLE                (1UL<<23)
5427#define   SPRITE0_FLIP_DONE_INT_EN_VLV          (1UL<<22)
5428#define   PIPE_LEGACY_BLC_EVENT_ENABLE          (1UL<<22)
5429#define   PIPE_ODD_FIELD_INTERRUPT_ENABLE       (1UL<<21)
5430#define   PIPE_EVEN_FIELD_INTERRUPT_ENABLE      (1UL<<20)
5431#define   PIPE_B_PSR_INTERRUPT_ENABLE_VLV       (1UL<<19)
5432#define   PERF_COUNTER_INTERRUPT_EN             (1UL<<19)
5433#define   PIPE_HOTPLUG_TV_INTERRUPT_ENABLE      (1UL<<18) /* pre-965 */
5434#define   PIPE_START_VBLANK_INTERRUPT_ENABLE    (1UL<<18) /* 965 or later */
5435#define   PIPE_FRAMESTART_INTERRUPT_ENABLE      (1UL<<17)
5436#define   PIPE_VBLANK_INTERRUPT_ENABLE          (1UL<<17)
5437#define   PIPEA_HBLANK_INT_EN_VLV               (1UL<<16)
5438#define   PIPE_OVERLAY_UPDATED_ENABLE           (1UL<<16)
5439#define   SPRITE1_FLIP_DONE_INT_STATUS_VLV      (1UL<<15)
5440#define   SPRITE0_FLIP_DONE_INT_STATUS_VLV      (1UL<<14)
5441#define   PIPE_CRC_ERROR_INTERRUPT_STATUS       (1UL<<13)
5442#define   PIPE_CRC_DONE_INTERRUPT_STATUS        (1UL<<12)
5443#define   PERF_COUNTER2_INTERRUPT_STATUS        (1UL<<11)
5444#define   PIPE_GMBUS_INTERRUPT_STATUS           (1UL<<11)
5445#define   PLANE_FLIP_DONE_INT_STATUS_VLV        (1UL<<10)
5446#define   PIPE_HOTPLUG_INTERRUPT_STATUS         (1UL<<10)
5447#define   PIPE_VSYNC_INTERRUPT_STATUS           (1UL<<9)
5448#define   PIPE_DISPLAY_LINE_COMPARE_STATUS      (1UL<<8)
5449#define   PIPE_DPST_EVENT_STATUS                (1UL<<7)
5450#define   PIPE_A_PSR_STATUS_VLV                 (1UL<<6)
5451#define   PIPE_LEGACY_BLC_EVENT_STATUS          (1UL<<6)
5452#define   PIPE_ODD_FIELD_INTERRUPT_STATUS       (1UL<<5)
5453#define   PIPE_EVEN_FIELD_INTERRUPT_STATUS      (1UL<<4)
5454#define   PIPE_B_PSR_STATUS_VLV                 (1UL<<3)
5455#define   PERF_COUNTER_INTERRUPT_STATUS         (1UL<<3)
5456#define   PIPE_HOTPLUG_TV_INTERRUPT_STATUS      (1UL<<2) /* pre-965 */
5457#define   PIPE_START_VBLANK_INTERRUPT_STATUS    (1UL<<2) /* 965 or later */
5458#define   PIPE_FRAMESTART_INTERRUPT_STATUS      (1UL<<1)
5459#define   PIPE_VBLANK_INTERRUPT_STATUS          (1UL<<1)
5460#define   PIPE_HBLANK_INT_STATUS                (1UL<<0)
5461#define   PIPE_OVERLAY_UPDATED_STATUS           (1UL<<0)
5462
5463#define PIPESTAT_INT_ENABLE_MASK                0x7fff0000
5464#define PIPESTAT_INT_STATUS_MASK                0x0000ffff
5465
5466#define PIPE_A_OFFSET           0x70000
5467#define PIPE_B_OFFSET           0x71000
5468#define PIPE_C_OFFSET           0x72000
5469#define CHV_PIPE_C_OFFSET       0x74000
5470/*
5471 * There's actually no pipe EDP. Some pipe registers have
5472 * simply shifted from the pipe to the transcoder, while
5473 * keeping their original offset. Thus we need PIPE_EDP_OFFSET
5474 * to access such registers in transcoder EDP.
5475 */
5476#define PIPE_EDP_OFFSET 0x7f000
5477
5478#define _MMIO_PIPE2(pipe, reg) _MMIO(dev_priv->info.pipe_offsets[pipe] - \
5479        dev_priv->info.pipe_offsets[PIPE_A] + (reg) + \
5480        dev_priv->info.display_mmio_offset)
5481
5482#define PIPECONF(pipe)          _MMIO_PIPE2(pipe, _PIPEACONF)
5483#define PIPEDSL(pipe)           _MMIO_PIPE2(pipe, _PIPEADSL)
5484#define PIPEFRAME(pipe)         _MMIO_PIPE2(pipe, _PIPEAFRAMEHIGH)
5485#define PIPEFRAMEPIXEL(pipe)    _MMIO_PIPE2(pipe, _PIPEAFRAMEPIXEL)
5486#define PIPESTAT(pipe)          _MMIO_PIPE2(pipe, _PIPEASTAT)
5487
5488#define _PIPE_MISC_A                    0x70030
5489#define _PIPE_MISC_B                    0x71030
5490#define   PIPEMISC_YUV420_ENABLE        (1<<27)
5491#define   PIPEMISC_YUV420_MODE_FULL_BLEND (1<<26)
5492#define   PIPEMISC_OUTPUT_COLORSPACE_YUV  (1<<11)
5493#define   PIPEMISC_DITHER_BPC_MASK      (7<<5)
5494#define   PIPEMISC_DITHER_8_BPC         (0<<5)
5495#define   PIPEMISC_DITHER_10_BPC        (1<<5)
5496#define   PIPEMISC_DITHER_6_BPC         (2<<5)
5497#define   PIPEMISC_DITHER_12_BPC        (3<<5)
5498#define   PIPEMISC_DITHER_ENABLE        (1<<4)
5499#define   PIPEMISC_DITHER_TYPE_MASK     (3<<2)
5500#define   PIPEMISC_DITHER_TYPE_SP       (0<<2)
5501#define PIPEMISC(pipe)                  _MMIO_PIPE2(pipe, _PIPE_MISC_A)
5502
5503#define VLV_DPFLIPSTAT                          _MMIO(VLV_DISPLAY_BASE + 0x70028)
5504#define   PIPEB_LINE_COMPARE_INT_EN             (1<<29)
5505#define   PIPEB_HLINE_INT_EN                    (1<<28)
5506#define   PIPEB_VBLANK_INT_EN                   (1<<27)
5507#define   SPRITED_FLIP_DONE_INT_EN              (1<<26)
5508#define   SPRITEC_FLIP_DONE_INT_EN              (1<<25)
5509#define   PLANEB_FLIP_DONE_INT_EN               (1<<24)
5510#define   PIPE_PSR_INT_EN                       (1<<22)
5511#define   PIPEA_LINE_COMPARE_INT_EN             (1<<21)
5512#define   PIPEA_HLINE_INT_EN                    (1<<20)
5513#define   PIPEA_VBLANK_INT_EN                   (1<<19)
5514#define   SPRITEB_FLIP_DONE_INT_EN              (1<<18)
5515#define   SPRITEA_FLIP_DONE_INT_EN              (1<<17)
5516#define   PLANEA_FLIPDONE_INT_EN                (1<<16)
5517#define   PIPEC_LINE_COMPARE_INT_EN             (1<<13)
5518#define   PIPEC_HLINE_INT_EN                    (1<<12)
5519#define   PIPEC_VBLANK_INT_EN                   (1<<11)
5520#define   SPRITEF_FLIPDONE_INT_EN               (1<<10)
5521#define   SPRITEE_FLIPDONE_INT_EN               (1<<9)
5522#define   PLANEC_FLIPDONE_INT_EN                (1<<8)
5523
5524#define DPINVGTT                                _MMIO(VLV_DISPLAY_BASE + 0x7002c) /* VLV/CHV only */
5525#define   SPRITEF_INVALID_GTT_INT_EN            (1<<27)
5526#define   SPRITEE_INVALID_GTT_INT_EN            (1<<26)
5527#define   PLANEC_INVALID_GTT_INT_EN             (1<<25)
5528#define   CURSORC_INVALID_GTT_INT_EN            (1<<24)
5529#define   CURSORB_INVALID_GTT_INT_EN            (1<<23)
5530#define   CURSORA_INVALID_GTT_INT_EN            (1<<22)
5531#define   SPRITED_INVALID_GTT_INT_EN            (1<<21)
5532#define   SPRITEC_INVALID_GTT_INT_EN            (1<<20)
5533#define   PLANEB_INVALID_GTT_INT_EN             (1<<19)
5534#define   SPRITEB_INVALID_GTT_INT_EN            (1<<18)
5535#define   SPRITEA_INVALID_GTT_INT_EN            (1<<17)
5536#define   PLANEA_INVALID_GTT_INT_EN             (1<<16)
5537#define   DPINVGTT_EN_MASK                      0xff0000
5538#define   DPINVGTT_EN_MASK_CHV                  0xfff0000
5539#define   SPRITEF_INVALID_GTT_STATUS            (1<<11)
5540#define   SPRITEE_INVALID_GTT_STATUS            (1<<10)
5541#define   PLANEC_INVALID_GTT_STATUS             (1<<9)
5542#define   CURSORC_INVALID_GTT_STATUS            (1<<8)
5543#define   CURSORB_INVALID_GTT_STATUS            (1<<7)
5544#define   CURSORA_INVALID_GTT_STATUS            (1<<6)
5545#define   SPRITED_INVALID_GTT_STATUS            (1<<5)
5546#define   SPRITEC_INVALID_GTT_STATUS            (1<<4)
5547#define   PLANEB_INVALID_GTT_STATUS             (1<<3)
5548#define   SPRITEB_INVALID_GTT_STATUS            (1<<2)
5549#define   SPRITEA_INVALID_GTT_STATUS            (1<<1)
5550#define   PLANEA_INVALID_GTT_STATUS             (1<<0)
5551#define   DPINVGTT_STATUS_MASK                  0xff
5552#define   DPINVGTT_STATUS_MASK_CHV              0xfff
5553
5554#define DSPARB                  _MMIO(dev_priv->info.display_mmio_offset + 0x70030)
5555#define   DSPARB_CSTART_MASK    (0x7f << 7)
5556#define   DSPARB_CSTART_SHIFT   7
5557#define   DSPARB_BSTART_MASK    (0x7f)
5558#define   DSPARB_BSTART_SHIFT   0
5559#define   DSPARB_BEND_SHIFT     9 /* on 855 */
5560#define   DSPARB_AEND_SHIFT     0
5561#define   DSPARB_SPRITEA_SHIFT_VLV      0
5562#define   DSPARB_SPRITEA_MASK_VLV       (0xff << 0)
5563#define   DSPARB_SPRITEB_SHIFT_VLV      8
5564#define   DSPARB_SPRITEB_MASK_VLV       (0xff << 8)
5565#define   DSPARB_SPRITEC_SHIFT_VLV      16
5566#define   DSPARB_SPRITEC_MASK_VLV       (0xff << 16)
5567#define   DSPARB_SPRITED_SHIFT_VLV      24
5568#define   DSPARB_SPRITED_MASK_VLV       (0xff << 24)
5569#define DSPARB2                         _MMIO(VLV_DISPLAY_BASE + 0x70060) /* vlv/chv */
5570#define   DSPARB_SPRITEA_HI_SHIFT_VLV   0
5571#define   DSPARB_SPRITEA_HI_MASK_VLV    (0x1 << 0)
5572#define   DSPARB_SPRITEB_HI_SHIFT_VLV   4
5573#define   DSPARB_SPRITEB_HI_MASK_VLV    (0x1 << 4)
5574#define   DSPARB_SPRITEC_HI_SHIFT_VLV   8
5575#define   DSPARB_SPRITEC_HI_MASK_VLV    (0x1 << 8)
5576#define   DSPARB_SPRITED_HI_SHIFT_VLV   12
5577#define   DSPARB_SPRITED_HI_MASK_VLV    (0x1 << 12)
5578#define   DSPARB_SPRITEE_HI_SHIFT_VLV   16
5579#define   DSPARB_SPRITEE_HI_MASK_VLV    (0x1 << 16)
5580#define   DSPARB_SPRITEF_HI_SHIFT_VLV   20
5581#define   DSPARB_SPRITEF_HI_MASK_VLV    (0x1 << 20)
5582#define DSPARB3                         _MMIO(VLV_DISPLAY_BASE + 0x7006c) /* chv */
5583#define   DSPARB_SPRITEE_SHIFT_VLV      0
5584#define   DSPARB_SPRITEE_MASK_VLV       (0xff << 0)
5585#define   DSPARB_SPRITEF_SHIFT_VLV      8
5586#define   DSPARB_SPRITEF_MASK_VLV       (0xff << 8)
5587
5588/* pnv/gen4/g4x/vlv/chv */
5589#define DSPFW1          _MMIO(dev_priv->info.display_mmio_offset + 0x70034)
5590#define   DSPFW_SR_SHIFT                23
5591#define   DSPFW_SR_MASK                 (0x1ff<<23)
5592#define   DSPFW_CURSORB_SHIFT           16
5593#define   DSPFW_CURSORB_MASK            (0x3f<<16)
5594#define   DSPFW_PLANEB_SHIFT            8
5595#define   DSPFW_PLANEB_MASK             (0x7f<<8)
5596#define   DSPFW_PLANEB_MASK_VLV         (0xff<<8) /* vlv/chv */
5597#define   DSPFW_PLANEA_SHIFT            0
5598#define   DSPFW_PLANEA_MASK             (0x7f<<0)
5599#define   DSPFW_PLANEA_MASK_VLV         (0xff<<0) /* vlv/chv */
5600#define DSPFW2          _MMIO(dev_priv->info.display_mmio_offset + 0x70038)
5601#define   DSPFW_FBC_SR_EN               (1<<31)   /* g4x */
5602#define   DSPFW_FBC_SR_SHIFT            28
5603#define   DSPFW_FBC_SR_MASK             (0x7<<28) /* g4x */
5604#define   DSPFW_FBC_HPLL_SR_SHIFT       24
5605#define   DSPFW_FBC_HPLL_SR_MASK        (0xf<<24) /* g4x */
5606#define   DSPFW_SPRITEB_SHIFT           (16)
5607#define   DSPFW_SPRITEB_MASK            (0x7f<<16) /* g4x */
5608#define   DSPFW_SPRITEB_MASK_VLV        (0xff<<16) /* vlv/chv */
5609#define   DSPFW_CURSORA_SHIFT           8
5610#define   DSPFW_CURSORA_MASK            (0x3f<<8)
5611#define   DSPFW_PLANEC_OLD_SHIFT        0
5612#define   DSPFW_PLANEC_OLD_MASK         (0x7f<<0) /* pre-gen4 sprite C */
5613#define   DSPFW_SPRITEA_SHIFT           0
5614#define   DSPFW_SPRITEA_MASK            (0x7f<<0) /* g4x */
5615#define   DSPFW_SPRITEA_MASK_VLV        (0xff<<0) /* vlv/chv */
5616#define DSPFW3          _MMIO(dev_priv->info.display_mmio_offset + 0x7003c)
5617#define   DSPFW_HPLL_SR_EN              (1<<31)
5618#define   PINEVIEW_SELF_REFRESH_EN      (1<<30)
5619#define   DSPFW_CURSOR_SR_SHIFT         24
5620#define   DSPFW_CURSOR_SR_MASK          (0x3f<<24)
5621#define   DSPFW_HPLL_CURSOR_SHIFT       16
5622#define   DSPFW_HPLL_CURSOR_MASK        (0x3f<<16)
5623#define   DSPFW_HPLL_SR_SHIFT           0
5624#define   DSPFW_HPLL_SR_MASK            (0x1ff<<0)
5625
5626/* vlv/chv */
5627#define DSPFW4          _MMIO(VLV_DISPLAY_BASE + 0x70070)
5628#define   DSPFW_SPRITEB_WM1_SHIFT       16
5629#define   DSPFW_SPRITEB_WM1_MASK        (0xff<<16)
5630#define   DSPFW_CURSORA_WM1_SHIFT       8
5631#define   DSPFW_CURSORA_WM1_MASK        (0x3f<<8)
5632#define   DSPFW_SPRITEA_WM1_SHIFT       0
5633#define   DSPFW_SPRITEA_WM1_MASK        (0xff<<0)
5634#define DSPFW5          _MMIO(VLV_DISPLAY_BASE + 0x70074)
5635#define   DSPFW_PLANEB_WM1_SHIFT        24
5636#define   DSPFW_PLANEB_WM1_MASK         (0xff<<24)
5637#define   DSPFW_PLANEA_WM1_SHIFT        16
5638#define   DSPFW_PLANEA_WM1_MASK         (0xff<<16)
5639#define   DSPFW_CURSORB_WM1_SHIFT       8
5640#define   DSPFW_CURSORB_WM1_MASK        (0x3f<<8)
5641#define   DSPFW_CURSOR_SR_WM1_SHIFT     0
5642#define   DSPFW_CURSOR_SR_WM1_MASK      (0x3f<<0)
5643#define DSPFW6          _MMIO(VLV_DISPLAY_BASE + 0x70078)
5644#define   DSPFW_SR_WM1_SHIFT            0
5645#define   DSPFW_SR_WM1_MASK             (0x1ff<<0)
5646#define DSPFW7          _MMIO(VLV_DISPLAY_BASE + 0x7007c)
5647#define DSPFW7_CHV      _MMIO(VLV_DISPLAY_BASE + 0x700b4) /* wtf #1? */
5648#define   DSPFW_SPRITED_WM1_SHIFT       24
5649#define   DSPFW_SPRITED_WM1_MASK        (0xff<<24)
5650#define   DSPFW_SPRITED_SHIFT           16
5651#define   DSPFW_SPRITED_MASK_VLV        (0xff<<16)
5652#define   DSPFW_SPRITEC_WM1_SHIFT       8
5653#define   DSPFW_SPRITEC_WM1_MASK        (0xff<<8)
5654#define   DSPFW_SPRITEC_SHIFT           0
5655#define   DSPFW_SPRITEC_MASK_VLV        (0xff<<0)
5656#define DSPFW8_CHV      _MMIO(VLV_DISPLAY_BASE + 0x700b8)
5657#define   DSPFW_SPRITEF_WM1_SHIFT       24
5658#define   DSPFW_SPRITEF_WM1_MASK        (0xff<<24)
5659#define   DSPFW_SPRITEF_SHIFT           16
5660#define   DSPFW_SPRITEF_MASK_VLV        (0xff<<16)
5661#define   DSPFW_SPRITEE_WM1_SHIFT       8
5662#define   DSPFW_SPRITEE_WM1_MASK        (0xff<<8)
5663#define   DSPFW_SPRITEE_SHIFT           0
5664#define   DSPFW_SPRITEE_MASK_VLV        (0xff<<0)
5665#define DSPFW9_CHV      _MMIO(VLV_DISPLAY_BASE + 0x7007c) /* wtf #2? */
5666#define   DSPFW_PLANEC_WM1_SHIFT        24
5667#define   DSPFW_PLANEC_WM1_MASK         (0xff<<24)
5668#define   DSPFW_PLANEC_SHIFT            16
5669#define   DSPFW_PLANEC_MASK_VLV         (0xff<<16)
5670#define   DSPFW_CURSORC_WM1_SHIFT       8
5671#define   DSPFW_CURSORC_WM1_MASK        (0x3f<<16)
5672#define   DSPFW_CURSORC_SHIFT           0
5673#define   DSPFW_CURSORC_MASK            (0x3f<<0)
5674
5675/* vlv/chv high order bits */
5676#define DSPHOWM         _MMIO(VLV_DISPLAY_BASE + 0x70064)
5677#define   DSPFW_SR_HI_SHIFT             24
5678#define   DSPFW_SR_HI_MASK              (3<<24) /* 2 bits for chv, 1 for vlv */
5679#define   DSPFW_SPRITEF_HI_SHIFT        23
5680#define   DSPFW_SPRITEF_HI_MASK         (1<<23)
5681#define   DSPFW_SPRITEE_HI_SHIFT        22
5682#define   DSPFW_SPRITEE_HI_MASK         (1<<22)
5683#define   DSPFW_PLANEC_HI_SHIFT         21
5684#define   DSPFW_PLANEC_HI_MASK          (1<<21)
5685#define   DSPFW_SPRITED_HI_SHIFT        20
5686#define   DSPFW_SPRITED_HI_MASK         (1<<20)
5687#define   DSPFW_SPRITEC_HI_SHIFT        16
5688#define   DSPFW_SPRITEC_HI_MASK         (1<<16)
5689#define   DSPFW_PLANEB_HI_SHIFT         12
5690#define   DSPFW_PLANEB_HI_MASK          (1<<12)
5691#define   DSPFW_SPRITEB_HI_SHIFT        8
5692#define   DSPFW_SPRITEB_HI_MASK         (1<<8)
5693#define   DSPFW_SPRITEA_HI_SHIFT        4
5694#define   DSPFW_SPRITEA_HI_MASK         (1<<4)
5695#define   DSPFW_PLANEA_HI_SHIFT         0
5696#define   DSPFW_PLANEA_HI_MASK          (1<<0)
5697#define DSPHOWM1        _MMIO(VLV_DISPLAY_BASE + 0x70068)
5698#define   DSPFW_SR_WM1_HI_SHIFT         24
5699#define   DSPFW_SR_WM1_HI_MASK          (3<<24) /* 2 bits for chv, 1 for vlv */
5700#define   DSPFW_SPRITEF_WM1_HI_SHIFT    23
5701#define   DSPFW_SPRITEF_WM1_HI_MASK     (1<<23)
5702#define   DSPFW_SPRITEE_WM1_HI_SHIFT    22
5703#define   DSPFW_SPRITEE_WM1_HI_MASK     (1<<22)
5704#define   DSPFW_PLANEC_WM1_HI_SHIFT     21
5705#define   DSPFW_PLANEC_WM1_HI_MASK      (1<<21)
5706#define   DSPFW_SPRITED_WM1_HI_SHIFT    20
5707#define   DSPFW_SPRITED_WM1_HI_MASK     (1<<20)
5708#define   DSPFW_SPRITEC_WM1_HI_SHIFT    16
5709#define   DSPFW_SPRITEC_WM1_HI_MASK     (1<<16)
5710#define   DSPFW_PLANEB_WM1_HI_SHIFT     12
5711#define   DSPFW_PLANEB_WM1_HI_MASK      (1<<12)
5712#define   DSPFW_SPRITEB_WM1_HI_SHIFT    8
5713#define   DSPFW_SPRITEB_WM1_HI_MASK     (1<<8)
5714#define   DSPFW_SPRITEA_WM1_HI_SHIFT    4
5715#define   DSPFW_SPRITEA_WM1_HI_MASK     (1<<4)
5716#define   DSPFW_PLANEA_WM1_HI_SHIFT     0
5717#define   DSPFW_PLANEA_WM1_HI_MASK      (1<<0)
5718
5719/* drain latency register values*/
5720#define VLV_DDL(pipe)                   _MMIO(VLV_DISPLAY_BASE + 0x70050 + 4 * (pipe))
5721#define DDL_CURSOR_SHIFT                24
5722#define DDL_SPRITE_SHIFT(sprite)        (8+8*(sprite))
5723#define DDL_PLANE_SHIFT                 0
5724#define DDL_PRECISION_HIGH              (1<<7)
5725#define DDL_PRECISION_LOW               (0<<7)
5726#define DRAIN_LATENCY_MASK              0x7f
5727
5728#define CBR1_VLV                        _MMIO(VLV_DISPLAY_BASE + 0x70400)
5729#define  CBR_PND_DEADLINE_DISABLE       (1<<31)
5730#define  CBR_PWM_CLOCK_MUX_SELECT       (1<<30)
5731
5732#define CBR4_VLV                        _MMIO(VLV_DISPLAY_BASE + 0x70450)
5733#define  CBR_DPLLBMD_PIPE(pipe)         (1<<(7+(pipe)*11)) /* pipes B and C */
5734
5735/* FIFO watermark sizes etc */
5736#define G4X_FIFO_LINE_SIZE      64
5737#define I915_FIFO_LINE_SIZE     64
5738#define I830_FIFO_LINE_SIZE     32
5739
5740#define VALLEYVIEW_FIFO_SIZE    255
5741#define G4X_FIFO_SIZE           127
5742#define I965_FIFO_SIZE          512
5743#define I945_FIFO_SIZE          127
5744#define I915_FIFO_SIZE          95
5745#define I855GM_FIFO_SIZE        127 /* In cachelines */
5746#define I830_FIFO_SIZE          95
5747
5748#define VALLEYVIEW_MAX_WM       0xff
5749#define G4X_MAX_WM              0x3f
5750#define I915_MAX_WM             0x3f
5751
5752#define PINEVIEW_DISPLAY_FIFO   512 /* in 64byte unit */
5753#define PINEVIEW_FIFO_LINE_SIZE 64
5754#define PINEVIEW_MAX_WM         0x1ff
5755#define PINEVIEW_DFT_WM         0x3f
5756#define PINEVIEW_DFT_HPLLOFF_WM 0
5757#define PINEVIEW_GUARD_WM               10
5758#define PINEVIEW_CURSOR_FIFO            64
5759#define PINEVIEW_CURSOR_MAX_WM  0x3f
5760#define PINEVIEW_CURSOR_DFT_WM  0
5761#define PINEVIEW_CURSOR_GUARD_WM        5
5762
5763#define VALLEYVIEW_CURSOR_MAX_WM 64
5764#define I965_CURSOR_FIFO        64
5765#define I965_CURSOR_MAX_WM      32
5766#define I965_CURSOR_DFT_WM      8
5767
5768/* Watermark register definitions for SKL */
5769#define _CUR_WM_A_0             0x70140
5770#define _CUR_WM_B_0             0x71140
5771#define _PLANE_WM_1_A_0         0x70240
5772#define _PLANE_WM_1_B_0         0x71240
5773#define _PLANE_WM_2_A_0         0x70340
5774#define _PLANE_WM_2_B_0         0x71340
5775#define _PLANE_WM_TRANS_1_A_0   0x70268
5776#define _PLANE_WM_TRANS_1_B_0   0x71268
5777#define _PLANE_WM_TRANS_2_A_0   0x70368
5778#define _PLANE_WM_TRANS_2_B_0   0x71368
5779#define _CUR_WM_TRANS_A_0       0x70168
5780#define _CUR_WM_TRANS_B_0       0x71168
5781#define   PLANE_WM_EN           (1 << 31)
5782#define   PLANE_WM_LINES_SHIFT  14
5783#define   PLANE_WM_LINES_MASK   0x1f
5784#define   PLANE_WM_BLOCKS_MASK  0x3ff
5785
5786#define _CUR_WM_0(pipe) _PIPE(pipe, _CUR_WM_A_0, _CUR_WM_B_0)
5787#define CUR_WM(pipe, level) _MMIO(_CUR_WM_0(pipe) + ((4) * (level)))
5788#define CUR_WM_TRANS(pipe) _MMIO_PIPE(pipe, _CUR_WM_TRANS_A_0, _CUR_WM_TRANS_B_0)
5789
5790#define _PLANE_WM_1(pipe) _PIPE(pipe, _PLANE_WM_1_A_0, _PLANE_WM_1_B_0)
5791#define _PLANE_WM_2(pipe) _PIPE(pipe, _PLANE_WM_2_A_0, _PLANE_WM_2_B_0)
5792#define _PLANE_WM_BASE(pipe, plane)     \
5793                        _PLANE(plane, _PLANE_WM_1(pipe), _PLANE_WM_2(pipe))
5794#define PLANE_WM(pipe, plane, level)    \
5795                        _MMIO(_PLANE_WM_BASE(pipe, plane) + ((4) * (level)))
5796#define _PLANE_WM_TRANS_1(pipe) \
5797                        _PIPE(pipe, _PLANE_WM_TRANS_1_A_0, _PLANE_WM_TRANS_1_B_0)
5798#define _PLANE_WM_TRANS_2(pipe) \
5799                        _PIPE(pipe, _PLANE_WM_TRANS_2_A_0, _PLANE_WM_TRANS_2_B_0)
5800#define PLANE_WM_TRANS(pipe, plane)     \
5801        _MMIO(_PLANE(plane, _PLANE_WM_TRANS_1(pipe), _PLANE_WM_TRANS_2(pipe)))
5802
5803/* define the Watermark register on Ironlake */
5804#define WM0_PIPEA_ILK           _MMIO(0x45100)
5805#define  WM0_PIPE_PLANE_MASK    (0xffff<<16)
5806#define  WM0_PIPE_PLANE_SHIFT   16
5807#define  WM0_PIPE_SPRITE_MASK   (0xff<<8)
5808#define  WM0_PIPE_SPRITE_SHIFT  8
5809#define  WM0_PIPE_CURSOR_MASK   (0xff)
5810
5811#define WM0_PIPEB_ILK           _MMIO(0x45104)
5812#define WM0_PIPEC_IVB           _MMIO(0x45200)
5813#define WM1_LP_ILK              _MMIO(0x45108)
5814#define  WM1_LP_SR_EN           (1<<31)
5815#define  WM1_LP_LATENCY_SHIFT   24
5816#define  WM1_LP_LATENCY_MASK    (0x7f<<24)
5817#define  WM1_LP_FBC_MASK        (0xf<<20)
5818#define  WM1_LP_FBC_SHIFT       20
5819#define  WM1_LP_FBC_SHIFT_BDW   19
5820#define  WM1_LP_SR_MASK         (0x7ff<<8)
5821#define  WM1_LP_SR_SHIFT        8
5822#define  WM1_LP_CURSOR_MASK     (0xff)
5823#define WM2_LP_ILK              _MMIO(0x4510c)
5824#define  WM2_LP_EN              (1<<31)
5825#define WM3_LP_ILK              _MMIO(0x45110)
5826#define  WM3_LP_EN              (1<<31)
5827#define WM1S_LP_ILK             _MMIO(0x45120)
5828#define WM2S_LP_IVB             _MMIO(0x45124)
5829#define WM3S_LP_IVB             _MMIO(0x45128)
5830#define  WM1S_LP_EN             (1<<31)
5831
5832#define HSW_WM_LP_VAL(lat, fbc, pri, cur) \
5833        (WM3_LP_EN | ((lat) << WM1_LP_LATENCY_SHIFT) | \
5834         ((fbc) << WM1_LP_FBC_SHIFT) | ((pri) << WM1_LP_SR_SHIFT) | (cur))
5835
5836/* Memory latency timer register */
5837#define MLTR_ILK                _MMIO(0x11222)
5838#define  MLTR_WM1_SHIFT         0
5839#define  MLTR_WM2_SHIFT         8
5840/* the unit of memory self-refresh latency time is 0.5us */
5841#define  ILK_SRLT_MASK          0x3f
5842
5843
5844/* the address where we get all kinds of latency value */
5845#define SSKPD                   _MMIO(0x5d10)
5846#define SSKPD_WM_MASK           0x3f
5847#define SSKPD_WM0_SHIFT         0
5848#define SSKPD_WM1_SHIFT         8
5849#define SSKPD_WM2_SHIFT         16
5850#define SSKPD_WM3_SHIFT         24
5851
5852/*
5853 * The two pipe frame counter registers are not synchronized, so
5854 * reading a stable value is somewhat tricky. The following code
5855 * should work:
5856 *
5857 *  do {
5858 *    high1 = ((INREG(PIPEAFRAMEHIGH) & PIPE_FRAME_HIGH_MASK) >>
5859 *             PIPE_FRAME_HIGH_SHIFT;
5860 *    low1 =  ((INREG(PIPEAFRAMEPIXEL) & PIPE_FRAME_LOW_MASK) >>
5861 *             PIPE_FRAME_LOW_SHIFT);
5862 *    high2 = ((INREG(PIPEAFRAMEHIGH) & PIPE_FRAME_HIGH_MASK) >>
5863 *             PIPE_FRAME_HIGH_SHIFT);
5864 *  } while (high1 != high2);
5865 *  frame = (high1 << 8) | low1;
5866 */
5867#define _PIPEAFRAMEHIGH          0x70040
5868#define   PIPE_FRAME_HIGH_MASK    0x0000ffff
5869#define   PIPE_FRAME_HIGH_SHIFT   0
5870#define _PIPEAFRAMEPIXEL         0x70044
5871#define   PIPE_FRAME_LOW_MASK     0xff000000
5872#define   PIPE_FRAME_LOW_SHIFT    24
5873#define   PIPE_PIXEL_MASK         0x00ffffff
5874#define   PIPE_PIXEL_SHIFT        0
5875/* GM45+ just has to be different */
5876#define _PIPEA_FRMCOUNT_G4X     0x70040
5877#define _PIPEA_FLIPCOUNT_G4X    0x70044
5878#define PIPE_FRMCOUNT_G4X(pipe) _MMIO_PIPE2(pipe, _PIPEA_FRMCOUNT_G4X)
5879#define PIPE_FLIPCOUNT_G4X(pipe) _MMIO_PIPE2(pipe, _PIPEA_FLIPCOUNT_G4X)
5880
5881/* Cursor A & B regs */
5882#define _CURACNTR               0x70080
5883/* Old style CUR*CNTR flags (desktop 8xx) */
5884#define   CURSOR_ENABLE         0x80000000
5885#define   CURSOR_GAMMA_ENABLE   0x40000000
5886#define   CURSOR_STRIDE_SHIFT   28
5887#define   CURSOR_STRIDE(x)      ((ffs(x)-9) << CURSOR_STRIDE_SHIFT) /* 256,512,1k,2k */
5888#define   CURSOR_PIPE_CSC_ENABLE (1<<24)
5889#define   CURSOR_FORMAT_SHIFT   24
5890#define   CURSOR_FORMAT_MASK    (0x07 << CURSOR_FORMAT_SHIFT)
5891#define   CURSOR_FORMAT_2C      (0x00 << CURSOR_FORMAT_SHIFT)
5892#define   CURSOR_FORMAT_3C      (0x01 << CURSOR_FORMAT_SHIFT)
5893#define   CURSOR_FORMAT_4C      (0x02 << CURSOR_FORMAT_SHIFT)
5894#define   CURSOR_FORMAT_ARGB    (0x04 << CURSOR_FORMAT_SHIFT)
5895#define   CURSOR_FORMAT_XRGB    (0x05 << CURSOR_FORMAT_SHIFT)
5896/* New style CUR*CNTR flags */
5897#define   CURSOR_MODE           0x27
5898#define   CURSOR_MODE_DISABLE   0x00
5899#define   CURSOR_MODE_128_32B_AX 0x02
5900#define   CURSOR_MODE_256_32B_AX 0x03
5901#define   CURSOR_MODE_64_32B_AX 0x07
5902#define   CURSOR_MODE_128_ARGB_AX ((1 << 5) | CURSOR_MODE_128_32B_AX)
5903#define   CURSOR_MODE_256_ARGB_AX ((1 << 5) | CURSOR_MODE_256_32B_AX)
5904#define   CURSOR_MODE_64_ARGB_AX ((1 << 5) | CURSOR_MODE_64_32B_AX)
5905#define   MCURSOR_PIPE_SELECT(pipe)     ((pipe) << 28)
5906#define   MCURSOR_GAMMA_ENABLE  (1 << 26)
5907#define   CURSOR_ROTATE_180     (1<<15)
5908#define   CURSOR_TRICKLE_FEED_DISABLE   (1 << 14)
5909#define _CURABASE               0x70084
5910#define _CURAPOS                0x70088
5911#define   CURSOR_POS_MASK       0x007FF
5912#define   CURSOR_POS_SIGN       0x8000
5913#define   CURSOR_X_SHIFT        0
5914#define   CURSOR_Y_SHIFT        16
5915#define CURSIZE                 _MMIO(0x700a0) /* 845/865 */
5916#define _CUR_FBC_CTL_A          0x700a0 /* ivb+ */
5917#define   CUR_FBC_CTL_EN        (1 << 31)
5918#define _CURBCNTR               0x700c0
5919#define _CURBBASE               0x700c4
5920#define _CURBPOS                0x700c8
5921
5922#define _CURBCNTR_IVB           0x71080
5923#define _CURBBASE_IVB           0x71084
5924#define _CURBPOS_IVB            0x71088
5925
5926#define _CURSOR2(pipe, reg) _MMIO(dev_priv->info.cursor_offsets[(pipe)] - \
5927        dev_priv->info.cursor_offsets[PIPE_A] + (reg) + \
5928        dev_priv->info.display_mmio_offset)
5929
5930#define CURCNTR(pipe) _CURSOR2(pipe, _CURACNTR)
5931#define CURBASE(pipe) _CURSOR2(pipe, _CURABASE)
5932#define CURPOS(pipe) _CURSOR2(pipe, _CURAPOS)
5933#define CUR_FBC_CTL(pipe) _CURSOR2(pipe, _CUR_FBC_CTL_A)
5934
5935#define CURSOR_A_OFFSET 0x70080
5936#define CURSOR_B_OFFSET 0x700c0
5937#define CHV_CURSOR_C_OFFSET 0x700e0
5938#define IVB_CURSOR_B_OFFSET 0x71080
5939#define IVB_CURSOR_C_OFFSET 0x72080
5940
5941/* Display A control */
5942#define _DSPACNTR                               0x70180
5943#define   DISPLAY_PLANE_ENABLE                  (1<<31)
5944#define   DISPLAY_PLANE_DISABLE                 0
5945#define   DISPPLANE_GAMMA_ENABLE                (1<<30)
5946#define   DISPPLANE_GAMMA_DISABLE               0
5947#define   DISPPLANE_PIXFORMAT_MASK              (0xf<<26)
5948#define   DISPPLANE_YUV422                      (0x0<<26)
5949#define   DISPPLANE_8BPP                        (0x2<<26)
5950#define   DISPPLANE_BGRA555                     (0x3<<26)
5951#define   DISPPLANE_BGRX555                     (0x4<<26)
5952#define   DISPPLANE_BGRX565                     (0x5<<26)
5953#define   DISPPLANE_BGRX888                     (0x6<<26)
5954#define   DISPPLANE_BGRA888                     (0x7<<26)
5955#define   DISPPLANE_RGBX101010                  (0x8<<26)
5956#define   DISPPLANE_RGBA101010                  (0x9<<26)
5957#define   DISPPLANE_BGRX101010                  (0xa<<26)
5958#define   DISPPLANE_RGBX161616                  (0xc<<26)
5959#define   DISPPLANE_RGBX888                     (0xe<<26)
5960#define   DISPPLANE_RGBA888                     (0xf<<26)
5961#define   DISPPLANE_STEREO_ENABLE               (1<<25)
5962#define   DISPPLANE_STEREO_DISABLE              0
5963#define   DISPPLANE_PIPE_CSC_ENABLE             (1<<24)
5964#define   DISPPLANE_SEL_PIPE_SHIFT              24
5965#define   DISPPLANE_SEL_PIPE_MASK               (3<<DISPPLANE_SEL_PIPE_SHIFT)
5966#define   DISPPLANE_SEL_PIPE(pipe)              ((pipe)<<DISPPLANE_SEL_PIPE_SHIFT)
5967#define   DISPPLANE_SRC_KEY_ENABLE              (1<<22)
5968#define   DISPPLANE_SRC_KEY_DISABLE             0
5969#define   DISPPLANE_LINE_DOUBLE                 (1<<20)
5970#define   DISPPLANE_NO_LINE_DOUBLE              0
5971#define   DISPPLANE_STEREO_POLARITY_FIRST       0
5972#define   DISPPLANE_STEREO_POLARITY_SECOND      (1<<18)
5973#define   DISPPLANE_ALPHA_PREMULTIPLY           (1<<16) /* CHV pipe B */
5974#define   DISPPLANE_ROTATE_180                  (1<<15)
5975#define   DISPPLANE_TRICKLE_FEED_DISABLE        (1<<14) /* Ironlake */
5976#define   DISPPLANE_TILED                       (1<<10)
5977#define   DISPPLANE_MIRROR                      (1<<8) /* CHV pipe B */
5978#define _DSPAADDR                               0x70184
5979#define _DSPASTRIDE                             0x70188
5980#define _DSPAPOS                                0x7018C /* reserved */
5981#define _DSPASIZE                               0x70190
5982#define _DSPASURF                               0x7019C /* 965+ only */
5983#define _DSPATILEOFF                            0x701A4 /* 965+ only */
5984#define _DSPAOFFSET                             0x701A4 /* HSW */
5985#define _DSPASURFLIVE                           0x701AC
5986
5987#define DSPCNTR(plane)          _MMIO_PIPE2(plane, _DSPACNTR)
5988#define DSPADDR(plane)          _MMIO_PIPE2(plane, _DSPAADDR)
5989#define DSPSTRIDE(plane)        _MMIO_PIPE2(plane, _DSPASTRIDE)
5990#define DSPPOS(plane)           _MMIO_PIPE2(plane, _DSPAPOS)
5991#define DSPSIZE(plane)          _MMIO_PIPE2(plane, _DSPASIZE)
5992#define DSPSURF(plane)          _MMIO_PIPE2(plane, _DSPASURF)
5993#define DSPTILEOFF(plane)       _MMIO_PIPE2(plane, _DSPATILEOFF)
5994#define DSPLINOFF(plane)        DSPADDR(plane)
5995#define DSPOFFSET(plane)        _MMIO_PIPE2(plane, _DSPAOFFSET)
5996#define DSPSURFLIVE(plane)      _MMIO_PIPE2(plane, _DSPASURFLIVE)
5997
5998/* CHV pipe B blender and primary plane */
5999#define _CHV_BLEND_A            0x60a00
6000#define   CHV_BLEND_LEGACY              (0<<30)
6001#define   CHV_BLEND_ANDROID             (1<<30)
6002#define   CHV_BLEND_MPO                 (2<<30)
6003#define   CHV_BLEND_MASK                (3<<30)
6004#define _CHV_CANVAS_A           0x60a04
6005#define _PRIMPOS_A              0x60a08
6006#define _PRIMSIZE_A             0x60a0c
6007#define _PRIMCNSTALPHA_A        0x60a10
6008#define   PRIM_CONST_ALPHA_ENABLE       (1<<31)
6009
6010#define CHV_BLEND(pipe)         _MMIO_TRANS2(pipe, _CHV_BLEND_A)
6011#define CHV_CANVAS(pipe)        _MMIO_TRANS2(pipe, _CHV_CANVAS_A)
6012#define PRIMPOS(plane)          _MMIO_TRANS2(plane, _PRIMPOS_A)
6013#define PRIMSIZE(plane)         _MMIO_TRANS2(plane, _PRIMSIZE_A)
6014#define PRIMCNSTALPHA(plane)    _MMIO_TRANS2(plane, _PRIMCNSTALPHA_A)
6015
6016/* Display/Sprite base address macros */
6017#define DISP_BASEADDR_MASK      (0xfffff000)
6018#define I915_LO_DISPBASE(val)   (val & ~DISP_BASEADDR_MASK)
6019#define I915_HI_DISPBASE(val)   (val & DISP_BASEADDR_MASK)
6020
6021/*
6022 * VBIOS flags
6023 * gen2:
6024 * [00:06] alm,mgm
6025 * [10:16] all
6026 * [30:32] alm,mgm
6027 * gen3+:
6028 * [00:0f] all
6029 * [10:1f] all
6030 * [30:32] all
6031 */
6032#define SWF0(i) _MMIO(dev_priv->info.display_mmio_offset + 0x70410 + (i) * 4)
6033#define SWF1(i) _MMIO(dev_priv->info.display_mmio_offset + 0x71410 + (i) * 4)
6034#define SWF3(i) _MMIO(dev_priv->info.display_mmio_offset + 0x72414 + (i) * 4)
6035#define SWF_ILK(i)      _MMIO(0x4F000 + (i) * 4)
6036
6037/* Pipe B */
6038#define _PIPEBDSL               (dev_priv->info.display_mmio_offset + 0x71000)
6039#define _PIPEBCONF              (dev_priv->info.display_mmio_offset + 0x71008)
6040#define _PIPEBSTAT              (dev_priv->info.display_mmio_offset + 0x71024)
6041#define _PIPEBFRAMEHIGH         0x71040
6042#define _PIPEBFRAMEPIXEL        0x71044
6043#define _PIPEB_FRMCOUNT_G4X     (dev_priv->info.display_mmio_offset + 0x71040)
6044#define _PIPEB_FLIPCOUNT_G4X    (dev_priv->info.display_mmio_offset + 0x71044)
6045
6046
6047/* Display B control */
6048#define _DSPBCNTR               (dev_priv->info.display_mmio_offset + 0x71180)
6049#define   DISPPLANE_ALPHA_TRANS_ENABLE          (1<<15)
6050#define   DISPPLANE_ALPHA_TRANS_DISABLE         0
6051#define   DISPPLANE_SPRITE_ABOVE_DISPLAY        0
6052#define   DISPPLANE_SPRITE_ABOVE_OVERLAY        (1)
6053#define _DSPBADDR               (dev_priv->info.display_mmio_offset + 0x71184)
6054#define _DSPBSTRIDE             (dev_priv->info.display_mmio_offset + 0x71188)
6055#define _DSPBPOS                (dev_priv->info.display_mmio_offset + 0x7118C)
6056#define _DSPBSIZE               (dev_priv->info.display_mmio_offset + 0x71190)
6057#define _DSPBSURF               (dev_priv->info.display_mmio_offset + 0x7119C)
6058#define _DSPBTILEOFF            (dev_priv->info.display_mmio_offset + 0x711A4)
6059#define _DSPBOFFSET             (dev_priv->info.display_mmio_offset + 0x711A4)
6060#define _DSPBSURFLIVE           (dev_priv->info.display_mmio_offset + 0x711AC)
6061
6062/* Sprite A control */
6063#define _DVSACNTR               0x72180
6064#define   DVS_ENABLE            (1<<31)
6065#define   DVS_GAMMA_ENABLE      (1<<30)
6066#define   DVS_PIXFORMAT_MASK    (3<<25)
6067#define   DVS_FORMAT_YUV422     (0<<25)
6068#define   DVS_FORMAT_RGBX101010 (1<<25)
6069#define   DVS_FORMAT_RGBX888    (2<<25)
6070#define   DVS_FORMAT_RGBX161616 (3<<25)
6071#define   DVS_PIPE_CSC_ENABLE   (1<<24)
6072#define   DVS_SOURCE_KEY        (1<<22)
6073#define   DVS_RGB_ORDER_XBGR    (1<<20)
6074#define   DVS_YUV_BYTE_ORDER_MASK (3<<16)
6075#define   DVS_YUV_ORDER_YUYV    (0<<16)
6076#define   DVS_YUV_ORDER_UYVY    (1<<16)
6077#define   DVS_YUV_ORDER_YVYU    (2<<16)
6078#define   DVS_YUV_ORDER_VYUY    (3<<16)
6079#define   DVS_ROTATE_180        (1<<15)
6080#define   DVS_DEST_KEY          (1<<2)
6081#define   DVS_TRICKLE_FEED_DISABLE (1<<14)
6082#define   DVS_TILED             (1<<10)
6083#define _DVSALINOFF             0x72184
6084#define _DVSASTRIDE             0x72188
6085#define _DVSAPOS                0x7218c
6086#define _DVSASIZE               0x72190
6087#define _DVSAKEYVAL             0x72194
6088#define _DVSAKEYMSK             0x72198
6089#define _DVSASURF               0x7219c
6090#define _DVSAKEYMAXVAL          0x721a0
6091#define _DVSATILEOFF            0x721a4
6092#define _DVSASURFLIVE           0x721ac
6093#define _DVSASCALE              0x72204
6094#define   DVS_SCALE_ENABLE      (1<<31)
6095#define   DVS_FILTER_MASK       (3<<29)
6096#define   DVS_FILTER_MEDIUM     (0<<29)
6097#define   DVS_FILTER_ENHANCING  (1<<29)
6098#define   DVS_FILTER_SOFTENING  (2<<29)
6099#define   DVS_VERTICAL_OFFSET_HALF (1<<28) /* must be enabled below */
6100#define   DVS_VERTICAL_OFFSET_ENABLE (1<<27)
6101#define _DVSAGAMC               0x72300
6102
6103#define _DVSBCNTR               0x73180
6104#define _DVSBLINOFF             0x73184
6105#define _DVSBSTRIDE             0x73188
6106#define _DVSBPOS                0x7318c
6107#define _DVSBSIZE               0x73190
6108#define _DVSBKEYVAL             0x73194
6109#define _DVSBKEYMSK             0x73198
6110#define _DVSBSURF               0x7319c
6111#define _DVSBKEYMAXVAL          0x731a0
6112#define _DVSBTILEOFF            0x731a4
6113#define _DVSBSURFLIVE           0x731ac
6114#define _DVSBSCALE              0x73204
6115#define _DVSBGAMC               0x73300
6116
6117#define DVSCNTR(pipe) _MMIO_PIPE(pipe, _DVSACNTR, _DVSBCNTR)
6118#define DVSLINOFF(pipe) _MMIO_PIPE(pipe, _DVSALINOFF, _DVSBLINOFF)
6119#define DVSSTRIDE(pipe) _MMIO_PIPE(pipe, _DVSASTRIDE, _DVSBSTRIDE)
6120#define DVSPOS(pipe) _MMIO_PIPE(pipe, _DVSAPOS, _DVSBPOS)
6121#define DVSSURF(pipe) _MMIO_PIPE(pipe, _DVSASURF, _DVSBSURF)
6122#define DVSKEYMAX(pipe) _MMIO_PIPE(pipe, _DVSAKEYMAXVAL, _DVSBKEYMAXVAL)
6123#define DVSSIZE(pipe) _MMIO_PIPE(pipe, _DVSASIZE, _DVSBSIZE)
6124#define DVSSCALE(pipe) _MMIO_PIPE(pipe, _DVSASCALE, _DVSBSCALE)
6125#define DVSTILEOFF(pipe) _MMIO_PIPE(pipe, _DVSATILEOFF, _DVSBTILEOFF)
6126#define DVSKEYVAL(pipe) _MMIO_PIPE(pipe, _DVSAKEYVAL, _DVSBKEYVAL)
6127#define DVSKEYMSK(pipe) _MMIO_PIPE(pipe, _DVSAKEYMSK, _DVSBKEYMSK)
6128#define DVSSURFLIVE(pipe) _MMIO_PIPE(pipe, _DVSASURFLIVE, _DVSBSURFLIVE)
6129
6130#define _SPRA_CTL               0x70280
6131#define   SPRITE_ENABLE                 (1<<31)
6132#define   SPRITE_GAMMA_ENABLE           (1<<30)
6133#define   SPRITE_PIXFORMAT_MASK         (7<<25)
6134#define   SPRITE_FORMAT_YUV422          (0<<25)
6135#define   SPRITE_FORMAT_RGBX101010      (1<<25)
6136#define   SPRITE_FORMAT_RGBX888         (2<<25)
6137#define   SPRITE_FORMAT_RGBX161616      (3<<25)
6138#define   SPRITE_FORMAT_YUV444          (4<<25)
6139#define   SPRITE_FORMAT_XR_BGR101010    (5<<25) /* Extended range */
6140#define   SPRITE_PIPE_CSC_ENABLE        (1<<24)
6141#define   SPRITE_SOURCE_KEY             (1<<22)
6142#define   SPRITE_RGB_ORDER_RGBX         (1<<20) /* only for 888 and 161616 */
6143#define   SPRITE_YUV_TO_RGB_CSC_DISABLE (1<<19)
6144#define   SPRITE_YUV_CSC_FORMAT_BT709   (1<<18) /* 0 is BT601 */
6145#define   SPRITE_YUV_BYTE_ORDER_MASK    (3<<16)
6146#define   SPRITE_YUV_ORDER_YUYV         (0<<16)
6147#define   SPRITE_YUV_ORDER_UYVY         (1<<16)
6148#define   SPRITE_YUV_ORDER_YVYU         (2<<16)
6149#define   SPRITE_YUV_ORDER_VYUY         (3<<16)
6150#define   SPRITE_ROTATE_180             (1<<15)
6151#define   SPRITE_TRICKLE_FEED_DISABLE   (1<<14)
6152#define   SPRITE_INT_GAMMA_ENABLE       (1<<13)
6153#define   SPRITE_TILED                  (1<<10)
6154#define   SPRITE_DEST_KEY               (1<<2)
6155#define _SPRA_LINOFF            0x70284
6156#define _SPRA_STRIDE            0x70288
6157#define _SPRA_POS               0x7028c
6158#define _SPRA_SIZE              0x70290
6159#define _SPRA_KEYVAL            0x70294
6160#define _SPRA_KEYMSK            0x70298
6161#define _SPRA_SURF              0x7029c
6162#define _SPRA_KEYMAX            0x702a0
6163#define _SPRA_TILEOFF           0x702a4
6164#define _SPRA_OFFSET            0x702a4
6165#define _SPRA_SURFLIVE          0x702ac
6166#define _SPRA_SCALE             0x70304
6167#define   SPRITE_SCALE_ENABLE   (1<<31)
6168#define   SPRITE_FILTER_MASK    (3<<29)
6169#define   SPRITE_FILTER_MEDIUM  (0<<29)
6170#define   SPRITE_FILTER_ENHANCING       (1<<29)
6171#define   SPRITE_FILTER_SOFTENING       (2<<29)
6172#define   SPRITE_VERTICAL_OFFSET_HALF   (1<<28) /* must be enabled below */
6173#define   SPRITE_VERTICAL_OFFSET_ENABLE (1<<27)
6174#define _SPRA_GAMC              0x70400
6175
6176#define _SPRB_CTL               0x71280
6177#define _SPRB_LINOFF            0x71284
6178#define _SPRB_STRIDE            0x71288
6179#define _SPRB_POS               0x7128c
6180#define _SPRB_SIZE              0x71290
6181#define _SPRB_KEYVAL            0x71294
6182#define _SPRB_KEYMSK            0x71298
6183#define _SPRB_SURF              0x7129c
6184#define _SPRB_KEYMAX            0x712a0
6185#define _SPRB_TILEOFF           0x712a4
6186#define _SPRB_OFFSET            0x712a4
6187#define _SPRB_SURFLIVE          0x712ac
6188#define _SPRB_SCALE             0x71304
6189#define _SPRB_GAMC              0x71400
6190
6191#define SPRCTL(pipe) _MMIO_PIPE(pipe, _SPRA_CTL, _SPRB_CTL)
6192#define SPRLINOFF(pipe) _MMIO_PIPE(pipe, _SPRA_LINOFF, _SPRB_LINOFF)
6193#define SPRSTRIDE(pipe) _MMIO_PIPE(pipe, _SPRA_STRIDE, _SPRB_STRIDE)
6194#define SPRPOS(pipe) _MMIO_PIPE(pipe, _SPRA_POS, _SPRB_POS)
6195#define SPRSIZE(pipe) _MMIO_PIPE(pipe, _SPRA_SIZE, _SPRB_SIZE)
6196#define SPRKEYVAL(pipe) _MMIO_PIPE(pipe, _SPRA_KEYVAL, _SPRB_KEYVAL)
6197#define SPRKEYMSK(pipe) _MMIO_PIPE(pipe, _SPRA_KEYMSK, _SPRB_KEYMSK)
6198#define SPRSURF(pipe) _MMIO_PIPE(pipe, _SPRA_SURF, _SPRB_SURF)
6199#define SPRKEYMAX(pipe) _MMIO_PIPE(pipe, _SPRA_KEYMAX, _SPRB_KEYMAX)
6200#define SPRTILEOFF(pipe) _MMIO_PIPE(pipe, _SPRA_TILEOFF, _SPRB_TILEOFF)
6201#define SPROFFSET(pipe) _MMIO_PIPE(pipe, _SPRA_OFFSET, _SPRB_OFFSET)
6202#define SPRSCALE(pipe) _MMIO_PIPE(pipe, _SPRA_SCALE, _SPRB_SCALE)
6203#define SPRGAMC(pipe) _MMIO_PIPE(pipe, _SPRA_GAMC, _SPRB_GAMC)
6204#define SPRSURFLIVE(pipe) _MMIO_PIPE(pipe, _SPRA_SURFLIVE, _SPRB_SURFLIVE)
6205
6206#define _SPACNTR                (VLV_DISPLAY_BASE + 0x72180)
6207#define   SP_ENABLE                     (1<<31)
6208#define   SP_GAMMA_ENABLE               (1<<30)
6209#define   SP_PIXFORMAT_MASK             (0xf<<26)
6210#define   SP_FORMAT_YUV422              (0<<26)
6211#define   SP_FORMAT_BGR565              (5<<26)
6212#define   SP_FORMAT_BGRX8888            (6<<26)
6213#define   SP_FORMAT_BGRA8888            (7<<26)
6214#define   SP_FORMAT_RGBX1010102         (8<<26)
6215#define   SP_FORMAT_RGBA1010102         (9<<26)
6216#define   SP_FORMAT_RGBX8888            (0xe<<26)
6217#define   SP_FORMAT_RGBA8888            (0xf<<26)
6218#define   SP_ALPHA_PREMULTIPLY          (1<<23) /* CHV pipe B */
6219#define   SP_SOURCE_KEY                 (1<<22)
6220#define   SP_YUV_BYTE_ORDER_MASK        (3<<16)
6221#define   SP_YUV_ORDER_YUYV             (0<<16)
6222#define   SP_YUV_ORDER_UYVY             (1<<16)
6223#define   SP_YUV_ORDER_YVYU             (2<<16)
6224#define   SP_YUV_ORDER_VYUY             (3<<16)
6225#define   SP_ROTATE_180                 (1<<15)
6226#define   SP_TILED                      (1<<10)
6227#define   SP_MIRROR                     (1<<8) /* CHV pipe B */
6228#define _SPALINOFF              (VLV_DISPLAY_BASE + 0x72184)
6229#define _SPASTRIDE              (VLV_DISPLAY_BASE + 0x72188)
6230#define _SPAPOS                 (VLV_DISPLAY_BASE + 0x7218c)
6231#define _SPASIZE                (VLV_DISPLAY_BASE + 0x72190)
6232#define _SPAKEYMINVAL           (VLV_DISPLAY_BASE + 0x72194)
6233#define _SPAKEYMSK              (VLV_DISPLAY_BASE + 0x72198)
6234#define _SPASURF                (VLV_DISPLAY_BASE + 0x7219c)
6235#define _SPAKEYMAXVAL           (VLV_DISPLAY_BASE + 0x721a0)
6236#define _SPATILEOFF             (VLV_DISPLAY_BASE + 0x721a4)
6237#define _SPACONSTALPHA          (VLV_DISPLAY_BASE + 0x721a8)
6238#define   SP_CONST_ALPHA_ENABLE         (1<<31)
6239#define _SPAGAMC                (VLV_DISPLAY_BASE + 0x721f4)
6240
6241#define _SPBCNTR                (VLV_DISPLAY_BASE + 0x72280)
6242#define _SPBLINOFF              (VLV_DISPLAY_BASE + 0x72284)
6243#define _SPBSTRIDE              (VLV_DISPLAY_BASE + 0x72288)
6244#define _SPBPOS                 (VLV_DISPLAY_BASE + 0x7228c)
6245#define _SPBSIZE                (VLV_DISPLAY_BASE + 0x72290)
6246#define _SPBKEYMINVAL           (VLV_DISPLAY_BASE + 0x72294)
6247#define _SPBKEYMSK              (VLV_DISPLAY_BASE + 0x72298)
6248#define _SPBSURF                (VLV_DISPLAY_BASE + 0x7229c)
6249#define _SPBKEYMAXVAL           (VLV_DISPLAY_BASE + 0x722a0)
6250#define _SPBTILEOFF             (VLV_DISPLAY_BASE + 0x722a4)
6251#define _SPBCONSTALPHA          (VLV_DISPLAY_BASE + 0x722a8)
6252#define _SPBGAMC                (VLV_DISPLAY_BASE + 0x722f4)
6253
6254#define _MMIO_VLV_SPR(pipe, plane_id, reg_a, reg_b) \
6255        _MMIO_PIPE((pipe) * 2 + (plane_id) - PLANE_SPRITE0, (reg_a), (reg_b))
6256
6257#define SPCNTR(pipe, plane_id)          _MMIO_VLV_SPR((pipe), (plane_id), _SPACNTR, _SPBCNTR)
6258#define SPLINOFF(pipe, plane_id)        _MMIO_VLV_SPR((pipe), (plane_id), _SPALINOFF, _SPBLINOFF)
6259#define SPSTRIDE(pipe, plane_id)        _MMIO_VLV_SPR((pipe), (plane_id), _SPASTRIDE, _SPBSTRIDE)
6260#define SPPOS(pipe, plane_id)           _MMIO_VLV_SPR((pipe), (plane_id), _SPAPOS, _SPBPOS)
6261#define SPSIZE(pipe, plane_id)          _MMIO_VLV_SPR((pipe), (plane_id), _SPASIZE, _SPBSIZE)
6262#define SPKEYMINVAL(pipe, plane_id)     _MMIO_VLV_SPR((pipe), (plane_id), _SPAKEYMINVAL, _SPBKEYMINVAL)
6263#define SPKEYMSK(pipe, plane_id)        _MMIO_VLV_SPR((pipe), (plane_id), _SPAKEYMSK, _SPBKEYMSK)
6264#define SPSURF(pipe, plane_id)          _MMIO_VLV_SPR((pipe), (plane_id), _SPASURF, _SPBSURF)
6265#define SPKEYMAXVAL(pipe, plane_id)     _MMIO_VLV_SPR((pipe), (plane_id), _SPAKEYMAXVAL, _SPBKEYMAXVAL)
6266#define SPTILEOFF(pipe, plane_id)       _MMIO_VLV_SPR((pipe), (plane_id), _SPATILEOFF, _SPBTILEOFF)
6267#define SPCONSTALPHA(pipe, plane_id)    _MMIO_VLV_SPR((pipe), (plane_id), _SPACONSTALPHA, _SPBCONSTALPHA)
6268#define SPGAMC(pipe, plane_id)          _MMIO_VLV_SPR((pipe), (plane_id), _SPAGAMC, _SPBGAMC)
6269
6270/*
6271 * CHV pipe B sprite CSC
6272 *
6273 * |cr|   |c0 c1 c2|   |cr + cr_ioff|   |cr_ooff|
6274 * |yg| = |c3 c4 c5| x |yg + yg_ioff| + |yg_ooff|
6275 * |cb|   |c6 c7 c8|   |cb + cr_ioff|   |cb_ooff|
6276 */
6277#define _MMIO_CHV_SPCSC(plane_id, reg) \
6278        _MMIO(VLV_DISPLAY_BASE + ((plane_id) - PLANE_SPRITE0) * 0x1000 + (reg))
6279
6280#define SPCSCYGOFF(plane_id)    _MMIO_CHV_SPCSC(plane_id, 0x6d900)
6281#define SPCSCCBOFF(plane_id)    _MMIO_CHV_SPCSC(plane_id, 0x6d904)
6282#define SPCSCCROFF(plane_id)    _MMIO_CHV_SPCSC(plane_id, 0x6d908)
6283#define  SPCSC_OOFF(x)          (((x) & 0x7ff) << 16) /* s11 */
6284#define  SPCSC_IOFF(x)          (((x) & 0x7ff) << 0) /* s11 */
6285
6286#define SPCSCC01(plane_id)      _MMIO_CHV_SPCSC(plane_id, 0x6d90c)
6287#define SPCSCC23(plane_id)      _MMIO_CHV_SPCSC(plane_id, 0x6d910)
6288#define SPCSCC45(plane_id)      _MMIO_CHV_SPCSC(plane_id, 0x6d914)
6289#define SPCSCC67(plane_id)      _MMIO_CHV_SPCSC(plane_id, 0x6d918)
6290#define SPCSCC8(plane_id)       _MMIO_CHV_SPCSC(plane_id, 0x6d91c)
6291#define  SPCSC_C1(x)            (((x) & 0x7fff) << 16) /* s3.12 */
6292#define  SPCSC_C0(x)            (((x) & 0x7fff) << 0) /* s3.12 */
6293
6294#define SPCSCYGICLAMP(plane_id) _MMIO_CHV_SPCSC(plane_id, 0x6d920)
6295#define SPCSCCBICLAMP(plane_id) _MMIO_CHV_SPCSC(plane_id, 0x6d924)
6296#define SPCSCCRICLAMP(plane_id) _MMIO_CHV_SPCSC(plane_id, 0x6d928)
6297#define  SPCSC_IMAX(x)          (((x) & 0x7ff) << 16) /* s11 */
6298#define  SPCSC_IMIN(x)          (((x) & 0x7ff) << 0) /* s11 */
6299
6300#define SPCSCYGOCLAMP(plane_id) _MMIO_CHV_SPCSC(plane_id, 0x6d92c)
6301#define SPCSCCBOCLAMP(plane_id) _MMIO_CHV_SPCSC(plane_id, 0x6d930)
6302#define SPCSCCROCLAMP(plane_id) _MMIO_CHV_SPCSC(plane_id, 0x6d934)
6303#define  SPCSC_OMAX(x)          ((x) << 16) /* u10 */
6304#define  SPCSC_OMIN(x)          ((x) << 0) /* u10 */
6305
6306/* Skylake plane registers */
6307
6308#define _PLANE_CTL_1_A                          0x70180
6309#define _PLANE_CTL_2_A                          0x70280
6310#define _PLANE_CTL_3_A                          0x70380
6311#define   PLANE_CTL_ENABLE                      (1 << 31)
6312#define   PLANE_CTL_PIPE_GAMMA_ENABLE           (1 << 30)   /* Pre-GLK */
6313#define   PLANE_CTL_FORMAT_MASK                 (0xf << 24)
6314#define   PLANE_CTL_FORMAT_YUV422               (  0 << 24)
6315#define   PLANE_CTL_FORMAT_NV12                 (  1 << 24)
6316#define   PLANE_CTL_FORMAT_XRGB_2101010         (  2 << 24)
6317#define   PLANE_CTL_FORMAT_XRGB_8888            (  4 << 24)
6318#define   PLANE_CTL_FORMAT_XRGB_16161616F       (  6 << 24)
6319#define   PLANE_CTL_FORMAT_AYUV                 (  8 << 24)
6320#define   PLANE_CTL_FORMAT_INDEXED              ( 12 << 24)
6321#define   PLANE_CTL_FORMAT_RGB_565              ( 14 << 24)
6322#define   PLANE_CTL_PIPE_CSC_ENABLE             (1 << 23) /* Pre-GLK */
6323#define   PLANE_CTL_KEY_ENABLE_MASK             (0x3 << 21)
6324#define   PLANE_CTL_KEY_ENABLE_SOURCE           (  1 << 21)
6325#define   PLANE_CTL_KEY_ENABLE_DESTINATION      (  2 << 21)
6326#define   PLANE_CTL_ORDER_BGRX                  (0 << 20)
6327#define   PLANE_CTL_ORDER_RGBX                  (1 << 20)
6328#define   PLANE_CTL_YUV422_ORDER_MASK           (0x3 << 16)
6329#define   PLANE_CTL_YUV422_YUYV                 (  0 << 16)
6330#define   PLANE_CTL_YUV422_UYVY                 (  1 << 16)
6331#define   PLANE_CTL_YUV422_YVYU                 (  2 << 16)
6332#define   PLANE_CTL_YUV422_VYUY                 (  3 << 16)
6333#define   PLANE_CTL_DECOMPRESSION_ENABLE        (1 << 15)
6334#define   PLANE_CTL_TRICKLE_FEED_DISABLE        (1 << 14)
6335#define   PLANE_CTL_PLANE_GAMMA_DISABLE         (1 << 13) /* Pre-GLK */
6336#define   PLANE_CTL_TILED_MASK                  (0x7 << 10)
6337#define   PLANE_CTL_TILED_LINEAR                (  0 << 10)
6338#define   PLANE_CTL_TILED_X                     (  1 << 10)
6339#define   PLANE_CTL_TILED_Y                     (  4 << 10)
6340#define   PLANE_CTL_TILED_YF                    (  5 << 10)
6341#define   PLANE_CTL_FLIP_HORIZONTAL             (  1 << 8)
6342#define   PLANE_CTL_ALPHA_MASK                  (0x3 << 4) /* Pre-GLK */
6343#define   PLANE_CTL_ALPHA_DISABLE               (  0 << 4)
6344#define   PLANE_CTL_ALPHA_SW_PREMULTIPLY        (  2 << 4)
6345#define   PLANE_CTL_ALPHA_HW_PREMULTIPLY        (  3 << 4)
6346#define   PLANE_CTL_ROTATE_MASK                 0x3
6347#define   PLANE_CTL_ROTATE_0                    0x0
6348#define   PLANE_CTL_ROTATE_90                   0x1
6349#define   PLANE_CTL_ROTATE_180                  0x2
6350#define   PLANE_CTL_ROTATE_270                  0x3
6351#define _PLANE_STRIDE_1_A                       0x70188
6352#define _PLANE_STRIDE_2_A                       0x70288
6353#define _PLANE_STRIDE_3_A                       0x70388
6354#define _PLANE_POS_1_A                          0x7018c
6355#define _PLANE_POS_2_A                          0x7028c
6356#define _PLANE_POS_3_A                          0x7038c
6357#define _PLANE_SIZE_1_A                         0x70190
6358#define _PLANE_SIZE_2_A                         0x70290
6359#define _PLANE_SIZE_3_A                         0x70390
6360#define _PLANE_SURF_1_A                         0x7019c
6361#define _PLANE_SURF_2_A                         0x7029c
6362#define _PLANE_SURF_3_A                         0x7039c
6363#define _PLANE_OFFSET_1_A                       0x701a4
6364#define _PLANE_OFFSET_2_A                       0x702a4
6365#define _PLANE_OFFSET_3_A                       0x703a4
6366#define _PLANE_KEYVAL_1_A                       0x70194
6367#define _PLANE_KEYVAL_2_A                       0x70294
6368#define _PLANE_KEYMSK_1_A                       0x70198
6369#define _PLANE_KEYMSK_2_A                       0x70298
6370#define _PLANE_KEYMAX_1_A                       0x701a0
6371#define _PLANE_KEYMAX_2_A                       0x702a0
6372#define _PLANE_AUX_DIST_1_A                     0x701c0
6373#define _PLANE_AUX_DIST_2_A                     0x702c0
6374#define _PLANE_AUX_OFFSET_1_A                   0x701c4
6375#define _PLANE_AUX_OFFSET_2_A                   0x702c4
6376#define _PLANE_COLOR_CTL_1_A                    0x701CC /* GLK+ */
6377#define _PLANE_COLOR_CTL_2_A                    0x702CC /* GLK+ */
6378#define _PLANE_COLOR_CTL_3_A                    0x703CC /* GLK+ */
6379#define   PLANE_COLOR_PIPE_GAMMA_ENABLE         (1 << 30)
6380#define   PLANE_COLOR_PIPE_CSC_ENABLE           (1 << 23)
6381#define   PLANE_COLOR_PLANE_GAMMA_DISABLE       (1 << 13)
6382#define   PLANE_COLOR_ALPHA_MASK                (0x3 << 4)
6383#define   PLANE_COLOR_ALPHA_DISABLE             (0 << 4)
6384#define   PLANE_COLOR_ALPHA_SW_PREMULTIPLY      (2 << 4)
6385#define   PLANE_COLOR_ALPHA_HW_PREMULTIPLY      (3 << 4)
6386#define _PLANE_BUF_CFG_1_A                      0x7027c
6387#define _PLANE_BUF_CFG_2_A                      0x7037c
6388#define _PLANE_NV12_BUF_CFG_1_A         0x70278
6389#define _PLANE_NV12_BUF_CFG_2_A         0x70378
6390
6391
6392#define _PLANE_CTL_1_B                          0x71180
6393#define _PLANE_CTL_2_B                          0x71280
6394#define _PLANE_CTL_3_B                          0x71380
6395#define _PLANE_CTL_1(pipe)      _PIPE(pipe, _PLANE_CTL_1_A, _PLANE_CTL_1_B)
6396#define _PLANE_CTL_2(pipe)      _PIPE(pipe, _PLANE_CTL_2_A, _PLANE_CTL_2_B)
6397#define _PLANE_CTL_3(pipe)      _PIPE(pipe, _PLANE_CTL_3_A, _PLANE_CTL_3_B)
6398#define PLANE_CTL(pipe, plane)  \
6399        _MMIO_PLANE(plane, _PLANE_CTL_1(pipe), _PLANE_CTL_2(pipe))
6400
6401#define _PLANE_STRIDE_1_B                       0x71188
6402#define _PLANE_STRIDE_2_B                       0x71288
6403#define _PLANE_STRIDE_3_B                       0x71388
6404#define _PLANE_STRIDE_1(pipe)   \
6405        _PIPE(pipe, _PLANE_STRIDE_1_A, _PLANE_STRIDE_1_B)
6406#define _PLANE_STRIDE_2(pipe)   \
6407        _PIPE(pipe, _PLANE_STRIDE_2_A, _PLANE_STRIDE_2_B)
6408#define _PLANE_STRIDE_3(pipe)   \
6409        _PIPE(pipe, _PLANE_STRIDE_3_A, _PLANE_STRIDE_3_B)
6410#define PLANE_STRIDE(pipe, plane)       \
6411        _MMIO_PLANE(plane, _PLANE_STRIDE_1(pipe), _PLANE_STRIDE_2(pipe))
6412
6413#define _PLANE_POS_1_B                          0x7118c
6414#define _PLANE_POS_2_B                          0x7128c
6415#define _PLANE_POS_3_B                          0x7138c
6416#define _PLANE_POS_1(pipe)      _PIPE(pipe, _PLANE_POS_1_A, _PLANE_POS_1_B)
6417#define _PLANE_POS_2(pipe)      _PIPE(pipe, _PLANE_POS_2_A, _PLANE_POS_2_B)
6418#define _PLANE_POS_3(pipe)      _PIPE(pipe, _PLANE_POS_3_A, _PLANE_POS_3_B)
6419#define PLANE_POS(pipe, plane)  \
6420        _MMIO_PLANE(plane, _PLANE_POS_1(pipe), _PLANE_POS_2(pipe))
6421
6422#define _PLANE_SIZE_1_B                         0x71190
6423#define _PLANE_SIZE_2_B                         0x71290
6424#define _PLANE_SIZE_3_B                         0x71390
6425#define _PLANE_SIZE_1(pipe)     _PIPE(pipe, _PLANE_SIZE_1_A, _PLANE_SIZE_1_B)
6426#define _PLANE_SIZE_2(pipe)     _PIPE(pipe, _PLANE_SIZE_2_A, _PLANE_SIZE_2_B)
6427#define _PLANE_SIZE_3(pipe)     _PIPE(pipe, _PLANE_SIZE_3_A, _PLANE_SIZE_3_B)
6428#define PLANE_SIZE(pipe, plane) \
6429        _MMIO_PLANE(plane, _PLANE_SIZE_1(pipe), _PLANE_SIZE_2(pipe))
6430
6431#define _PLANE_SURF_1_B                         0x7119c
6432#define _PLANE_SURF_2_B                         0x7129c
6433#define _PLANE_SURF_3_B                         0x7139c
6434#define _PLANE_SURF_1(pipe)     _PIPE(pipe, _PLANE_SURF_1_A, _PLANE_SURF_1_B)
6435#define _PLANE_SURF_2(pipe)     _PIPE(pipe, _PLANE_SURF_2_A, _PLANE_SURF_2_B)
6436#define _PLANE_SURF_3(pipe)     _PIPE(pipe, _PLANE_SURF_3_A, _PLANE_SURF_3_B)
6437#define PLANE_SURF(pipe, plane) \
6438        _MMIO_PLANE(plane, _PLANE_SURF_1(pipe), _PLANE_SURF_2(pipe))
6439
6440#define _PLANE_OFFSET_1_B                       0x711a4
6441#define _PLANE_OFFSET_2_B                       0x712a4
6442#define _PLANE_OFFSET_1(pipe) _PIPE(pipe, _PLANE_OFFSET_1_A, _PLANE_OFFSET_1_B)
6443#define _PLANE_OFFSET_2(pipe) _PIPE(pipe, _PLANE_OFFSET_2_A, _PLANE_OFFSET_2_B)
6444#define PLANE_OFFSET(pipe, plane)       \
6445        _MMIO_PLANE(plane, _PLANE_OFFSET_1(pipe), _PLANE_OFFSET_2(pipe))
6446
6447#define _PLANE_KEYVAL_1_B                       0x71194
6448#define _PLANE_KEYVAL_2_B                       0x71294
6449#define _PLANE_KEYVAL_1(pipe) _PIPE(pipe, _PLANE_KEYVAL_1_A, _PLANE_KEYVAL_1_B)
6450#define _PLANE_KEYVAL_2(pipe) _PIPE(pipe, _PLANE_KEYVAL_2_A, _PLANE_KEYVAL_2_B)
6451#define PLANE_KEYVAL(pipe, plane)       \
6452        _MMIO_PLANE(plane, _PLANE_KEYVAL_1(pipe), _PLANE_KEYVAL_2(pipe))
6453
6454#define _PLANE_KEYMSK_1_B                       0x71198
6455#define _PLANE_KEYMSK_2_B                       0x71298
6456#define _PLANE_KEYMSK_1(pipe) _PIPE(pipe, _PLANE_KEYMSK_1_A, _PLANE_KEYMSK_1_B)
6457#define _PLANE_KEYMSK_2(pipe) _PIPE(pipe, _PLANE_KEYMSK_2_A, _PLANE_KEYMSK_2_B)
6458#define PLANE_KEYMSK(pipe, plane)       \
6459        _MMIO_PLANE(plane, _PLANE_KEYMSK_1(pipe), _PLANE_KEYMSK_2(pipe))
6460
6461#define _PLANE_KEYMAX_1_B                       0x711a0
6462#define _PLANE_KEYMAX_2_B                       0x712a0
6463#define _PLANE_KEYMAX_1(pipe) _PIPE(pipe, _PLANE_KEYMAX_1_A, _PLANE_KEYMAX_1_B)
6464#define _PLANE_KEYMAX_2(pipe) _PIPE(pipe, _PLANE_KEYMAX_2_A, _PLANE_KEYMAX_2_B)
6465#define PLANE_KEYMAX(pipe, plane)       \
6466        _MMIO_PLANE(plane, _PLANE_KEYMAX_1(pipe), _PLANE_KEYMAX_2(pipe))
6467
6468#define _PLANE_BUF_CFG_1_B                      0x7127c
6469#define _PLANE_BUF_CFG_2_B                      0x7137c
6470#define _PLANE_BUF_CFG_1(pipe)  \
6471        _PIPE(pipe, _PLANE_BUF_CFG_1_A, _PLANE_BUF_CFG_1_B)
6472#define _PLANE_BUF_CFG_2(pipe)  \
6473        _PIPE(pipe, _PLANE_BUF_CFG_2_A, _PLANE_BUF_CFG_2_B)
6474#define PLANE_BUF_CFG(pipe, plane)      \
6475        _MMIO_PLANE(plane, _PLANE_BUF_CFG_1(pipe), _PLANE_BUF_CFG_2(pipe))
6476
6477#define _PLANE_NV12_BUF_CFG_1_B         0x71278
6478#define _PLANE_NV12_BUF_CFG_2_B         0x71378
6479#define _PLANE_NV12_BUF_CFG_1(pipe)     \
6480        _PIPE(pipe, _PLANE_NV12_BUF_CFG_1_A, _PLANE_NV12_BUF_CFG_1_B)
6481#define _PLANE_NV12_BUF_CFG_2(pipe)     \
6482        _PIPE(pipe, _PLANE_NV12_BUF_CFG_2_A, _PLANE_NV12_BUF_CFG_2_B)
6483#define PLANE_NV12_BUF_CFG(pipe, plane) \
6484        _MMIO_PLANE(plane, _PLANE_NV12_BUF_CFG_1(pipe), _PLANE_NV12_BUF_CFG_2(pipe))
6485
6486#define _PLANE_AUX_DIST_1_B             0x711c0
6487#define _PLANE_AUX_DIST_2_B             0x712c0
6488#define _PLANE_AUX_DIST_1(pipe) \
6489                        _PIPE(pipe, _PLANE_AUX_DIST_1_A, _PLANE_AUX_DIST_1_B)
6490#define _PLANE_AUX_DIST_2(pipe) \
6491                        _PIPE(pipe, _PLANE_AUX_DIST_2_A, _PLANE_AUX_DIST_2_B)
6492#define PLANE_AUX_DIST(pipe, plane)     \
6493        _MMIO_PLANE(plane, _PLANE_AUX_DIST_1(pipe), _PLANE_AUX_DIST_2(pipe))
6494
6495#define _PLANE_AUX_OFFSET_1_B           0x711c4
6496#define _PLANE_AUX_OFFSET_2_B           0x712c4
6497#define _PLANE_AUX_OFFSET_1(pipe)       \
6498                _PIPE(pipe, _PLANE_AUX_OFFSET_1_A, _PLANE_AUX_OFFSET_1_B)
6499#define _PLANE_AUX_OFFSET_2(pipe)       \
6500                _PIPE(pipe, _PLANE_AUX_OFFSET_2_A, _PLANE_AUX_OFFSET_2_B)
6501#define PLANE_AUX_OFFSET(pipe, plane)   \
6502        _MMIO_PLANE(plane, _PLANE_AUX_OFFSET_1(pipe), _PLANE_AUX_OFFSET_2(pipe))
6503
6504#define _PLANE_COLOR_CTL_1_B                    0x711CC
6505#define _PLANE_COLOR_CTL_2_B                    0x712CC
6506#define _PLANE_COLOR_CTL_3_B                    0x713CC
6507#define _PLANE_COLOR_CTL_1(pipe)        \
6508        _PIPE(pipe, _PLANE_COLOR_CTL_1_A, _PLANE_COLOR_CTL_1_B)
6509#define _PLANE_COLOR_CTL_2(pipe)        \
6510        _PIPE(pipe, _PLANE_COLOR_CTL_2_A, _PLANE_COLOR_CTL_2_B)
6511#define PLANE_COLOR_CTL(pipe, plane)    \
6512        _MMIO_PLANE(plane, _PLANE_COLOR_CTL_1(pipe), _PLANE_COLOR_CTL_2(pipe))
6513
6514#/* SKL new cursor registers */
6515#define _CUR_BUF_CFG_A                          0x7017c
6516#define _CUR_BUF_CFG_B                          0x7117c
6517#define CUR_BUF_CFG(pipe)       _MMIO_PIPE(pipe, _CUR_BUF_CFG_A, _CUR_BUF_CFG_B)
6518
6519/* VBIOS regs */
6520#define VGACNTRL                _MMIO(0x71400)
6521# define VGA_DISP_DISABLE                       (1 << 31)
6522# define VGA_2X_MODE                            (1 << 30)
6523# define VGA_PIPE_B_SELECT                      (1 << 29)
6524
6525#define VLV_VGACNTRL            _MMIO(VLV_DISPLAY_BASE + 0x71400)
6526
6527/* Ironlake */
6528
6529#define CPU_VGACNTRL    _MMIO(0x41000)
6530
6531#define DIGITAL_PORT_HOTPLUG_CNTRL      _MMIO(0x44030)
6532#define  DIGITAL_PORTA_HOTPLUG_ENABLE           (1 << 4)
6533#define  DIGITAL_PORTA_PULSE_DURATION_2ms       (0 << 2) /* pre-HSW */
6534#define  DIGITAL_PORTA_PULSE_DURATION_4_5ms     (1 << 2) /* pre-HSW */
6535#define  DIGITAL_PORTA_PULSE_DURATION_6ms       (2 << 2) /* pre-HSW */
6536#define  DIGITAL_PORTA_PULSE_DURATION_100ms     (3 << 2) /* pre-HSW */
6537#define  DIGITAL_PORTA_PULSE_DURATION_MASK      (3 << 2) /* pre-HSW */
6538#define  DIGITAL_PORTA_HOTPLUG_STATUS_MASK      (3 << 0)
6539#define  DIGITAL_PORTA_HOTPLUG_NO_DETECT        (0 << 0)
6540#define  DIGITAL_PORTA_HOTPLUG_SHORT_DETECT     (1 << 0)
6541#define  DIGITAL_PORTA_HOTPLUG_LONG_DETECT      (2 << 0)
6542
6543/* refresh rate hardware control */
6544#define RR_HW_CTL       _MMIO(0x45300)
6545#define  RR_HW_LOW_POWER_FRAMES_MASK    0xff
6546#define  RR_HW_HIGH_POWER_FRAMES_MASK   0xff00
6547
6548#define FDI_PLL_BIOS_0  _MMIO(0x46000)
6549#define  FDI_PLL_FB_CLOCK_MASK  0xff
6550#define FDI_PLL_BIOS_1  _MMIO(0x46004)
6551#define FDI_PLL_BIOS_2  _MMIO(0x46008)
6552#define DISPLAY_PORT_PLL_BIOS_0         _MMIO(0x4600c)
6553#define DISPLAY_PORT_PLL_BIOS_1         _MMIO(0x46010)
6554#define DISPLAY_PORT_PLL_BIOS_2         _MMIO(0x46014)
6555
6556#define PCH_3DCGDIS0            _MMIO(0x46020)
6557# define MARIUNIT_CLOCK_GATE_DISABLE            (1 << 18)
6558# define SVSMUNIT_CLOCK_GATE_DISABLE            (1 << 1)
6559
6560#define PCH_3DCGDIS1            _MMIO(0x46024)
6561# define VFMUNIT_CLOCK_GATE_DISABLE             (1 << 11)
6562
6563#define FDI_PLL_FREQ_CTL        _MMIO(0x46030)
6564#define  FDI_PLL_FREQ_CHANGE_REQUEST    (1<<24)
6565#define  FDI_PLL_FREQ_LOCK_LIMIT_MASK   0xfff00
6566#define  FDI_PLL_FREQ_DISABLE_COUNT_LIMIT_MASK  0xff
6567
6568
6569#define _PIPEA_DATA_M1          0x60030
6570#define  PIPE_DATA_M1_OFFSET    0
6571#define _PIPEA_DATA_N1          0x60034
6572#define  PIPE_DATA_N1_OFFSET    0
6573
6574#define _PIPEA_DATA_M2          0x60038
6575#define  PIPE_DATA_M2_OFFSET    0
6576#define _PIPEA_DATA_N2          0x6003c
6577#define  PIPE_DATA_N2_OFFSET    0
6578
6579#define _PIPEA_LINK_M1          0x60040
6580#define  PIPE_LINK_M1_OFFSET    0
6581#define _PIPEA_LINK_N1          0x60044
6582#define  PIPE_LINK_N1_OFFSET    0
6583
6584#define _PIPEA_LINK_M2          0x60048
6585#define  PIPE_LINK_M2_OFFSET    0
6586#define _PIPEA_LINK_N2          0x6004c
6587#define  PIPE_LINK_N2_OFFSET    0
6588
6589/* PIPEB timing regs are same start from 0x61000 */
6590
6591#define _PIPEB_DATA_M1          0x61030
6592#define _PIPEB_DATA_N1          0x61034
6593#define _PIPEB_DATA_M2          0x61038
6594#define _PIPEB_DATA_N2          0x6103c
6595#define _PIPEB_LINK_M1          0x61040
6596#define _PIPEB_LINK_N1          0x61044
6597#define _PIPEB_LINK_M2          0x61048
6598#define _PIPEB_LINK_N2          0x6104c
6599
6600#define PIPE_DATA_M1(tran) _MMIO_TRANS2(tran, _PIPEA_DATA_M1)
6601#define PIPE_DATA_N1(tran) _MMIO_TRANS2(tran, _PIPEA_DATA_N1)
6602#define PIPE_DATA_M2(tran) _MMIO_TRANS2(tran, _PIPEA_DATA_M2)
6603#define PIPE_DATA_N2(tran) _MMIO_TRANS2(tran, _PIPEA_DATA_N2)
6604#define PIPE_LINK_M1(tran) _MMIO_TRANS2(tran, _PIPEA_LINK_M1)
6605#define PIPE_LINK_N1(tran) _MMIO_TRANS2(tran, _PIPEA_LINK_N1)
6606#define PIPE_LINK_M2(tran) _MMIO_TRANS2(tran, _PIPEA_LINK_M2)
6607#define PIPE_LINK_N2(tran) _MMIO_TRANS2(tran, _PIPEA_LINK_N2)
6608
6609/* CPU panel fitter */
6610/* IVB+ has 3 fitters, 0 is 7x5 capable, the other two only 3x3 */
6611#define _PFA_CTL_1               0x68080
6612#define _PFB_CTL_1               0x68880
6613#define  PF_ENABLE              (1<<31)
6614#define  PF_PIPE_SEL_MASK_IVB   (3<<29)
6615#define  PF_PIPE_SEL_IVB(pipe)  ((pipe)<<29)
6616#define  PF_FILTER_MASK         (3<<23)
6617#define  PF_FILTER_PROGRAMMED   (0<<23)
6618#define  PF_FILTER_MED_3x3      (1<<23)
6619#define  PF_FILTER_EDGE_ENHANCE (2<<23)
6620#define  PF_FILTER_EDGE_SOFTEN  (3<<23)
6621#define _PFA_WIN_SZ             0x68074
6622#define _PFB_WIN_SZ             0x68874
6623#define _PFA_WIN_POS            0x68070
6624#define _PFB_WIN_POS            0x68870
6625#define _PFA_VSCALE             0x68084
6626#define _PFB_VSCALE             0x68884
6627#define _PFA_HSCALE             0x68090
6628#define _PFB_HSCALE             0x68890
6629
6630#define PF_CTL(pipe)            _MMIO_PIPE(pipe, _PFA_CTL_1, _PFB_CTL_1)
6631#define PF_WIN_SZ(pipe)         _MMIO_PIPE(pipe, _PFA_WIN_SZ, _PFB_WIN_SZ)
6632#define PF_WIN_POS(pipe)        _MMIO_PIPE(pipe, _PFA_WIN_POS, _PFB_WIN_POS)
6633#define PF_VSCALE(pipe)         _MMIO_PIPE(pipe, _PFA_VSCALE, _PFB_VSCALE)
6634#define PF_HSCALE(pipe)         _MMIO_PIPE(pipe, _PFA_HSCALE, _PFB_HSCALE)
6635
6636#define _PSA_CTL                0x68180
6637#define _PSB_CTL                0x68980
6638#define PS_ENABLE               (1<<31)
6639#define _PSA_WIN_SZ             0x68174
6640#define _PSB_WIN_SZ             0x68974
6641#define _PSA_WIN_POS            0x68170
6642#define _PSB_WIN_POS            0x68970
6643
6644#define PS_CTL(pipe)            _MMIO_PIPE(pipe, _PSA_CTL, _PSB_CTL)
6645#define PS_WIN_SZ(pipe)         _MMIO_PIPE(pipe, _PSA_WIN_SZ, _PSB_WIN_SZ)
6646#define PS_WIN_POS(pipe)        _MMIO_PIPE(pipe, _PSA_WIN_POS, _PSB_WIN_POS)
6647
6648/*
6649 * Skylake scalers
6650 */
6651#define _PS_1A_CTRL      0x68180
6652#define _PS_2A_CTRL      0x68280
6653#define _PS_1B_CTRL      0x68980
6654#define _PS_2B_CTRL      0x68A80
6655#define _PS_1C_CTRL      0x69180
6656#define PS_SCALER_EN        (1 << 31)
6657#define PS_SCALER_MODE_MASK (3 << 28)
6658#define PS_SCALER_MODE_DYN  (0 << 28)
6659#define PS_SCALER_MODE_HQ  (1 << 28)
6660#define PS_PLANE_SEL_MASK  (7 << 25)
6661#define PS_PLANE_SEL(plane) (((plane) + 1) << 25)
6662#define PS_FILTER_MASK         (3 << 23)
6663#define PS_FILTER_MEDIUM       (0 << 23)
6664#define PS_FILTER_EDGE_ENHANCE (2 << 23)
6665#define PS_FILTER_BILINEAR     (3 << 23)
6666#define PS_VERT3TAP            (1 << 21)
6667#define PS_VERT_INT_INVERT_FIELD1 (0 << 20)
6668#define PS_VERT_INT_INVERT_FIELD0 (1 << 20)
6669#define PS_PWRUP_PROGRESS         (1 << 17)
6670#define PS_V_FILTER_BYPASS        (1 << 8)
6671#define PS_VADAPT_EN              (1 << 7)
6672#define PS_VADAPT_MODE_MASK        (3 << 5)
6673#define PS_VADAPT_MODE_LEAST_ADAPT (0 << 5)
6674#define PS_VADAPT_MODE_MOD_ADAPT   (1 << 5)
6675#define PS_VADAPT_MODE_MOST_ADAPT  (3 << 5)
6676
6677#define _PS_PWR_GATE_1A     0x68160
6678#define _PS_PWR_GATE_2A     0x68260
6679#define _PS_PWR_GATE_1B     0x68960
6680#define _PS_PWR_GATE_2B     0x68A60
6681#define _PS_PWR_GATE_1C     0x69160
6682#define PS_PWR_GATE_DIS_OVERRIDE       (1 << 31)
6683#define PS_PWR_GATE_SETTLING_TIME_32   (0 << 3)
6684#define PS_PWR_GATE_SETTLING_TIME_64   (1 << 3)
6685#define PS_PWR_GATE_SETTLING_TIME_96   (2 << 3)
6686#define PS_PWR_GATE_SETTLING_TIME_128  (3 << 3)
6687#define PS_PWR_GATE_SLPEN_8             0
6688#define PS_PWR_GATE_SLPEN_16            1
6689#define PS_PWR_GATE_SLPEN_24            2
6690#define PS_PWR_GATE_SLPEN_32            3
6691
6692#define _PS_WIN_POS_1A      0x68170
6693#define _PS_WIN_POS_2A      0x68270
6694#define _PS_WIN_POS_1B      0x68970
6695#define _PS_WIN_POS_2B      0x68A70
6696#define _PS_WIN_POS_1C      0x69170
6697
6698#define _PS_WIN_SZ_1A       0x68174
6699#define _PS_WIN_SZ_2A       0x68274
6700#define _PS_WIN_SZ_1B       0x68974
6701#define _PS_WIN_SZ_2B       0x68A74
6702#define _PS_WIN_SZ_1C       0x69174
6703
6704#define _PS_VSCALE_1A       0x68184
6705#define _PS_VSCALE_2A       0x68284
6706#define _PS_VSCALE_1B       0x68984
6707#define _PS_VSCALE_2B       0x68A84
6708#define _PS_VSCALE_1C       0x69184
6709
6710#define _PS_HSCALE_1A       0x68190
6711#define _PS_HSCALE_2A       0x68290
6712#define _PS_HSCALE_1B       0x68990
6713#define _PS_HSCALE_2B       0x68A90
6714#define _PS_HSCALE_1C       0x69190
6715
6716#define _PS_VPHASE_1A       0x68188
6717#define _PS_VPHASE_2A       0x68288
6718#define _PS_VPHASE_1B       0x68988
6719#define _PS_VPHASE_2B       0x68A88
6720#define _PS_VPHASE_1C       0x69188
6721
6722#define _PS_HPHASE_1A       0x68194
6723#define _PS_HPHASE_2A       0x68294
6724#define _PS_HPHASE_1B       0x68994
6725#define _PS_HPHASE_2B       0x68A94
6726#define _PS_HPHASE_1C       0x69194
6727
6728#define _PS_ECC_STAT_1A     0x681D0
6729#define _PS_ECC_STAT_2A     0x682D0
6730#define _PS_ECC_STAT_1B     0x689D0
6731#define _PS_ECC_STAT_2B     0x68AD0
6732#define _PS_ECC_STAT_1C     0x691D0
6733
6734#define _ID(id, a, b) ((a) + (id)*((b)-(a)))
6735#define SKL_PS_CTRL(pipe, id) _MMIO_PIPE(pipe,        \
6736                        _ID(id, _PS_1A_CTRL, _PS_2A_CTRL),       \
6737                        _ID(id, _PS_1B_CTRL, _PS_2B_CTRL))
6738#define SKL_PS_PWR_GATE(pipe, id) _MMIO_PIPE(pipe,    \
6739                        _ID(id, _PS_PWR_GATE_1A, _PS_PWR_GATE_2A), \
6740                        _ID(id, _PS_PWR_GATE_1B, _PS_PWR_GATE_2B))
6741#define SKL_PS_WIN_POS(pipe, id) _MMIO_PIPE(pipe,     \
6742                        _ID(id, _PS_WIN_POS_1A, _PS_WIN_POS_2A), \
6743                        _ID(id, _PS_WIN_POS_1B, _PS_WIN_POS_2B))
6744#define SKL_PS_WIN_SZ(pipe, id)  _MMIO_PIPE(pipe,     \
6745                        _ID(id, _PS_WIN_SZ_1A, _PS_WIN_SZ_2A),   \
6746                        _ID(id, _PS_WIN_SZ_1B, _PS_WIN_SZ_2B))
6747#define SKL_PS_VSCALE(pipe, id)  _MMIO_PIPE(pipe,     \
6748                        _ID(id, _PS_VSCALE_1A, _PS_VSCALE_2A),   \
6749                        _ID(id, _PS_VSCALE_1B, _PS_VSCALE_2B))
6750#define SKL_PS_HSCALE(pipe, id)  _MMIO_PIPE(pipe,     \
6751                        _ID(id, _PS_HSCALE_1A, _PS_HSCALE_2A),   \
6752                        _ID(id, _PS_HSCALE_1B, _PS_HSCALE_2B))
6753#define SKL_PS_VPHASE(pipe, id)  _MMIO_PIPE(pipe,     \
6754                        _ID(id, _PS_VPHASE_1A, _PS_VPHASE_2A),   \
6755                        _ID(id, _PS_VPHASE_1B, _PS_VPHASE_2B))
6756#define SKL_PS_HPHASE(pipe, id)  _MMIO_PIPE(pipe,     \
6757                        _ID(id, _PS_HPHASE_1A, _PS_HPHASE_2A),   \
6758                        _ID(id, _PS_HPHASE_1B, _PS_HPHASE_2B))
6759#define SKL_PS_ECC_STAT(pipe, id)  _MMIO_PIPE(pipe,     \
6760                        _ID(id, _PS_ECC_STAT_1A, _PS_ECC_STAT_2A),   \
6761                        _ID(id, _PS_ECC_STAT_1B, _PS_ECC_STAT_2B))
6762
6763/* legacy palette */
6764#define _LGC_PALETTE_A           0x4a000
6765#define _LGC_PALETTE_B           0x4a800
6766#define LGC_PALETTE(pipe, i) _MMIO(_PIPE(pipe, _LGC_PALETTE_A, _LGC_PALETTE_B) + (i) * 4)
6767
6768#define _GAMMA_MODE_A           0x4a480
6769#define _GAMMA_MODE_B           0x4ac80
6770#define GAMMA_MODE(pipe) _MMIO_PIPE(pipe, _GAMMA_MODE_A, _GAMMA_MODE_B)
6771#define GAMMA_MODE_MODE_MASK    (3 << 0)
6772#define GAMMA_MODE_MODE_8BIT    (0 << 0)
6773#define GAMMA_MODE_MODE_10BIT   (1 << 0)
6774#define GAMMA_MODE_MODE_12BIT   (2 << 0)
6775#define GAMMA_MODE_MODE_SPLIT   (3 << 0)
6776
6777/* DMC/CSR */
6778#define CSR_PROGRAM(i)          _MMIO(0x80000 + (i) * 4)
6779#define CSR_SSP_BASE_ADDR_GEN9  0x00002FC0
6780#define CSR_HTP_ADDR_SKL        0x00500034
6781#define CSR_SSP_BASE            _MMIO(0x8F074)
6782#define CSR_HTP_SKL             _MMIO(0x8F004)
6783#define CSR_LAST_WRITE          _MMIO(0x8F034)
6784#define CSR_LAST_WRITE_VALUE    0xc003b400
6785/* MMIO address range for CSR program (0x80000 - 0x82FFF) */
6786#define CSR_MMIO_START_RANGE    0x80000
6787#define CSR_MMIO_END_RANGE      0x8FFFF
6788#define SKL_CSR_DC3_DC5_COUNT   _MMIO(0x80030)
6789#define SKL_CSR_DC5_DC6_COUNT   _MMIO(0x8002C)
6790#define BXT_CSR_DC3_DC5_COUNT   _MMIO(0x80038)
6791
6792/* interrupts */
6793#define DE_MASTER_IRQ_CONTROL   (1 << 31)
6794#define DE_SPRITEB_FLIP_DONE    (1 << 29)
6795#define DE_SPRITEA_FLIP_DONE    (1 << 28)
6796#define DE_PLANEB_FLIP_DONE     (1 << 27)
6797#define DE_PLANEA_FLIP_DONE     (1 << 26)
6798#define DE_PLANE_FLIP_DONE(plane) (1 << (26 + (plane)))
6799#define DE_PCU_EVENT            (1 << 25)
6800#define DE_GTT_FAULT            (1 << 24)
6801#define DE_POISON               (1 << 23)
6802#define DE_PERFORM_COUNTER      (1 << 22)
6803#define DE_PCH_EVENT            (1 << 21)
6804#define DE_AUX_CHANNEL_A        (1 << 20)
6805#define DE_DP_A_HOTPLUG         (1 << 19)
6806#define DE_GSE                  (1 << 18)
6807#define DE_PIPEB_VBLANK         (1 << 15)
6808#define DE_PIPEB_EVEN_FIELD     (1 << 14)
6809#define DE_PIPEB_ODD_FIELD      (1 << 13)
6810#define DE_PIPEB_LINE_COMPARE   (1 << 12)
6811#define DE_PIPEB_VSYNC          (1 << 11)
6812#define DE_PIPEB_CRC_DONE       (1 << 10)
6813#define DE_PIPEB_FIFO_UNDERRUN  (1 << 8)
6814#define DE_PIPEA_VBLANK         (1 << 7)
6815#define DE_PIPE_VBLANK(pipe)    (1 << (7 + 8*(pipe)))
6816#define DE_PIPEA_EVEN_FIELD     (1 << 6)
6817#define DE_PIPEA_ODD_FIELD      (1 << 5)
6818#define DE_PIPEA_LINE_COMPARE   (1 << 4)
6819#define DE_PIPEA_VSYNC          (1 << 3)
6820#define DE_PIPEA_CRC_DONE       (1 << 2)
6821#define DE_PIPE_CRC_DONE(pipe)  (1 << (2 + 8*(pipe)))
6822#define DE_PIPEA_FIFO_UNDERRUN  (1 << 0)
6823#define DE_PIPE_FIFO_UNDERRUN(pipe)  (1 << (8*(pipe)))
6824
6825/* More Ivybridge lolz */
6826#define DE_ERR_INT_IVB                  (1<<30)
6827#define DE_GSE_IVB                      (1<<29)
6828#define DE_PCH_EVENT_IVB                (1<<28)
6829#define DE_DP_A_HOTPLUG_IVB             (1<<27)
6830#define DE_AUX_CHANNEL_A_IVB            (1<<26)
6831#define DE_SPRITEC_FLIP_DONE_IVB        (1<<14)
6832#define DE_PLANEC_FLIP_DONE_IVB         (1<<13)
6833#define DE_PIPEC_VBLANK_IVB             (1<<10)
6834#define DE_SPRITEB_FLIP_DONE_IVB        (1<<9)
6835#define DE_PLANEB_FLIP_DONE_IVB         (1<<8)
6836#define DE_PIPEB_VBLANK_IVB             (1<<5)
6837#define DE_SPRITEA_FLIP_DONE_IVB        (1<<4)
6838#define DE_PLANEA_FLIP_DONE_IVB         (1<<3)
6839#define DE_PLANE_FLIP_DONE_IVB(plane)   (1<< (3 + 5*(plane)))
6840#define DE_PIPEA_VBLANK_IVB             (1<<0)
6841#define DE_PIPE_VBLANK_IVB(pipe)        (1 << ((pipe) * 5))
6842
6843#define VLV_MASTER_IER                  _MMIO(0x4400c) /* Gunit master IER */
6844#define   MASTER_INTERRUPT_ENABLE       (1<<31)
6845
6846#define DEISR   _MMIO(0x44000)
6847#define DEIMR   _MMIO(0x44004)
6848#define DEIIR   _MMIO(0x44008)
6849#define DEIER   _MMIO(0x4400c)
6850
6851#define GTISR   _MMIO(0x44010)
6852#define GTIMR   _MMIO(0x44014)
6853#define GTIIR   _MMIO(0x44018)
6854#define GTIER   _MMIO(0x4401c)
6855
6856#define GEN8_MASTER_IRQ                 _MMIO(0x44200)
6857#define  GEN8_MASTER_IRQ_CONTROL        (1<<31)
6858#define  GEN8_PCU_IRQ                   (1<<30)
6859#define  GEN8_DE_PCH_IRQ                (1<<23)
6860#define  GEN8_DE_MISC_IRQ               (1<<22)
6861#define  GEN8_DE_PORT_IRQ               (1<<20)
6862#define  GEN8_DE_PIPE_C_IRQ             (1<<18)
6863#define  GEN8_DE_PIPE_B_IRQ             (1<<17)
6864#define  GEN8_DE_PIPE_A_IRQ             (1<<16)
6865#define  GEN8_DE_PIPE_IRQ(pipe)         (1<<(16+(pipe)))
6866#define  GEN8_GT_VECS_IRQ               (1<<6)
6867#define  GEN8_GT_GUC_IRQ                (1<<5)
6868#define  GEN8_GT_PM_IRQ                 (1<<4)
6869#define  GEN8_GT_VCS2_IRQ               (1<<3)
6870#define  GEN8_GT_VCS1_IRQ               (1<<2)
6871#define  GEN8_GT_BCS_IRQ                (1<<1)
6872#define  GEN8_GT_RCS_IRQ                (1<<0)
6873
6874#define GEN8_GT_ISR(which) _MMIO(0x44300 + (0x10 * (which)))
6875#define GEN8_GT_IMR(which) _MMIO(0x44304 + (0x10 * (which)))
6876#define GEN8_GT_IIR(which) _MMIO(0x44308 + (0x10 * (which)))
6877#define GEN8_GT_IER(which) _MMIO(0x4430c + (0x10 * (which)))
6878
6879#define GEN9_GUC_TO_HOST_INT_EVENT      (1<<31)
6880#define GEN9_GUC_EXEC_ERROR_EVENT       (1<<30)
6881#define GEN9_GUC_DISPLAY_EVENT          (1<<29)
6882#define GEN9_GUC_SEMA_SIGNAL_EVENT      (1<<28)
6883#define GEN9_GUC_IOMMU_MSG_EVENT        (1<<27)
6884#define GEN9_GUC_DB_RING_EVENT          (1<<26)
6885#define GEN9_GUC_DMA_DONE_EVENT         (1<<25)
6886#define GEN9_GUC_FATAL_ERROR_EVENT      (1<<24)
6887#define GEN9_GUC_NOTIFICATION_EVENT     (1<<23)
6888
6889#define GEN8_RCS_IRQ_SHIFT 0
6890#define GEN8_BCS_IRQ_SHIFT 16
6891#define GEN8_VCS1_IRQ_SHIFT 0
6892#define GEN8_VCS2_IRQ_SHIFT 16
6893#define GEN8_VECS_IRQ_SHIFT 0
6894#define GEN8_WD_IRQ_SHIFT 16
6895
6896#define GEN8_DE_PIPE_ISR(pipe) _MMIO(0x44400 + (0x10 * (pipe)))
6897#define GEN8_DE_PIPE_IMR(pipe) _MMIO(0x44404 + (0x10 * (pipe)))
6898#define GEN8_DE_PIPE_IIR(pipe) _MMIO(0x44408 + (0x10 * (pipe)))
6899#define GEN8_DE_PIPE_IER(pipe) _MMIO(0x4440c + (0x10 * (pipe)))
6900#define  GEN8_PIPE_FIFO_UNDERRUN        (1 << 31)
6901#define  GEN8_PIPE_CDCLK_CRC_ERROR      (1 << 29)
6902#define  GEN8_PIPE_CDCLK_CRC_DONE       (1 << 28)
6903#define  GEN8_PIPE_CURSOR_FAULT         (1 << 10)
6904#define  GEN8_PIPE_SPRITE_FAULT         (1 << 9)
6905#define  GEN8_PIPE_PRIMARY_FAULT        (1 << 8)
6906#define  GEN8_PIPE_SPRITE_FLIP_DONE     (1 << 5)
6907#define  GEN8_PIPE_PRIMARY_FLIP_DONE    (1 << 4)
6908#define  GEN8_PIPE_SCAN_LINE_EVENT      (1 << 2)
6909#define  GEN8_PIPE_VSYNC                (1 << 1)
6910#define  GEN8_PIPE_VBLANK               (1 << 0)
6911#define  GEN9_PIPE_CURSOR_FAULT         (1 << 11)
6912#define  GEN9_PIPE_PLANE4_FAULT         (1 << 10)
6913#define  GEN9_PIPE_PLANE3_FAULT         (1 << 9)
6914#define  GEN9_PIPE_PLANE2_FAULT         (1 << 8)
6915#define  GEN9_PIPE_PLANE1_FAULT         (1 << 7)
6916#define  GEN9_PIPE_PLANE4_FLIP_DONE     (1 << 6)
6917#define  GEN9_PIPE_PLANE3_FLIP_DONE     (1 << 5)
6918#define  GEN9_PIPE_PLANE2_FLIP_DONE     (1 << 4)
6919#define  GEN9_PIPE_PLANE1_FLIP_DONE     (1 << 3)
6920#define  GEN9_PIPE_PLANE_FLIP_DONE(p)   (1 << (3 + (p)))
6921#define GEN8_DE_PIPE_IRQ_FAULT_ERRORS \
6922        (GEN8_PIPE_CURSOR_FAULT | \
6923         GEN8_PIPE_SPRITE_FAULT | \
6924         GEN8_PIPE_PRIMARY_FAULT)
6925#define GEN9_DE_PIPE_IRQ_FAULT_ERRORS \
6926        (GEN9_PIPE_CURSOR_FAULT | \
6927         GEN9_PIPE_PLANE4_FAULT | \
6928         GEN9_PIPE_PLANE3_FAULT | \
6929         GEN9_PIPE_PLANE2_FAULT | \
6930         GEN9_PIPE_PLANE1_FAULT)
6931
6932#define GEN8_DE_PORT_ISR _MMIO(0x44440)
6933#define GEN8_DE_PORT_IMR _MMIO(0x44444)
6934#define GEN8_DE_PORT_IIR _MMIO(0x44448)
6935#define GEN8_DE_PORT_IER _MMIO(0x4444c)
6936#define  GEN9_AUX_CHANNEL_D             (1 << 27)
6937#define  GEN9_AUX_CHANNEL_C             (1 << 26)
6938#define  GEN9_AUX_CHANNEL_B             (1 << 25)
6939#define  BXT_DE_PORT_HP_DDIC            (1 << 5)
6940#define  BXT_DE_PORT_HP_DDIB            (1 << 4)
6941#define  BXT_DE_PORT_HP_DDIA            (1 << 3)
6942#define  BXT_DE_PORT_HOTPLUG_MASK       (BXT_DE_PORT_HP_DDIA | \
6943                                         BXT_DE_PORT_HP_DDIB | \
6944                                         BXT_DE_PORT_HP_DDIC)
6945#define  GEN8_PORT_DP_A_HOTPLUG         (1 << 3)
6946#define  BXT_DE_PORT_GMBUS              (1 << 1)
6947#define  GEN8_AUX_CHANNEL_A             (1 << 0)
6948
6949#define GEN8_DE_MISC_ISR _MMIO(0x44460)
6950#define GEN8_DE_MISC_IMR _MMIO(0x44464)
6951#define GEN8_DE_MISC_IIR _MMIO(0x44468)
6952#define GEN8_DE_MISC_IER _MMIO(0x4446c)
6953#define  GEN8_DE_MISC_GSE               (1 << 27)
6954
6955#define GEN8_PCU_ISR _MMIO(0x444e0)
6956#define GEN8_PCU_IMR _MMIO(0x444e4)
6957#define GEN8_PCU_IIR _MMIO(0x444e8)
6958#define GEN8_PCU_IER _MMIO(0x444ec)
6959
6960#define ILK_DISPLAY_CHICKEN2    _MMIO(0x42004)
6961/* Required on all Ironlake and Sandybridge according to the B-Spec. */
6962#define  ILK_ELPIN_409_SELECT   (1 << 25)
6963#define  ILK_DPARB_GATE (1<<22)
6964#define  ILK_VSDPFD_FULL        (1<<21)
6965#define FUSE_STRAP                      _MMIO(0x42014)
6966#define  ILK_INTERNAL_GRAPHICS_DISABLE  (1 << 31)
6967#define  ILK_INTERNAL_DISPLAY_DISABLE   (1 << 30)
6968#define  ILK_DISPLAY_DEBUG_DISABLE      (1 << 29)
6969#define  IVB_PIPE_C_DISABLE             (1 << 28)
6970#define  ILK_HDCP_DISABLE               (1 << 25)
6971#define  ILK_eDP_A_DISABLE              (1 << 24)
6972#define  HSW_CDCLK_LIMIT                (1 << 24)
6973#define  ILK_DESKTOP                    (1 << 23)
6974
6975#define ILK_DSPCLK_GATE_D                       _MMIO(0x42020)
6976#define   ILK_VRHUNIT_CLOCK_GATE_DISABLE        (1 << 28)
6977#define   ILK_DPFCUNIT_CLOCK_GATE_DISABLE       (1 << 9)
6978#define   ILK_DPFCRUNIT_CLOCK_GATE_DISABLE      (1 << 8)
6979#define   ILK_DPFDUNIT_CLOCK_GATE_ENABLE        (1 << 7)
6980#define   ILK_DPARBUNIT_CLOCK_GATE_ENABLE       (1 << 5)
6981
6982#define IVB_CHICKEN3    _MMIO(0x4200c)
6983# define CHICKEN3_DGMG_REQ_OUT_FIX_DISABLE      (1 << 5)
6984# define CHICKEN3_DGMG_DONE_FIX_DISABLE         (1 << 2)
6985
6986#define CHICKEN_PAR1_1          _MMIO(0x42080)
6987#define  SKL_DE_COMPRESSED_HASH_MODE    (1 << 15)
6988#define  DPA_MASK_VBLANK_SRD    (1 << 15)
6989#define  FORCE_ARB_IDLE_PLANES  (1 << 14)
6990#define  SKL_EDP_PSR_FIX_RDWRAP (1 << 3)
6991
6992#define CHICKEN_PAR2_1          _MMIO(0x42090)
6993#define  KVM_CONFIG_CHANGE_NOTIFICATION_SELECT  (1 << 14)
6994
6995#define CHICKEN_MISC_2          _MMIO(0x42084)
6996#define  CNL_COMP_PWR_DOWN      (1 << 23)
6997#define  GLK_CL2_PWR_DOWN       (1 << 12)
6998#define  GLK_CL1_PWR_DOWN       (1 << 11)
6999#define  GLK_CL0_PWR_DOWN       (1 << 10)
7000
7001#define CHICKEN_MISC_4          _MMIO(0x4208c)
7002#define   FBC_STRIDE_OVERRIDE   (1 << 13)
7003#define   FBC_STRIDE_MASK       0x1FFF
7004
7005#define _CHICKEN_PIPESL_1_A     0x420b0
7006#define _CHICKEN_PIPESL_1_B     0x420b4
7007#define  HSW_FBCQ_DIS                   (1 << 22)
7008#define  BDW_DPRS_MASK_VBLANK_SRD       (1 << 0)
7009#define CHICKEN_PIPESL_1(pipe) _MMIO_PIPE(pipe, _CHICKEN_PIPESL_1_A, _CHICKEN_PIPESL_1_B)
7010
7011#define CHICKEN_TRANS_A         0x420c0
7012#define CHICKEN_TRANS_B         0x420c4
7013#define CHICKEN_TRANS(trans) _MMIO_TRANS(trans, CHICKEN_TRANS_A, CHICKEN_TRANS_B)
7014#define PSR2_VSC_ENABLE_PROG_HEADER    (1<<12)
7015#define PSR2_ADD_VERTICAL_LINE_COUNT   (1<<15)
7016
7017#define DISP_ARB_CTL    _MMIO(0x45000)
7018#define  DISP_FBC_MEMORY_WAKE           (1<<31)
7019#define  DISP_TILE_SURFACE_SWIZZLING    (1<<13)
7020#define  DISP_FBC_WM_DIS                (1<<15)
7021#define DISP_ARB_CTL2   _MMIO(0x45004)
7022#define  DISP_DATA_PARTITION_5_6        (1<<6)
7023#define  DISP_IPC_ENABLE                (1<<3)
7024#define DBUF_CTL        _MMIO(0x45008)
7025#define  DBUF_POWER_REQUEST             (1<<31)
7026#define  DBUF_POWER_STATE               (1<<30)
7027#define GEN7_MSG_CTL    _MMIO(0x45010)
7028#define  WAIT_FOR_PCH_RESET_ACK         (1<<1)
7029#define  WAIT_FOR_PCH_FLR_ACK           (1<<0)
7030#define HSW_NDE_RSTWRN_OPT      _MMIO(0x46408)
7031#define  RESET_PCH_HANDSHAKE_ENABLE     (1<<4)
7032
7033#define GEN8_CHICKEN_DCPR_1             _MMIO(0x46430)
7034#define   SKL_SELECT_ALTERNATE_DC_EXIT  (1<<30)
7035#define   MASK_WAKEMEM                  (1<<13)
7036
7037#define SKL_DFSM                        _MMIO(0x51000)
7038#define SKL_DFSM_CDCLK_LIMIT_MASK       (3 << 23)
7039#define SKL_DFSM_CDCLK_LIMIT_675        (0 << 23)
7040#define SKL_DFSM_CDCLK_LIMIT_540        (1 << 23)
7041#define SKL_DFSM_CDCLK_LIMIT_450        (2 << 23)
7042#define SKL_DFSM_CDCLK_LIMIT_337_5      (3 << 23)
7043#define SKL_DFSM_PIPE_A_DISABLE         (1 << 30)
7044#define SKL_DFSM_PIPE_B_DISABLE         (1 << 21)
7045#define SKL_DFSM_PIPE_C_DISABLE         (1 << 28)
7046
7047#define SKL_DSSM                        _MMIO(0x51004)
7048#define CNL_DSSM_CDCLK_PLL_REFCLK_24MHz (1 << 31)
7049
7050#define GEN7_FF_SLICE_CS_CHICKEN1       _MMIO(0x20e0)
7051#define   GEN9_FFSC_PERCTX_PREEMPT_CTRL (1<<14)
7052
7053#define FF_SLICE_CS_CHICKEN2                    _MMIO(0x20e4)
7054#define  GEN9_TSG_BARRIER_ACK_DISABLE           (1<<8)
7055#define  GEN9_POOLED_EU_LOAD_BALANCING_FIX_DISABLE  (1<<10)
7056
7057#define GEN9_CS_DEBUG_MODE1             _MMIO(0x20ec)
7058#define GEN9_CTX_PREEMPT_REG            _MMIO(0x2248)
7059#define GEN8_CS_CHICKEN1                _MMIO(0x2580)
7060#define GEN9_PREEMPT_3D_OBJECT_LEVEL            (1<<0)
7061#define GEN9_PREEMPT_GPGPU_LEVEL(hi, lo)        (((hi) << 2) | ((lo) << 1))
7062#define GEN9_PREEMPT_GPGPU_MID_THREAD_LEVEL     GEN9_PREEMPT_GPGPU_LEVEL(0, 0)
7063#define GEN9_PREEMPT_GPGPU_THREAD_GROUP_LEVEL   GEN9_PREEMPT_GPGPU_LEVEL(0, 1)
7064#define GEN9_PREEMPT_GPGPU_COMMAND_LEVEL        GEN9_PREEMPT_GPGPU_LEVEL(1, 0)
7065#define GEN9_PREEMPT_GPGPU_LEVEL_MASK           GEN9_PREEMPT_GPGPU_LEVEL(1, 1)
7066
7067/* GEN7 chicken */
7068#define GEN7_COMMON_SLICE_CHICKEN1              _MMIO(0x7010)
7069# define GEN7_CSC1_RHWO_OPT_DISABLE_IN_RCC      ((1<<10) | (1<<26))
7070# define GEN9_RHWO_OPTIMIZATION_DISABLE         (1<<14)
7071#define COMMON_SLICE_CHICKEN2                   _MMIO(0x7014)
7072# define GEN9_PBE_COMPRESSED_HASH_SELECTION     (1<<13)
7073# define GEN9_DISABLE_GATHER_AT_SET_SHADER_COMMON_SLICE (1<<12)
7074# define GEN8_SBE_DISABLE_REPLAY_BUF_OPTIMIZATION (1<<8)
7075# define GEN8_CSC2_SBE_VUE_CACHE_CONSERVATIVE   (1<<0)
7076
7077#define HIZ_CHICKEN                                     _MMIO(0x7018)
7078# define CHV_HZ_8X8_MODE_IN_1X                          (1<<15)
7079# define BDW_HIZ_POWER_COMPILER_CLOCK_GATING_DISABLE    (1<<3)
7080
7081#define GEN9_SLICE_COMMON_ECO_CHICKEN0          _MMIO(0x7308)
7082#define  DISABLE_PIXEL_MASK_CAMMING             (1<<14)
7083
7084#define GEN9_SLICE_COMMON_ECO_CHICKEN1          _MMIO(0x731c)
7085
7086#define GEN7_L3SQCREG1                          _MMIO(0xB010)
7087#define  VLV_B0_WA_L3SQCREG1_VALUE              0x00D30000
7088
7089#define GEN8_L3SQCREG1                          _MMIO(0xB100)
7090/*
7091 * Note that on CHV the following has an off-by-one error wrt. to BSpec.
7092 * Using the formula in BSpec leads to a hang, while the formula here works
7093 * fine and matches the formulas for all other platforms. A BSpec change
7094 * request has been filed to clarify this.
7095 */
7096#define  L3_GENERAL_PRIO_CREDITS(x)             (((x) >> 1) << 19)
7097#define  L3_HIGH_PRIO_CREDITS(x)                (((x) >> 1) << 14)
7098#define  L3_PRIO_CREDITS_MASK                   ((0x1f << 19) | (0x1f << 14))
7099
7100#define GEN7_L3CNTLREG1                         _MMIO(0xB01C)
7101#define  GEN7_WA_FOR_GEN7_L3_CONTROL                    0x3C47FF8C
7102#define  GEN7_L3AGDIS                           (1<<19)
7103#define GEN7_L3CNTLREG2                         _MMIO(0xB020)
7104#define GEN7_L3CNTLREG3                         _MMIO(0xB024)
7105
7106#define GEN7_L3_CHICKEN_MODE_REGISTER           _MMIO(0xB030)
7107#define  GEN7_WA_L3_CHICKEN_MODE                                0x20000000
7108
7109#define GEN7_L3SQCREG4                          _MMIO(0xb034)
7110#define  L3SQ_URB_READ_CAM_MATCH_DISABLE        (1<<27)
7111
7112#define GEN8_L3SQCREG4                          _MMIO(0xb118)
7113#define  GEN8_LQSC_RO_PERF_DIS                  (1<<27)
7114#define  GEN8_LQSC_FLUSH_COHERENT_LINES         (1<<21)
7115
7116/* GEN8 chicken */
7117#define HDC_CHICKEN0                            _MMIO(0x7300)
7118#define CNL_HDC_CHICKEN0                        _MMIO(0xE5F0)
7119#define  HDC_FORCE_CSR_NON_COHERENT_OVR_DISABLE (1<<15)
7120#define  HDC_FENCE_DEST_SLM_DISABLE             (1<<14)
7121#define  HDC_DONOT_FETCH_MEM_WHEN_MASKED        (1<<11)
7122#define  HDC_FORCE_CONTEXT_SAVE_RESTORE_NON_COHERENT    (1<<5)
7123#define  HDC_FORCE_NON_COHERENT                 (1<<4)
7124#define  HDC_BARRIER_PERFORMANCE_DISABLE        (1<<10)
7125
7126#define GEN8_HDC_CHICKEN1                       _MMIO(0x7304)
7127
7128/* GEN9 chicken */
7129#define SLICE_ECO_CHICKEN0                      _MMIO(0x7308)
7130#define   PIXEL_MASK_CAMMING_DISABLE            (1 << 14)
7131
7132/* WaCatErrorRejectionIssue */
7133#define GEN7_SQ_CHICKEN_MBCUNIT_CONFIG          _MMIO(0x9030)
7134#define  GEN7_SQ_CHICKEN_MBCUNIT_SQINTMOB       (1<<11)
7135
7136#define HSW_SCRATCH1                            _MMIO(0xb038)
7137#define  HSW_SCRATCH1_L3_DATA_ATOMICS_DISABLE   (1<<27)
7138
7139#define BDW_SCRATCH1                                    _MMIO(0xb11c)
7140#define  GEN9_LBS_SLA_RETRY_TIMER_DECREMENT_ENABLE      (1<<2)
7141
7142/* PCH */
7143
7144/* south display engine interrupt: IBX */
7145#define SDE_AUDIO_POWER_D       (1 << 27)
7146#define SDE_AUDIO_POWER_C       (1 << 26)
7147#define SDE_AUDIO_POWER_B       (1 << 25)
7148#define SDE_AUDIO_POWER_SHIFT   (25)
7149#define SDE_AUDIO_POWER_MASK    (7 << SDE_AUDIO_POWER_SHIFT)
7150#define SDE_GMBUS               (1 << 24)
7151#define SDE_AUDIO_HDCP_TRANSB   (1 << 23)
7152#define SDE_AUDIO_HDCP_TRANSA   (1 << 22)
7153#define SDE_AUDIO_HDCP_MASK     (3 << 22)
7154#define SDE_AUDIO_TRANSB        (1 << 21)
7155#define SDE_AUDIO_TRANSA        (1 << 20)
7156#define SDE_AUDIO_TRANS_MASK    (3 << 20)
7157#define SDE_POISON              (1 << 19)
7158/* 18 reserved */
7159#define SDE_FDI_RXB             (1 << 17)
7160#define SDE_FDI_RXA             (1 << 16)
7161#define SDE_FDI_MASK            (3 << 16)
7162#define SDE_AUXD                (1 << 15)
7163#define SDE_AUXC                (1 << 14)
7164#define SDE_AUXB                (1 << 13)
7165#define SDE_AUX_MASK            (7 << 13)
7166/* 12 reserved */
7167#define SDE_CRT_HOTPLUG         (1 << 11)
7168#define SDE_PORTD_HOTPLUG       (1 << 10)
7169#define SDE_PORTC_HOTPLUG       (1 << 9)
7170#define SDE_PORTB_HOTPLUG       (1 << 8)
7171#define SDE_SDVOB_HOTPLUG       (1 << 6)
7172#define SDE_HOTPLUG_MASK        (SDE_CRT_HOTPLUG | \
7173                                 SDE_SDVOB_HOTPLUG |    \
7174                                 SDE_PORTB_HOTPLUG |    \
7175                                 SDE_PORTC_HOTPLUG |    \
7176                                 SDE_PORTD_HOTPLUG)
7177#define SDE_TRANSB_CRC_DONE     (1 << 5)
7178#define SDE_TRANSB_CRC_ERR      (1 << 4)
7179#define SDE_TRANSB_FIFO_UNDER   (1 << 3)
7180#define SDE_TRANSA_CRC_DONE     (1 << 2)
7181#define SDE_TRANSA_CRC_ERR      (1 << 1)
7182#define SDE_TRANSA_FIFO_UNDER   (1 << 0)
7183#define SDE_TRANS_MASK          (0x3f)
7184
7185/* south display engine interrupt: CPT/PPT */
7186#define SDE_AUDIO_POWER_D_CPT   (1 << 31)
7187#define SDE_AUDIO_POWER_C_CPT   (1 << 30)
7188#define SDE_AUDIO_POWER_B_CPT   (1 << 29)
7189#define SDE_AUDIO_POWER_SHIFT_CPT   29
7190#define SDE_AUDIO_POWER_MASK_CPT    (7 << 29)
7191#define SDE_AUXD_CPT            (1 << 27)
7192#define SDE_AUXC_CPT            (1 << 26)
7193#define SDE_AUXB_CPT            (1 << 25)
7194#define SDE_AUX_MASK_CPT        (7 << 25)
7195#define SDE_PORTE_HOTPLUG_SPT   (1 << 25)
7196#define SDE_PORTA_HOTPLUG_SPT   (1 << 24)
7197#define SDE_PORTD_HOTPLUG_CPT   (1 << 23)
7198#define SDE_PORTC_HOTPLUG_CPT   (1 << 22)
7199#define SDE_PORTB_HOTPLUG_CPT   (1 << 21)
7200#define SDE_CRT_HOTPLUG_CPT     (1 << 19)
7201#define SDE_SDVOB_HOTPLUG_CPT   (1 << 18)
7202#define SDE_HOTPLUG_MASK_CPT    (SDE_CRT_HOTPLUG_CPT |          \
7203                                 SDE_SDVOB_HOTPLUG_CPT |        \
7204                                 SDE_PORTD_HOTPLUG_CPT |        \
7205                                 SDE_PORTC_HOTPLUG_CPT |        \
7206                                 SDE_PORTB_HOTPLUG_CPT)
7207#define SDE_HOTPLUG_MASK_SPT    (SDE_PORTE_HOTPLUG_SPT |        \
7208                                 SDE_PORTD_HOTPLUG_CPT |        \
7209                                 SDE_PORTC_HOTPLUG_CPT |        \
7210                                 SDE_PORTB_HOTPLUG_CPT |        \
7211                                 SDE_PORTA_HOTPLUG_SPT)
7212#define SDE_GMBUS_CPT           (1 << 17)
7213#define SDE_ERROR_CPT           (1 << 16)
7214#define SDE_AUDIO_CP_REQ_C_CPT  (1 << 10)
7215#define SDE_AUDIO_CP_CHG_C_CPT  (1 << 9)
7216#define SDE_FDI_RXC_CPT         (1 << 8)
7217#define SDE_AUDIO_CP_REQ_B_CPT  (1 << 6)
7218#define SDE_AUDIO_CP_CHG_B_CPT  (1 << 5)
7219#define SDE_FDI_RXB_CPT         (1 << 4)
7220#define SDE_AUDIO_CP_REQ_A_CPT  (1 << 2)
7221#define SDE_AUDIO_CP_CHG_A_CPT  (1 << 1)
7222#define SDE_FDI_RXA_CPT         (1 << 0)
7223#define SDE_AUDIO_CP_REQ_CPT    (SDE_AUDIO_CP_REQ_C_CPT | \
7224                                 SDE_AUDIO_CP_REQ_B_CPT | \
7225                                 SDE_AUDIO_CP_REQ_A_CPT)
7226#define SDE_AUDIO_CP_CHG_CPT    (SDE_AUDIO_CP_CHG_C_CPT | \
7227                                 SDE_AUDIO_CP_CHG_B_CPT | \
7228                                 SDE_AUDIO_CP_CHG_A_CPT)
7229#define SDE_FDI_MASK_CPT        (SDE_FDI_RXC_CPT | \
7230                                 SDE_FDI_RXB_CPT | \
7231                                 SDE_FDI_RXA_CPT)
7232
7233#define SDEISR  _MMIO(0xc4000)
7234#define SDEIMR  _MMIO(0xc4004)
7235#define SDEIIR  _MMIO(0xc4008)
7236#define SDEIER  _MMIO(0xc400c)
7237
7238#define SERR_INT                        _MMIO(0xc4040)
7239#define  SERR_INT_POISON                (1<<31)
7240#define  SERR_INT_TRANS_FIFO_UNDERRUN(pipe)     (1<<((pipe)*3))
7241
7242/* digital port hotplug */
7243#define PCH_PORT_HOTPLUG                _MMIO(0xc4030)  /* SHOTPLUG_CTL */
7244#define  PORTA_HOTPLUG_ENABLE           (1 << 28) /* LPT:LP+ & BXT */
7245#define  BXT_DDIA_HPD_INVERT            (1 << 27)
7246#define  PORTA_HOTPLUG_STATUS_MASK      (3 << 24) /* SPT+ & BXT */
7247#define  PORTA_HOTPLUG_NO_DETECT        (0 << 24) /* SPT+ & BXT */
7248#define  PORTA_HOTPLUG_SHORT_DETECT     (1 << 24) /* SPT+ & BXT */
7249#define  PORTA_HOTPLUG_LONG_DETECT      (2 << 24) /* SPT+ & BXT */
7250#define  PORTD_HOTPLUG_ENABLE           (1 << 20)
7251#define  PORTD_PULSE_DURATION_2ms       (0 << 18) /* pre-LPT */
7252#define  PORTD_PULSE_DURATION_4_5ms     (1 << 18) /* pre-LPT */
7253#define  PORTD_PULSE_DURATION_6ms       (2 << 18) /* pre-LPT */
7254#define  PORTD_PULSE_DURATION_100ms     (3 << 18) /* pre-LPT */
7255#define  PORTD_PULSE_DURATION_MASK      (3 << 18) /* pre-LPT */
7256#define  PORTD_HOTPLUG_STATUS_MASK      (3 << 16)
7257#define  PORTD_HOTPLUG_NO_DETECT        (0 << 16)
7258#define  PORTD_HOTPLUG_SHORT_DETECT     (1 << 16)
7259#define  PORTD_HOTPLUG_LONG_DETECT      (2 << 16)
7260#define  PORTC_HOTPLUG_ENABLE           (1 << 12)
7261#define  BXT_DDIC_HPD_INVERT            (1 << 11)
7262#define  PORTC_PULSE_DURATION_2ms       (0 << 10) /* pre-LPT */
7263#define  PORTC_PULSE_DURATION_4_5ms     (1 << 10) /* pre-LPT */
7264#define  PORTC_PULSE_DURATION_6ms       (2 << 10) /* pre-LPT */
7265#define  PORTC_PULSE_DURATION_100ms     (3 << 10) /* pre-LPT */
7266#define  PORTC_PULSE_DURATION_MASK      (3 << 10) /* pre-LPT */
7267#define  PORTC_HOTPLUG_STATUS_MASK      (3 << 8)
7268#define  PORTC_HOTPLUG_NO_DETECT        (0 << 8)
7269#define  PORTC_HOTPLUG_SHORT_DETECT     (1 << 8)
7270#define  PORTC_HOTPLUG_LONG_DETECT      (2 << 8)
7271#define  PORTB_HOTPLUG_ENABLE           (1 << 4)
7272#define  BXT_DDIB_HPD_INVERT            (1 << 3)
7273#define  PORTB_PULSE_DURATION_2ms       (0 << 2) /* pre-LPT */
7274#define  PORTB_PULSE_DURATION_4_5ms     (1 << 2) /* pre-LPT */
7275#define  PORTB_PULSE_DURATION_6ms       (2 << 2) /* pre-LPT */
7276#define  PORTB_PULSE_DURATION_100ms     (3 << 2) /* pre-LPT */
7277#define  PORTB_PULSE_DURATION_MASK      (3 << 2) /* pre-LPT */
7278#define  PORTB_HOTPLUG_STATUS_MASK      (3 << 0)
7279#define  PORTB_HOTPLUG_NO_DETECT        (0 << 0)
7280#define  PORTB_HOTPLUG_SHORT_DETECT     (1 << 0)
7281#define  PORTB_HOTPLUG_LONG_DETECT      (2 << 0)
7282#define  BXT_DDI_HPD_INVERT_MASK        (BXT_DDIA_HPD_INVERT | \
7283                                        BXT_DDIB_HPD_INVERT | \
7284                                        BXT_DDIC_HPD_INVERT)
7285
7286#define PCH_PORT_HOTPLUG2               _MMIO(0xc403C)  /* SHOTPLUG_CTL2 SPT+ */
7287#define  PORTE_HOTPLUG_ENABLE           (1 << 4)
7288#define  PORTE_HOTPLUG_STATUS_MASK      (3 << 0)
7289#define  PORTE_HOTPLUG_NO_DETECT        (0 << 0)
7290#define  PORTE_HOTPLUG_SHORT_DETECT     (1 << 0)
7291#define  PORTE_HOTPLUG_LONG_DETECT      (2 << 0)
7292
7293#define PCH_GPIOA               _MMIO(0xc5010)
7294#define PCH_GPIOB               _MMIO(0xc5014)
7295#define PCH_GPIOC               _MMIO(0xc5018)
7296#define PCH_GPIOD               _MMIO(0xc501c)
7297#define PCH_GPIOE               _MMIO(0xc5020)
7298#define PCH_GPIOF               _MMIO(0xc5024)
7299
7300#define PCH_GMBUS0              _MMIO(0xc5100)
7301#define PCH_GMBUS1              _MMIO(0xc5104)
7302#define PCH_GMBUS2              _MMIO(0xc5108)
7303#define PCH_GMBUS3              _MMIO(0xc510c)
7304#define PCH_GMBUS4              _MMIO(0xc5110)
7305#define PCH_GMBUS5              _MMIO(0xc5120)
7306
7307#define _PCH_DPLL_A              0xc6014
7308#define _PCH_DPLL_B              0xc6018
7309#define PCH_DPLL(pll) _MMIO(pll == 0 ? _PCH_DPLL_A : _PCH_DPLL_B)
7310
7311#define _PCH_FPA0                0xc6040
7312#define  FP_CB_TUNE             (0x3<<22)
7313#define _PCH_FPA1                0xc6044
7314#define _PCH_FPB0                0xc6048
7315#define _PCH_FPB1                0xc604c
7316#define PCH_FP0(pll) _MMIO(pll == 0 ? _PCH_FPA0 : _PCH_FPB0)
7317#define PCH_FP1(pll) _MMIO(pll == 0 ? _PCH_FPA1 : _PCH_FPB1)
7318
7319#define PCH_DPLL_TEST           _MMIO(0xc606c)
7320
7321#define PCH_DREF_CONTROL        _MMIO(0xC6200)
7322#define  DREF_CONTROL_MASK      0x7fc3
7323#define  DREF_CPU_SOURCE_OUTPUT_DISABLE         (0<<13)
7324#define  DREF_CPU_SOURCE_OUTPUT_DOWNSPREAD      (2<<13)
7325#define  DREF_CPU_SOURCE_OUTPUT_NONSPREAD       (3<<13)
7326#define  DREF_CPU_SOURCE_OUTPUT_MASK            (3<<13)
7327#define  DREF_SSC_SOURCE_DISABLE                (0<<11)
7328#define  DREF_SSC_SOURCE_ENABLE                 (2<<11)
7329#define  DREF_SSC_SOURCE_MASK                   (3<<11)
7330#define  DREF_NONSPREAD_SOURCE_DISABLE          (0<<9)
7331#define  DREF_NONSPREAD_CK505_ENABLE            (1<<9)
7332#define  DREF_NONSPREAD_SOURCE_ENABLE           (2<<9)
7333#define  DREF_NONSPREAD_SOURCE_MASK             (3<<9)
7334#define  DREF_SUPERSPREAD_SOURCE_DISABLE        (0<<7)
7335#define  DREF_SUPERSPREAD_SOURCE_ENABLE         (2<<7)
7336#define  DREF_SUPERSPREAD_SOURCE_MASK           (3<<7)
7337#define  DREF_SSC4_DOWNSPREAD                   (0<<6)
7338#define  DREF_SSC4_CENTERSPREAD                 (1<<6)
7339#define  DREF_SSC1_DISABLE                      (0<<1)
7340#define  DREF_SSC1_ENABLE                       (1<<1)
7341#define  DREF_SSC4_DISABLE                      (0)
7342#define  DREF_SSC4_ENABLE                       (1)
7343
7344#define PCH_RAWCLK_FREQ         _MMIO(0xc6204)
7345#define  FDL_TP1_TIMER_SHIFT    12
7346#define  FDL_TP1_TIMER_MASK     (3<<12)
7347#define  FDL_TP2_TIMER_SHIFT    10
7348#define  FDL_TP2_TIMER_MASK     (3<<10)
7349#define  RAWCLK_FREQ_MASK       0x3ff
7350#define  CNP_RAWCLK_DIV_MASK    (0x3ff << 16)
7351#define  CNP_RAWCLK_DIV(div)    ((div) << 16)
7352#define  CNP_RAWCLK_FRAC_MASK   (0xf << 26)
7353#define  CNP_RAWCLK_FRAC(frac)  ((frac) << 26)
7354
7355#define PCH_DPLL_TMR_CFG        _MMIO(0xc6208)
7356
7357#define PCH_SSC4_PARMS          _MMIO(0xc6210)
7358#define PCH_SSC4_AUX_PARMS      _MMIO(0xc6214)
7359
7360#define PCH_DPLL_SEL            _MMIO(0xc7000)
7361#define  TRANS_DPLLB_SEL(pipe)          (1 << ((pipe) * 4))
7362#define  TRANS_DPLLA_SEL(pipe)          0
7363#define  TRANS_DPLL_ENABLE(pipe)        (1 << ((pipe) * 4 + 3))
7364
7365/* transcoder */
7366
7367#define _PCH_TRANS_HTOTAL_A             0xe0000
7368#define  TRANS_HTOTAL_SHIFT             16
7369#define  TRANS_HACTIVE_SHIFT            0
7370#define _PCH_TRANS_HBLANK_A             0xe0004
7371#define  TRANS_HBLANK_END_SHIFT         16
7372#define  TRANS_HBLANK_START_SHIFT       0
7373#define _PCH_TRANS_HSYNC_A              0xe0008
7374#define  TRANS_HSYNC_END_SHIFT          16
7375#define  TRANS_HSYNC_START_SHIFT        0
7376#define _PCH_TRANS_VTOTAL_A             0xe000c
7377#define  TRANS_VTOTAL_SHIFT             16
7378#define  TRANS_VACTIVE_SHIFT            0
7379#define _PCH_TRANS_VBLANK_A             0xe0010
7380#define  TRANS_VBLANK_END_SHIFT         16
7381#define  TRANS_VBLANK_START_SHIFT       0
7382#define _PCH_TRANS_VSYNC_A              0xe0014
7383#define  TRANS_VSYNC_END_SHIFT          16
7384#define  TRANS_VSYNC_START_SHIFT        0
7385#define _PCH_TRANS_VSYNCSHIFT_A         0xe0028
7386
7387#define _PCH_TRANSA_DATA_M1     0xe0030
7388#define _PCH_TRANSA_DATA_N1     0xe0034
7389#define _PCH_TRANSA_DATA_M2     0xe0038
7390#define _PCH_TRANSA_DATA_N2     0xe003c
7391#define _PCH_TRANSA_LINK_M1     0xe0040
7392#define _PCH_TRANSA_LINK_N1     0xe0044
7393#define _PCH_TRANSA_LINK_M2     0xe0048
7394#define _PCH_TRANSA_LINK_N2     0xe004c
7395
7396/* Per-transcoder DIP controls (PCH) */
7397#define _VIDEO_DIP_CTL_A         0xe0200
7398#define _VIDEO_DIP_DATA_A        0xe0208
7399#define _VIDEO_DIP_GCP_A         0xe0210
7400#define  GCP_COLOR_INDICATION           (1 << 2)
7401#define  GCP_DEFAULT_PHASE_ENABLE       (1 << 1)
7402#define  GCP_AV_MUTE                    (1 << 0)
7403
7404#define _VIDEO_DIP_CTL_B         0xe1200
7405#define _VIDEO_DIP_DATA_B        0xe1208
7406#define _VIDEO_DIP_GCP_B         0xe1210
7407
7408#define TVIDEO_DIP_CTL(pipe) _MMIO_PIPE(pipe, _VIDEO_DIP_CTL_A, _VIDEO_DIP_CTL_B)
7409#define TVIDEO_DIP_DATA(pipe) _MMIO_PIPE(pipe, _VIDEO_DIP_DATA_A, _VIDEO_DIP_DATA_B)
7410#define TVIDEO_DIP_GCP(pipe) _MMIO_PIPE(pipe, _VIDEO_DIP_GCP_A, _VIDEO_DIP_GCP_B)
7411
7412/* Per-transcoder DIP controls (VLV) */
7413#define _VLV_VIDEO_DIP_CTL_A            (VLV_DISPLAY_BASE + 0x60200)
7414#define _VLV_VIDEO_DIP_DATA_A           (VLV_DISPLAY_BASE + 0x60208)
7415#define _VLV_VIDEO_DIP_GDCP_PAYLOAD_A   (VLV_DISPLAY_BASE + 0x60210)
7416
7417#define _VLV_VIDEO_DIP_CTL_B            (VLV_DISPLAY_BASE + 0x61170)
7418#define _VLV_VIDEO_DIP_DATA_B           (VLV_DISPLAY_BASE + 0x61174)
7419#define _VLV_VIDEO_DIP_GDCP_PAYLOAD_B   (VLV_DISPLAY_BASE + 0x61178)
7420
7421#define _CHV_VIDEO_DIP_CTL_C            (VLV_DISPLAY_BASE + 0x611f0)
7422#define _CHV_VIDEO_DIP_DATA_C           (VLV_DISPLAY_BASE + 0x611f4)
7423#define _CHV_VIDEO_DIP_GDCP_PAYLOAD_C   (VLV_DISPLAY_BASE + 0x611f8)
7424
7425#define VLV_TVIDEO_DIP_CTL(pipe) \
7426        _MMIO_PIPE3((pipe), _VLV_VIDEO_DIP_CTL_A, \
7427               _VLV_VIDEO_DIP_CTL_B, _CHV_VIDEO_DIP_CTL_C)
7428#define VLV_TVIDEO_DIP_DATA(pipe) \
7429        _MMIO_PIPE3((pipe), _VLV_VIDEO_DIP_DATA_A, \
7430               _VLV_VIDEO_DIP_DATA_B, _CHV_VIDEO_DIP_DATA_C)
7431#define VLV_TVIDEO_DIP_GCP(pipe) \
7432        _MMIO_PIPE3((pipe), _VLV_VIDEO_DIP_GDCP_PAYLOAD_A, \
7433                _VLV_VIDEO_DIP_GDCP_PAYLOAD_B, _CHV_VIDEO_DIP_GDCP_PAYLOAD_C)
7434
7435/* Haswell DIP controls */
7436
7437#define _HSW_VIDEO_DIP_CTL_A            0x60200
7438#define _HSW_VIDEO_DIP_AVI_DATA_A       0x60220
7439#define _HSW_VIDEO_DIP_VS_DATA_A        0x60260
7440#define _HSW_VIDEO_DIP_SPD_DATA_A       0x602A0
7441#define _HSW_VIDEO_DIP_GMP_DATA_A       0x602E0
7442#define _HSW_VIDEO_DIP_VSC_DATA_A       0x60320
7443#define _HSW_VIDEO_DIP_AVI_ECC_A        0x60240
7444#define _HSW_VIDEO_DIP_VS_ECC_A         0x60280
7445#define _HSW_VIDEO_DIP_SPD_ECC_A        0x602C0
7446#define _HSW_VIDEO_DIP_GMP_ECC_A        0x60300
7447#define _HSW_VIDEO_DIP_VSC_ECC_A        0x60344
7448#define _HSW_VIDEO_DIP_GCP_A            0x60210
7449
7450#define _HSW_VIDEO_DIP_CTL_B            0x61200
7451#define _HSW_VIDEO_DIP_AVI_DATA_B       0x61220
7452#define _HSW_VIDEO_DIP_VS_DATA_B        0x61260
7453#define _HSW_VIDEO_DIP_SPD_DATA_B       0x612A0
7454#define _HSW_VIDEO_DIP_GMP_DATA_B       0x612E0
7455#define _HSW_VIDEO_DIP_VSC_DATA_B       0x61320
7456#define _HSW_VIDEO_DIP_BVI_ECC_B        0x61240
7457#define _HSW_VIDEO_DIP_VS_ECC_B         0x61280
7458#define _HSW_VIDEO_DIP_SPD_ECC_B        0x612C0
7459#define _HSW_VIDEO_DIP_GMP_ECC_B        0x61300
7460#define _HSW_VIDEO_DIP_VSC_ECC_B        0x61344
7461#define _HSW_VIDEO_DIP_GCP_B            0x61210
7462
7463#define HSW_TVIDEO_DIP_CTL(trans)               _MMIO_TRANS2(trans, _HSW_VIDEO_DIP_CTL_A)
7464#define HSW_TVIDEO_DIP_AVI_DATA(trans, i)       _MMIO_TRANS2(trans, _HSW_VIDEO_DIP_AVI_DATA_A + (i) * 4)
7465#define HSW_TVIDEO_DIP_VS_DATA(trans, i)        _MMIO_TRANS2(trans, _HSW_VIDEO_DIP_VS_DATA_A + (i) * 4)
7466#define HSW_TVIDEO_DIP_SPD_DATA(trans, i)       _MMIO_TRANS2(trans, _HSW_VIDEO_DIP_SPD_DATA_A + (i) * 4)
7467#define HSW_TVIDEO_DIP_GCP(trans)               _MMIO_TRANS2(trans, _HSW_VIDEO_DIP_GCP_A)
7468#define HSW_TVIDEO_DIP_VSC_DATA(trans, i)       _MMIO_TRANS2(trans, _HSW_VIDEO_DIP_VSC_DATA_A + (i) * 4)
7469
7470#define _HSW_STEREO_3D_CTL_A            0x70020
7471#define   S3D_ENABLE                    (1<<31)
7472#define _HSW_STEREO_3D_CTL_B            0x71020
7473
7474#define HSW_STEREO_3D_CTL(trans)        _MMIO_PIPE2(trans, _HSW_STEREO_3D_CTL_A)
7475
7476#define _PCH_TRANS_HTOTAL_B          0xe1000
7477#define _PCH_TRANS_HBLANK_B          0xe1004
7478#define _PCH_TRANS_HSYNC_B           0xe1008
7479#define _PCH_TRANS_VTOTAL_B          0xe100c
7480#define _PCH_TRANS_VBLANK_B          0xe1010
7481#define _PCH_TRANS_VSYNC_B           0xe1014
7482#define _PCH_TRANS_VSYNCSHIFT_B 0xe1028
7483
7484#define PCH_TRANS_HTOTAL(pipe)          _MMIO_PIPE(pipe, _PCH_TRANS_HTOTAL_A, _PCH_TRANS_HTOTAL_B)
7485#define PCH_TRANS_HBLANK(pipe)          _MMIO_PIPE(pipe, _PCH_TRANS_HBLANK_A, _PCH_TRANS_HBLANK_B)
7486#define PCH_TRANS_HSYNC(pipe)           _MMIO_PIPE(pipe, _PCH_TRANS_HSYNC_A, _PCH_TRANS_HSYNC_B)
7487#define PCH_TRANS_VTOTAL(pipe)          _MMIO_PIPE(pipe, _PCH_TRANS_VTOTAL_A, _PCH_TRANS_VTOTAL_B)
7488#define PCH_TRANS_VBLANK(pipe)          _MMIO_PIPE(pipe, _PCH_TRANS_VBLANK_A, _PCH_TRANS_VBLANK_B)
7489#define PCH_TRANS_VSYNC(pipe)           _MMIO_PIPE(pipe, _PCH_TRANS_VSYNC_A, _PCH_TRANS_VSYNC_B)
7490#define PCH_TRANS_VSYNCSHIFT(pipe)      _MMIO_PIPE(pipe, _PCH_TRANS_VSYNCSHIFT_A, _PCH_TRANS_VSYNCSHIFT_B)
7491
7492#define _PCH_TRANSB_DATA_M1     0xe1030
7493#define _PCH_TRANSB_DATA_N1     0xe1034
7494#define _PCH_TRANSB_DATA_M2     0xe1038
7495#define _PCH_TRANSB_DATA_N2     0xe103c
7496#define _PCH_TRANSB_LINK_M1     0xe1040
7497#define _PCH_TRANSB_LINK_N1     0xe1044
7498#define _PCH_TRANSB_LINK_M2     0xe1048
7499#define _PCH_TRANSB_LINK_N2     0xe104c
7500
7501#define PCH_TRANS_DATA_M1(pipe) _MMIO_PIPE(pipe, _PCH_TRANSA_DATA_M1, _PCH_TRANSB_DATA_M1)
7502#define PCH_TRANS_DATA_N1(pipe) _MMIO_PIPE(pipe, _PCH_TRANSA_DATA_N1, _PCH_TRANSB_DATA_N1)
7503#define PCH_TRANS_DATA_M2(pipe) _MMIO_PIPE(pipe, _PCH_TRANSA_DATA_M2, _PCH_TRANSB_DATA_M2)
7504#define PCH_TRANS_DATA_N2(pipe) _MMIO_PIPE(pipe, _PCH_TRANSA_DATA_N2, _PCH_TRANSB_DATA_N2)
7505#define PCH_TRANS_LINK_M1(pipe) _MMIO_PIPE(pipe, _PCH_TRANSA_LINK_M1, _PCH_TRANSB_LINK_M1)
7506#define PCH_TRANS_LINK_N1(pipe) _MMIO_PIPE(pipe, _PCH_TRANSA_LINK_N1, _PCH_TRANSB_LINK_N1)
7507#define PCH_TRANS_LINK_M2(pipe) _MMIO_PIPE(pipe, _PCH_TRANSA_LINK_M2, _PCH_TRANSB_LINK_M2)
7508#define PCH_TRANS_LINK_N2(pipe) _MMIO_PIPE(pipe, _PCH_TRANSA_LINK_N2, _PCH_TRANSB_LINK_N2)
7509
7510#define _PCH_TRANSACONF              0xf0008
7511#define _PCH_TRANSBCONF              0xf1008
7512#define PCH_TRANSCONF(pipe)     _MMIO_PIPE(pipe, _PCH_TRANSACONF, _PCH_TRANSBCONF)
7513#define LPT_TRANSCONF           PCH_TRANSCONF(PIPE_A) /* lpt has only one transcoder */
7514#define  TRANS_DISABLE          (0<<31)
7515#define  TRANS_ENABLE           (1<<31)
7516#define  TRANS_STATE_MASK       (1<<30)
7517#define  TRANS_STATE_DISABLE    (0<<30)
7518#define  TRANS_STATE_ENABLE     (1<<30)
7519#define  TRANS_FSYNC_DELAY_HB1  (0<<27)
7520#define  TRANS_FSYNC_DELAY_HB2  (1<<27)
7521#define  TRANS_FSYNC_DELAY_HB3  (2<<27)
7522#define  TRANS_FSYNC_DELAY_HB4  (3<<27)
7523#define  TRANS_INTERLACE_MASK   (7<<21)
7524#define  TRANS_PROGRESSIVE      (0<<21)
7525#define  TRANS_INTERLACED       (3<<21)
7526#define  TRANS_LEGACY_INTERLACED_ILK (2<<21)
7527#define  TRANS_8BPC             (0<<5)
7528#define  TRANS_10BPC            (1<<5)
7529#define  TRANS_6BPC             (2<<5)
7530#define  TRANS_12BPC            (3<<5)
7531
7532#define _TRANSA_CHICKEN1         0xf0060
7533#define _TRANSB_CHICKEN1         0xf1060
7534#define TRANS_CHICKEN1(pipe)    _MMIO_PIPE(pipe, _TRANSA_CHICKEN1, _TRANSB_CHICKEN1)
7535#define  TRANS_CHICKEN1_HDMIUNIT_GC_DISABLE     (1<<10)
7536#define  TRANS_CHICKEN1_DP0UNIT_GC_DISABLE      (1<<4)
7537#define _TRANSA_CHICKEN2         0xf0064
7538#define _TRANSB_CHICKEN2         0xf1064
7539#define TRANS_CHICKEN2(pipe)    _MMIO_PIPE(pipe, _TRANSA_CHICKEN2, _TRANSB_CHICKEN2)
7540#define  TRANS_CHICKEN2_TIMING_OVERRIDE                 (1<<31)
7541#define  TRANS_CHICKEN2_FDI_POLARITY_REVERSED           (1<<29)
7542#define  TRANS_CHICKEN2_FRAME_START_DELAY_MASK          (3<<27)
7543#define  TRANS_CHICKEN2_DISABLE_DEEP_COLOR_COUNTER      (1<<26)
7544#define  TRANS_CHICKEN2_DISABLE_DEEP_COLOR_MODESWITCH   (1<<25)
7545
7546#define SOUTH_CHICKEN1          _MMIO(0xc2000)
7547#define  FDIA_PHASE_SYNC_SHIFT_OVR      19
7548#define  FDIA_PHASE_SYNC_SHIFT_EN       18
7549#define  FDI_PHASE_SYNC_OVR(pipe) (1<<(FDIA_PHASE_SYNC_SHIFT_OVR - ((pipe) * 2)))
7550#define  FDI_PHASE_SYNC_EN(pipe) (1<<(FDIA_PHASE_SYNC_SHIFT_EN - ((pipe) * 2)))
7551#define  FDI_BC_BIFURCATION_SELECT      (1 << 12)
7552#define  CHASSIS_CLK_REQ_DURATION_MASK  (0xf << 8)
7553#define  CHASSIS_CLK_REQ_DURATION(x)    ((x) << 8)
7554#define  SPT_PWM_GRANULARITY            (1<<0)
7555#define SOUTH_CHICKEN2          _MMIO(0xc2004)
7556#define  FDI_MPHY_IOSFSB_RESET_STATUS   (1<<13)
7557#define  FDI_MPHY_IOSFSB_RESET_CTL      (1<<12)
7558#define  LPT_PWM_GRANULARITY            (1<<5)
7559#define  DPLS_EDP_PPS_FIX_DIS           (1<<0)
7560
7561#define _FDI_RXA_CHICKEN        0xc200c
7562#define _FDI_RXB_CHICKEN        0xc2010
7563#define  FDI_RX_PHASE_SYNC_POINTER_OVR  (1<<1)
7564#define  FDI_RX_PHASE_SYNC_POINTER_EN   (1<<0)
7565#define FDI_RX_CHICKEN(pipe)    _MMIO_PIPE(pipe, _FDI_RXA_CHICKEN, _FDI_RXB_CHICKEN)
7566
7567#define SOUTH_DSPCLK_GATE_D     _MMIO(0xc2020)
7568#define  PCH_GMBUSUNIT_CLOCK_GATE_DISABLE (1<<31)
7569#define  PCH_DPLUNIT_CLOCK_GATE_DISABLE (1<<30)
7570#define  PCH_DPLSUNIT_CLOCK_GATE_DISABLE (1<<29)
7571#define  PCH_CPUNIT_CLOCK_GATE_DISABLE (1<<14)
7572#define  CNP_PWM_CGE_GATING_DISABLE (1<<13)
7573#define  PCH_LP_PARTITION_LEVEL_DISABLE  (1<<12)
7574
7575/* CPU: FDI_TX */
7576#define _FDI_TXA_CTL            0x60100
7577#define _FDI_TXB_CTL            0x61100
7578#define FDI_TX_CTL(pipe)        _MMIO_PIPE(pipe, _FDI_TXA_CTL, _FDI_TXB_CTL)
7579#define  FDI_TX_DISABLE         (0<<31)
7580#define  FDI_TX_ENABLE          (1<<31)
7581#define  FDI_LINK_TRAIN_PATTERN_1       (0<<28)
7582#define  FDI_LINK_TRAIN_PATTERN_2       (1<<28)
7583#define  FDI_LINK_TRAIN_PATTERN_IDLE    (2<<28)
7584#define  FDI_LINK_TRAIN_NONE            (3<<28)
7585#define  FDI_LINK_TRAIN_VOLTAGE_0_4V    (0<<25)
7586#define  FDI_LINK_TRAIN_VOLTAGE_0_6V    (1<<25)
7587#define  FDI_LINK_TRAIN_VOLTAGE_0_8V    (2<<25)
7588#define  FDI_LINK_TRAIN_VOLTAGE_1_2V    (3<<25)
7589#define  FDI_LINK_TRAIN_PRE_EMPHASIS_NONE (0<<22)
7590#define  FDI_LINK_TRAIN_PRE_EMPHASIS_1_5X (1<<22)
7591#define  FDI_LINK_TRAIN_PRE_EMPHASIS_2X   (2<<22)
7592#define  FDI_LINK_TRAIN_PRE_EMPHASIS_3X   (3<<22)
7593/* ILK always use 400mV 0dB for voltage swing and pre-emphasis level.
7594   SNB has different settings. */
7595/* SNB A-stepping */
7596#define  FDI_LINK_TRAIN_400MV_0DB_SNB_A         (0x38<<22)
7597#define  FDI_LINK_TRAIN_400MV_6DB_SNB_A         (0x02<<22)
7598#define  FDI_LINK_TRAIN_600MV_3_5DB_SNB_A       (0x01<<22)
7599#define  FDI_LINK_TRAIN_800MV_0DB_SNB_A         (0x0<<22)
7600/* SNB B-stepping */
7601#define  FDI_LINK_TRAIN_400MV_0DB_SNB_B         (0x0<<22)
7602#define  FDI_LINK_TRAIN_400MV_6DB_SNB_B         (0x3a<<22)
7603#define  FDI_LINK_TRAIN_600MV_3_5DB_SNB_B       (0x39<<22)
7604#define  FDI_LINK_TRAIN_800MV_0DB_SNB_B         (0x38<<22)
7605#define  FDI_LINK_TRAIN_VOL_EMP_MASK            (0x3f<<22)
7606#define  FDI_DP_PORT_WIDTH_SHIFT                19
7607#define  FDI_DP_PORT_WIDTH_MASK                 (7 << FDI_DP_PORT_WIDTH_SHIFT)
7608#define  FDI_DP_PORT_WIDTH(width)           (((width) - 1) << FDI_DP_PORT_WIDTH_SHIFT)
7609#define  FDI_TX_ENHANCE_FRAME_ENABLE    (1<<18)
7610/* Ironlake: hardwired to 1 */
7611#define  FDI_TX_PLL_ENABLE              (1<<14)
7612
7613/* Ivybridge has different bits for lolz */
7614#define  FDI_LINK_TRAIN_PATTERN_1_IVB       (0<<8)
7615#define  FDI_LINK_TRAIN_PATTERN_2_IVB       (1<<8)
7616#define  FDI_LINK_TRAIN_PATTERN_IDLE_IVB    (2<<8)
7617#define  FDI_LINK_TRAIN_NONE_IVB            (3<<8)
7618
7619/* both Tx and Rx */
7620#define  FDI_COMPOSITE_SYNC             (1<<11)
7621#define  FDI_LINK_TRAIN_AUTO            (1<<10)
7622#define  FDI_SCRAMBLING_ENABLE          (0<<7)
7623#define  FDI_SCRAMBLING_DISABLE         (1<<7)
7624
7625/* FDI_RX, FDI_X is hard-wired to Transcoder_X */
7626#define _FDI_RXA_CTL             0xf000c
7627#define _FDI_RXB_CTL             0xf100c
7628#define FDI_RX_CTL(pipe)        _MMIO_PIPE(pipe, _FDI_RXA_CTL, _FDI_RXB_CTL)
7629#define  FDI_RX_ENABLE          (1<<31)
7630/* train, dp width same as FDI_TX */
7631#define  FDI_FS_ERRC_ENABLE             (1<<27)
7632#define  FDI_FE_ERRC_ENABLE             (1<<26)
7633#define  FDI_RX_POLARITY_REVERSED_LPT   (1<<16)
7634#define  FDI_8BPC                       (0<<16)
7635#define  FDI_10BPC                      (1<<16)
7636#define  FDI_6BPC                       (2<<16)
7637#define  FDI_12BPC                      (3<<16)
7638#define  FDI_RX_LINK_REVERSAL_OVERRIDE  (1<<15)
7639#define  FDI_DMI_LINK_REVERSE_MASK      (1<<14)
7640#define  FDI_RX_PLL_ENABLE              (1<<13)
7641#define  FDI_FS_ERR_CORRECT_ENABLE      (1<<11)
7642#define  FDI_FE_ERR_CORRECT_ENABLE      (1<<10)
7643#define  FDI_FS_ERR_REPORT_ENABLE       (1<<9)
7644#define  FDI_FE_ERR_REPORT_ENABLE       (1<<8)
7645#define  FDI_RX_ENHANCE_FRAME_ENABLE    (1<<6)
7646#define  FDI_PCDCLK                     (1<<4)
7647/* CPT */
7648#define  FDI_AUTO_TRAINING                      (1<<10)
7649#define  FDI_LINK_TRAIN_PATTERN_1_CPT           (0<<8)
7650#define  FDI_LINK_TRAIN_PATTERN_2_CPT           (1<<8)
7651#define  FDI_LINK_TRAIN_PATTERN_IDLE_CPT        (2<<8)
7652#define  FDI_LINK_TRAIN_NORMAL_CPT              (3<<8)
7653#define  FDI_LINK_TRAIN_PATTERN_MASK_CPT        (3<<8)
7654
7655#define _FDI_RXA_MISC                   0xf0010
7656#define _FDI_RXB_MISC                   0xf1010
7657#define  FDI_RX_PWRDN_LANE1_MASK        (3<<26)
7658#define  FDI_RX_PWRDN_LANE1_VAL(x)      ((x)<<26)
7659#define  FDI_RX_PWRDN_LANE0_MASK        (3<<24)
7660#define  FDI_RX_PWRDN_LANE0_VAL(x)      ((x)<<24)
7661#define  FDI_RX_TP1_TO_TP2_48           (2<<20)
7662#define  FDI_RX_TP1_TO_TP2_64           (3<<20)
7663#define  FDI_RX_FDI_DELAY_90            (0x90<<0)
7664#define FDI_RX_MISC(pipe)       _MMIO_PIPE(pipe, _FDI_RXA_MISC, _FDI_RXB_MISC)
7665
7666#define _FDI_RXA_TUSIZE1        0xf0030
7667#define _FDI_RXA_TUSIZE2        0xf0038
7668#define _FDI_RXB_TUSIZE1        0xf1030
7669#define _FDI_RXB_TUSIZE2        0xf1038
7670#define FDI_RX_TUSIZE1(pipe)    _MMIO_PIPE(pipe, _FDI_RXA_TUSIZE1, _FDI_RXB_TUSIZE1)
7671#define FDI_RX_TUSIZE2(pipe)    _MMIO_PIPE(pipe, _FDI_RXA_TUSIZE2, _FDI_RXB_TUSIZE2)
7672
7673/* FDI_RX interrupt register format */
7674#define FDI_RX_INTER_LANE_ALIGN         (1<<10)
7675#define FDI_RX_SYMBOL_LOCK              (1<<9) /* train 2 */
7676#define FDI_RX_BIT_LOCK                 (1<<8) /* train 1 */
7677#define FDI_RX_TRAIN_PATTERN_2_FAIL     (1<<7)
7678#define FDI_RX_FS_CODE_ERR              (1<<6)
7679#define FDI_RX_FE_CODE_ERR              (1<<5)
7680#define FDI_RX_SYMBOL_ERR_RATE_ABOVE    (1<<4)
7681#define FDI_RX_HDCP_LINK_FAIL           (1<<3)
7682#define FDI_RX_PIXEL_FIFO_OVERFLOW      (1<<2)
7683#define FDI_RX_CROSS_CLOCK_OVERFLOW     (1<<1)
7684#define FDI_RX_SYMBOL_QUEUE_OVERFLOW    (1<<0)
7685
7686#define _FDI_RXA_IIR            0xf0014
7687#define _FDI_RXA_IMR            0xf0018
7688#define _FDI_RXB_IIR            0xf1014
7689#define _FDI_RXB_IMR            0xf1018
7690#define FDI_RX_IIR(pipe)        _MMIO_PIPE(pipe, _FDI_RXA_IIR, _FDI_RXB_IIR)
7691#define FDI_RX_IMR(pipe)        _MMIO_PIPE(pipe, _FDI_RXA_IMR, _FDI_RXB_IMR)
7692
7693#define FDI_PLL_CTL_1           _MMIO(0xfe000)
7694#define FDI_PLL_CTL_2           _MMIO(0xfe004)
7695
7696#define PCH_LVDS        _MMIO(0xe1180)
7697#define  LVDS_DETECTED  (1 << 1)
7698
7699#define _PCH_DP_B               0xe4100
7700#define PCH_DP_B                _MMIO(_PCH_DP_B)
7701#define _PCH_DPB_AUX_CH_CTL     0xe4110
7702#define _PCH_DPB_AUX_CH_DATA1   0xe4114
7703#define _PCH_DPB_AUX_CH_DATA2   0xe4118
7704#define _PCH_DPB_AUX_CH_DATA3   0xe411c
7705#define _PCH_DPB_AUX_CH_DATA4   0xe4120
7706#define _PCH_DPB_AUX_CH_DATA5   0xe4124
7707
7708#define _PCH_DP_C               0xe4200
7709#define PCH_DP_C                _MMIO(_PCH_DP_C)
7710#define _PCH_DPC_AUX_CH_CTL     0xe4210
7711#define _PCH_DPC_AUX_CH_DATA1   0xe4214
7712#define _PCH_DPC_AUX_CH_DATA2   0xe4218
7713#define _PCH_DPC_AUX_CH_DATA3   0xe421c
7714#define _PCH_DPC_AUX_CH_DATA4   0xe4220
7715#define _PCH_DPC_AUX_CH_DATA5   0xe4224
7716
7717#define _PCH_DP_D               0xe4300
7718#define PCH_DP_D                _MMIO(_PCH_DP_D)
7719#define _PCH_DPD_AUX_CH_CTL     0xe4310
7720#define _PCH_DPD_AUX_CH_DATA1   0xe4314
7721#define _PCH_DPD_AUX_CH_DATA2   0xe4318
7722#define _PCH_DPD_AUX_CH_DATA3   0xe431c
7723#define _PCH_DPD_AUX_CH_DATA4   0xe4320
7724#define _PCH_DPD_AUX_CH_DATA5   0xe4324
7725
7726#define PCH_DP_AUX_CH_CTL(port)         _MMIO_PORT((port) - PORT_B, _PCH_DPB_AUX_CH_CTL, _PCH_DPC_AUX_CH_CTL)
7727#define PCH_DP_AUX_CH_DATA(port, i)     _MMIO(_PORT((port) - PORT_B, _PCH_DPB_AUX_CH_DATA1, _PCH_DPC_AUX_CH_DATA1) + (i) * 4) /* 5 registers */
7728
7729/* CPT */
7730#define  PORT_TRANS_A_SEL_CPT   0
7731#define  PORT_TRANS_B_SEL_CPT   (1<<29)
7732#define  PORT_TRANS_C_SEL_CPT   (2<<29)
7733#define  PORT_TRANS_SEL_MASK    (3<<29)
7734#define  PORT_TRANS_SEL_CPT(pipe)       ((pipe) << 29)
7735#define  PORT_TO_PIPE(val)      (((val) & (1<<30)) >> 30)
7736#define  PORT_TO_PIPE_CPT(val)  (((val) & PORT_TRANS_SEL_MASK) >> 29)
7737#define  SDVO_PORT_TO_PIPE_CHV(val)     (((val) & (3<<24)) >> 24)
7738#define  DP_PORT_TO_PIPE_CHV(val)       (((val) & (3<<16)) >> 16)
7739
7740#define _TRANS_DP_CTL_A         0xe0300
7741#define _TRANS_DP_CTL_B         0xe1300
7742#define _TRANS_DP_CTL_C         0xe2300
7743#define TRANS_DP_CTL(pipe)      _MMIO_PIPE(pipe, _TRANS_DP_CTL_A, _TRANS_DP_CTL_B)
7744#define  TRANS_DP_OUTPUT_ENABLE (1<<31)
7745#define  TRANS_DP_PORT_SEL_B    (0<<29)
7746#define  TRANS_DP_PORT_SEL_C    (1<<29)
7747#define  TRANS_DP_PORT_SEL_D    (2<<29)
7748#define  TRANS_DP_PORT_SEL_NONE (3<<29)
7749#define  TRANS_DP_PORT_SEL_MASK (3<<29)
7750#define  TRANS_DP_PIPE_TO_PORT(val)     ((((val) & TRANS_DP_PORT_SEL_MASK) >> 29) + PORT_B)
7751#define  TRANS_DP_AUDIO_ONLY    (1<<26)
7752#define  TRANS_DP_ENH_FRAMING   (1<<18)
7753#define  TRANS_DP_8BPC          (0<<9)
7754#define  TRANS_DP_10BPC         (1<<9)
7755#define  TRANS_DP_6BPC          (2<<9)
7756#define  TRANS_DP_12BPC         (3<<9)
7757#define  TRANS_DP_BPC_MASK      (3<<9)
7758#define  TRANS_DP_VSYNC_ACTIVE_HIGH     (1<<4)
7759#define  TRANS_DP_VSYNC_ACTIVE_LOW      0
7760#define  TRANS_DP_HSYNC_ACTIVE_HIGH     (1<<3)
7761#define  TRANS_DP_HSYNC_ACTIVE_LOW      0
7762#define  TRANS_DP_SYNC_MASK     (3<<3)
7763
7764/* SNB eDP training params */
7765/* SNB A-stepping */
7766#define  EDP_LINK_TRAIN_400MV_0DB_SNB_A         (0x38<<22)
7767#define  EDP_LINK_TRAIN_400MV_6DB_SNB_A         (0x02<<22)
7768#define  EDP_LINK_TRAIN_600MV_3_5DB_SNB_A       (0x01<<22)
7769#define  EDP_LINK_TRAIN_800MV_0DB_SNB_A         (0x0<<22)
7770/* SNB B-stepping */
7771#define  EDP_LINK_TRAIN_400_600MV_0DB_SNB_B     (0x0<<22)
7772#define  EDP_LINK_TRAIN_400MV_3_5DB_SNB_B       (0x1<<22)
7773#define  EDP_LINK_TRAIN_400_600MV_6DB_SNB_B     (0x3a<<22)
7774#define  EDP_LINK_TRAIN_600_800MV_3_5DB_SNB_B   (0x39<<22)
7775#define  EDP_LINK_TRAIN_800_1200MV_0DB_SNB_B    (0x38<<22)
7776#define  EDP_LINK_TRAIN_VOL_EMP_MASK_SNB        (0x3f<<22)
7777
7778/* IVB */
7779#define EDP_LINK_TRAIN_400MV_0DB_IVB            (0x24 <<22)
7780#define EDP_LINK_TRAIN_400MV_3_5DB_IVB          (0x2a <<22)
7781#define EDP_LINK_TRAIN_400MV_6DB_IVB            (0x2f <<22)
7782#define EDP_LINK_TRAIN_600MV_0DB_IVB            (0x30 <<22)
7783#define EDP_LINK_TRAIN_600MV_3_5DB_IVB          (0x36 <<22)
7784#define EDP_LINK_TRAIN_800MV_0DB_IVB            (0x38 <<22)
7785#define EDP_LINK_TRAIN_800MV_3_5DB_IVB          (0x3e <<22)
7786
7787/* legacy values */
7788#define EDP_LINK_TRAIN_500MV_0DB_IVB            (0x00 <<22)
7789#define EDP_LINK_TRAIN_1000MV_0DB_IVB           (0x20 <<22)
7790#define EDP_LINK_TRAIN_500MV_3_5DB_IVB          (0x02 <<22)
7791#define EDP_LINK_TRAIN_1000MV_3_5DB_IVB         (0x22 <<22)
7792#define EDP_LINK_TRAIN_1000MV_6DB_IVB           (0x23 <<22)
7793
7794#define  EDP_LINK_TRAIN_VOL_EMP_MASK_IVB        (0x3f<<22)
7795
7796#define  VLV_PMWGICZ                            _MMIO(0x1300a4)
7797
7798#define  RC6_LOCATION                           _MMIO(0xD40)
7799#define    RC6_CTX_IN_DRAM                      (1 << 0)
7800#define  RC6_CTX_BASE                           _MMIO(0xD48)
7801#define    RC6_CTX_BASE_MASK                    0xFFFFFFF0
7802#define  PWRCTX_MAXCNT_RCSUNIT                  _MMIO(0x2054)
7803#define  PWRCTX_MAXCNT_VCSUNIT0                 _MMIO(0x12054)
7804#define  PWRCTX_MAXCNT_BCSUNIT                  _MMIO(0x22054)
7805#define  PWRCTX_MAXCNT_VECSUNIT                 _MMIO(0x1A054)
7806#define  PWRCTX_MAXCNT_VCSUNIT1                 _MMIO(0x1C054)
7807#define    IDLE_TIME_MASK                       0xFFFFF
7808#define  FORCEWAKE                              _MMIO(0xA18C)
7809#define  FORCEWAKE_VLV                          _MMIO(0x1300b0)
7810#define  FORCEWAKE_ACK_VLV                      _MMIO(0x1300b4)
7811#define  FORCEWAKE_MEDIA_VLV                    _MMIO(0x1300b8)
7812#define  FORCEWAKE_ACK_MEDIA_VLV                _MMIO(0x1300bc)
7813#define  FORCEWAKE_ACK_HSW                      _MMIO(0x130044)
7814#define  FORCEWAKE_ACK                          _MMIO(0x130090)
7815#define  VLV_GTLC_WAKE_CTRL                     _MMIO(0x130090)
7816#define   VLV_GTLC_RENDER_CTX_EXISTS            (1 << 25)
7817#define   VLV_GTLC_MEDIA_CTX_EXISTS             (1 << 24)
7818#define   VLV_GTLC_ALLOWWAKEREQ                 (1 << 0)
7819
7820#define  VLV_GTLC_PW_STATUS                     _MMIO(0x130094)
7821#define   VLV_GTLC_ALLOWWAKEACK                 (1 << 0)
7822#define   VLV_GTLC_ALLOWWAKEERR                 (1 << 1)
7823#define   VLV_GTLC_PW_MEDIA_STATUS_MASK         (1 << 5)
7824#define   VLV_GTLC_PW_RENDER_STATUS_MASK        (1 << 7)
7825#define  FORCEWAKE_MT                           _MMIO(0xa188) /* multi-threaded */
7826#define  FORCEWAKE_MEDIA_GEN9                   _MMIO(0xa270)
7827#define  FORCEWAKE_RENDER_GEN9                  _MMIO(0xa278)
7828#define  FORCEWAKE_BLITTER_GEN9                 _MMIO(0xa188)
7829#define  FORCEWAKE_ACK_MEDIA_GEN9               _MMIO(0x0D88)
7830#define  FORCEWAKE_ACK_RENDER_GEN9              _MMIO(0x0D84)
7831#define  FORCEWAKE_ACK_BLITTER_GEN9             _MMIO(0x130044)
7832#define   FORCEWAKE_KERNEL                      BIT(0)
7833#define   FORCEWAKE_USER                        BIT(1)
7834#define   FORCEWAKE_KERNEL_FALLBACK             BIT(15)
7835#define  FORCEWAKE_MT_ACK                       _MMIO(0x130040)
7836#define  ECOBUS                                 _MMIO(0xa180)
7837#define    FORCEWAKE_MT_ENABLE                  (1<<5)
7838#define  VLV_SPAREG2H                           _MMIO(0xA194)
7839#define  GEN9_PWRGT_DOMAIN_STATUS               _MMIO(0xA2A0)
7840#define   GEN9_PWRGT_MEDIA_STATUS_MASK          (1 << 0)
7841#define   GEN9_PWRGT_RENDER_STATUS_MASK         (1 << 1)
7842
7843#define  GTFIFODBG                              _MMIO(0x120000)
7844#define    GT_FIFO_SBDEDICATE_FREE_ENTRY_CHV    (0x1f << 20)
7845#define    GT_FIFO_FREE_ENTRIES_CHV             (0x7f << 13)
7846#define    GT_FIFO_SBDROPERR                    (1<<6)
7847#define    GT_FIFO_BLOBDROPERR                  (1<<5)
7848#define    GT_FIFO_SB_READ_ABORTERR             (1<<4)
7849#define    GT_FIFO_DROPERR                      (1<<3)
7850#define    GT_FIFO_OVFERR                       (1<<2)
7851#define    GT_FIFO_IAWRERR                      (1<<1)
7852#define    GT_FIFO_IARDERR                      (1<<0)
7853
7854#define  GTFIFOCTL                              _MMIO(0x120008)
7855#define    GT_FIFO_FREE_ENTRIES_MASK            0x7f
7856#define    GT_FIFO_NUM_RESERVED_ENTRIES         20
7857#define    GT_FIFO_CTL_BLOCK_ALL_POLICY_STALL   (1 << 12)
7858#define    GT_FIFO_CTL_RC6_POLICY_STALL         (1 << 11)
7859
7860#define  HSW_IDICR                              _MMIO(0x9008)
7861#define    IDIHASHMSK(x)                        (((x) & 0x3f) << 16)
7862#define  HSW_EDRAM_CAP                          _MMIO(0x120010)
7863#define    EDRAM_ENABLED                        0x1
7864#define    EDRAM_NUM_BANKS(cap)                 (((cap) >> 1) & 0xf)
7865#define    EDRAM_WAYS_IDX(cap)                  (((cap) >> 5) & 0x7)
7866#define    EDRAM_SETS_IDX(cap)                  (((cap) >> 8) & 0x3)
7867
7868#define GEN6_UCGCTL1                            _MMIO(0x9400)
7869# define GEN6_GAMUNIT_CLOCK_GATE_DISABLE                (1 << 22)
7870# define GEN6_EU_TCUNIT_CLOCK_GATE_DISABLE              (1 << 16)
7871# define GEN6_BLBUNIT_CLOCK_GATE_DISABLE                (1 << 5)
7872# define GEN6_CSUNIT_CLOCK_GATE_DISABLE                 (1 << 7)
7873
7874#define GEN6_UCGCTL2                            _MMIO(0x9404)
7875# define GEN6_VFUNIT_CLOCK_GATE_DISABLE                 (1 << 31)
7876# define GEN7_VDSUNIT_CLOCK_GATE_DISABLE                (1 << 30)
7877# define GEN7_TDLUNIT_CLOCK_GATE_DISABLE                (1 << 22)
7878# define GEN6_RCZUNIT_CLOCK_GATE_DISABLE                (1 << 13)
7879# define GEN6_RCPBUNIT_CLOCK_GATE_DISABLE               (1 << 12)
7880# define GEN6_RCCUNIT_CLOCK_GATE_DISABLE                (1 << 11)
7881
7882#define GEN6_UCGCTL3                            _MMIO(0x9408)
7883# define GEN6_OACSUNIT_CLOCK_GATE_DISABLE               (1 << 20)
7884
7885#define GEN7_UCGCTL4                            _MMIO(0x940c)
7886#define  GEN7_L3BANK2X_CLOCK_GATE_DISABLE       (1<<25)
7887#define  GEN8_EU_GAUNIT_CLOCK_GATE_DISABLE      (1<<14)
7888
7889#define GEN6_RCGCTL1                            _MMIO(0x9410)
7890#define GEN6_RCGCTL2                            _MMIO(0x9414)
7891#define GEN6_RSTCTL                             _MMIO(0x9420)
7892
7893#define GEN8_UCGCTL6                            _MMIO(0x9430)
7894#define   GEN8_GAPSUNIT_CLOCK_GATE_DISABLE      (1<<24)
7895#define   GEN8_SDEUNIT_CLOCK_GATE_DISABLE       (1<<14)
7896#define   GEN8_HDCUNIT_CLOCK_GATE_DISABLE_HDCREQ (1<<28)
7897
7898#define GEN6_GFXPAUSE                           _MMIO(0xA000)
7899#define GEN6_RPNSWREQ                           _MMIO(0xA008)
7900#define   GEN6_TURBO_DISABLE                    (1<<31)
7901#define   GEN6_FREQUENCY(x)                     ((x)<<25)
7902#define   HSW_FREQUENCY(x)                      ((x)<<24)
7903#define   GEN9_FREQUENCY(x)                     ((x)<<23)
7904#define   GEN6_OFFSET(x)                        ((x)<<19)
7905#define   GEN6_AGGRESSIVE_TURBO                 (0<<15)
7906#define GEN6_RC_VIDEO_FREQ                      _MMIO(0xA00C)
7907#define GEN6_RC_CONTROL                         _MMIO(0xA090)
7908#define   GEN6_RC_CTL_RC6pp_ENABLE              (1<<16)
7909#define   GEN6_RC_CTL_RC6p_ENABLE               (1<<17)
7910#define   GEN6_RC_CTL_RC6_ENABLE                (1<<18)
7911#define   GEN6_RC_CTL_RC1e_ENABLE               (1<<20)
7912#define   GEN6_RC_CTL_RC7_ENABLE                (1<<22)
7913#define   VLV_RC_CTL_CTX_RST_PARALLEL           (1<<24)
7914#define   GEN7_RC_CTL_TO_MODE                   (1<<28)
7915#define   GEN6_RC_CTL_EI_MODE(x)                ((x)<<27)
7916#define   GEN6_RC_CTL_HW_ENABLE                 (1<<31)
7917#define GEN6_RP_DOWN_TIMEOUT                    _MMIO(0xA010)
7918#define GEN6_RP_INTERRUPT_LIMITS                _MMIO(0xA014)
7919#define GEN6_RPSTAT1                            _MMIO(0xA01C)
7920#define   GEN6_CAGF_SHIFT                       8
7921#define   HSW_CAGF_SHIFT                        7
7922#define   GEN9_CAGF_SHIFT                       23
7923#define   GEN6_CAGF_MASK                        (0x7f << GEN6_CAGF_SHIFT)
7924#define   HSW_CAGF_MASK                         (0x7f << HSW_CAGF_SHIFT)
7925#define   GEN9_CAGF_MASK                        (0x1ff << GEN9_CAGF_SHIFT)
7926#define GEN6_RP_CONTROL                         _MMIO(0xA024)
7927#define   GEN6_RP_MEDIA_TURBO                   (1<<11)
7928#define   GEN6_RP_MEDIA_MODE_MASK               (3<<9)
7929#define   GEN6_RP_MEDIA_HW_TURBO_MODE           (3<<9)
7930#define   GEN6_RP_MEDIA_HW_NORMAL_MODE          (2<<9)
7931#define   GEN6_RP_MEDIA_HW_MODE                 (1<<9)
7932#define   GEN6_RP_MEDIA_SW_MODE                 (0<<9)
7933#define   GEN6_RP_MEDIA_IS_GFX                  (1<<8)
7934#define   GEN6_RP_ENABLE                        (1<<7)
7935#define   GEN6_RP_UP_IDLE_MIN                   (0x1<<3)
7936#define   GEN6_RP_UP_BUSY_AVG                   (0x2<<3)
7937#define   GEN6_RP_UP_BUSY_CONT                  (0x4<<3)
7938#define   GEN6_RP_DOWN_IDLE_AVG                 (0x2<<0)
7939#define   GEN6_RP_DOWN_IDLE_CONT                (0x1<<0)
7940#define GEN6_RP_UP_THRESHOLD                    _MMIO(0xA02C)
7941#define GEN6_RP_DOWN_THRESHOLD                  _MMIO(0xA030)
7942#define GEN6_RP_CUR_UP_EI                       _MMIO(0xA050)
7943#define   GEN6_RP_EI_MASK                       0xffffff
7944#define   GEN6_CURICONT_MASK                    GEN6_RP_EI_MASK
7945#define GEN6_RP_CUR_UP                          _MMIO(0xA054)
7946#define   GEN6_CURBSYTAVG_MASK                  GEN6_RP_EI_MASK
7947#define GEN6_RP_PREV_UP                         _MMIO(0xA058)
7948#define GEN6_RP_CUR_DOWN_EI                     _MMIO(0xA05C)
7949#define   GEN6_CURIAVG_MASK                     GEN6_RP_EI_MASK
7950#define GEN6_RP_CUR_DOWN                        _MMIO(0xA060)
7951#define GEN6_RP_PREV_DOWN                       _MMIO(0xA064)
7952#define GEN6_RP_UP_EI                           _MMIO(0xA068)
7953#define GEN6_RP_DOWN_EI                         _MMIO(0xA06C)
7954#define GEN6_RP_IDLE_HYSTERSIS                  _MMIO(0xA070)
7955#define GEN6_RPDEUHWTC                          _MMIO(0xA080)
7956#define GEN6_RPDEUC                             _MMIO(0xA084)
7957#define GEN6_RPDEUCSW                           _MMIO(0xA088)
7958#define GEN6_RC_STATE                           _MMIO(0xA094)
7959#define   RC_SW_TARGET_STATE_SHIFT              16
7960#define   RC_SW_TARGET_STATE_MASK               (7 << RC_SW_TARGET_STATE_SHIFT)
7961#define GEN6_RC1_WAKE_RATE_LIMIT                _MMIO(0xA098)
7962#define GEN6_RC6_WAKE_RATE_LIMIT                _MMIO(0xA09C)
7963#define GEN6_RC6pp_WAKE_RATE_LIMIT              _MMIO(0xA0A0)
7964#define GEN10_MEDIA_WAKE_RATE_LIMIT             _MMIO(0xA0A0)
7965#define GEN6_RC_EVALUATION_INTERVAL             _MMIO(0xA0A8)
7966#define GEN6_RC_IDLE_HYSTERSIS                  _MMIO(0xA0AC)
7967#define GEN6_RC_SLEEP                           _MMIO(0xA0B0)
7968#define GEN6_RCUBMABDTMR                        _MMIO(0xA0B0)
7969#define GEN6_RC1e_THRESHOLD                     _MMIO(0xA0B4)
7970#define GEN6_RC6_THRESHOLD                      _MMIO(0xA0B8)
7971#define GEN6_RC6p_THRESHOLD                     _MMIO(0xA0BC)
7972#define VLV_RCEDATA                             _MMIO(0xA0BC)
7973#define GEN6_RC6pp_THRESHOLD                    _MMIO(0xA0C0)
7974#define GEN6_PMINTRMSK                          _MMIO(0xA168)
7975#define   GEN8_PMINTR_DISABLE_REDIRECT_TO_GUC   (1<<31)
7976#define   ARAT_EXPIRED_INTRMSK                  (1<<9)
7977#define GEN8_MISC_CTRL0                         _MMIO(0xA180)
7978#define VLV_PWRDWNUPCTL                         _MMIO(0xA294)
7979#define GEN9_MEDIA_PG_IDLE_HYSTERESIS           _MMIO(0xA0C4)
7980#define GEN9_RENDER_PG_IDLE_HYSTERESIS          _MMIO(0xA0C8)
7981#define GEN9_PG_ENABLE                          _MMIO(0xA210)
7982#define GEN9_RENDER_PG_ENABLE                   (1<<0)
7983#define GEN9_MEDIA_PG_ENABLE                    (1<<1)
7984#define GEN8_PUSHBUS_CONTROL                    _MMIO(0xA248)
7985#define GEN8_PUSHBUS_ENABLE                     _MMIO(0xA250)
7986#define GEN8_PUSHBUS_SHIFT                      _MMIO(0xA25C)
7987
7988#define VLV_CHICKEN_3                           _MMIO(VLV_DISPLAY_BASE + 0x7040C)
7989#define  PIXEL_OVERLAP_CNT_MASK                 (3 << 30)
7990#define  PIXEL_OVERLAP_CNT_SHIFT                30
7991
7992#define GEN6_PMISR                              _MMIO(0x44020)
7993#define GEN6_PMIMR                              _MMIO(0x44024) /* rps_lock */
7994#define GEN6_PMIIR                              _MMIO(0x44028)
7995#define GEN6_PMIER                              _MMIO(0x4402C)
7996#define  GEN6_PM_MBOX_EVENT                     (1<<25)
7997#define  GEN6_PM_THERMAL_EVENT                  (1<<24)
7998#define  GEN6_PM_RP_DOWN_TIMEOUT                (1<<6)
7999#define  GEN6_PM_RP_UP_THRESHOLD                (1<<5)
8000#define  GEN6_PM_RP_DOWN_THRESHOLD              (1<<4)
8001#define  GEN6_PM_RP_UP_EI_EXPIRED               (1<<2)
8002#define  GEN6_PM_RP_DOWN_EI_EXPIRED             (1<<1)
8003#define  GEN6_PM_RPS_EVENTS                     (GEN6_PM_RP_UP_THRESHOLD | \
8004                                                 GEN6_PM_RP_DOWN_THRESHOLD | \
8005                                                 GEN6_PM_RP_DOWN_TIMEOUT)
8006
8007#define GEN7_GT_SCRATCH(i)                      _MMIO(0x4F100 + (i) * 4)
8008#define GEN7_GT_SCRATCH_REG_NUM                 8
8009
8010#define VLV_GTLC_SURVIVABILITY_REG              _MMIO(0x130098)
8011#define VLV_GFX_CLK_STATUS_BIT                  (1<<3)
8012#define VLV_GFX_CLK_FORCE_ON_BIT                (1<<2)
8013
8014#define GEN6_GT_GFX_RC6_LOCKED                  _MMIO(0x138104)
8015#define VLV_COUNTER_CONTROL                     _MMIO(0x138104)
8016#define   VLV_COUNT_RANGE_HIGH                  (1<<15)
8017#define   VLV_MEDIA_RC0_COUNT_EN                (1<<5)
8018#define   VLV_RENDER_RC0_COUNT_EN               (1<<4)
8019#define   VLV_MEDIA_RC6_COUNT_EN                (1<<1)
8020#define   VLV_RENDER_RC6_COUNT_EN               (1<<0)
8021#define GEN6_GT_GFX_RC6                         _MMIO(0x138108)
8022#define VLV_GT_RENDER_RC6                       _MMIO(0x138108)
8023#define VLV_GT_MEDIA_RC6                        _MMIO(0x13810C)
8024
8025#define GEN6_GT_GFX_RC6p                        _MMIO(0x13810C)
8026#define GEN6_GT_GFX_RC6pp                       _MMIO(0x138110)
8027#define VLV_RENDER_C0_COUNT                     _MMIO(0x138118)
8028#define VLV_MEDIA_C0_COUNT                      _MMIO(0x13811C)
8029
8030#define GEN6_PCODE_MAILBOX                      _MMIO(0x138124)
8031#define   GEN6_PCODE_READY                      (1<<31)
8032#define   GEN6_PCODE_ERROR_MASK                 0xFF
8033#define     GEN6_PCODE_SUCCESS                  0x0
8034#define     GEN6_PCODE_ILLEGAL_CMD              0x1
8035#define     GEN6_PCODE_MIN_FREQ_TABLE_GT_RATIO_OUT_OF_RANGE 0x2
8036#define     GEN6_PCODE_TIMEOUT                  0x3
8037#define     GEN6_PCODE_UNIMPLEMENTED_CMD        0xFF
8038#define     GEN7_PCODE_TIMEOUT                  0x2
8039#define     GEN7_PCODE_ILLEGAL_DATA             0x3
8040#define     GEN7_PCODE_MIN_FREQ_TABLE_GT_RATIO_OUT_OF_RANGE 0x10
8041#define   GEN6_PCODE_WRITE_RC6VIDS              0x4
8042#define   GEN6_PCODE_READ_RC6VIDS               0x5
8043#define     GEN6_ENCODE_RC6_VID(mv)             (((mv) - 245) / 5)
8044#define     GEN6_DECODE_RC6_VID(vids)           (((vids) * 5) + 245)
8045#define   BDW_PCODE_DISPLAY_FREQ_CHANGE_REQ     0x18
8046#define   GEN9_PCODE_READ_MEM_LATENCY           0x6
8047#define     GEN9_MEM_LATENCY_LEVEL_MASK         0xFF
8048#define     GEN9_MEM_LATENCY_LEVEL_1_5_SHIFT    8
8049#define     GEN9_MEM_LATENCY_LEVEL_2_6_SHIFT    16
8050#define     GEN9_MEM_LATENCY_LEVEL_3_7_SHIFT    24
8051#define   SKL_PCODE_CDCLK_CONTROL               0x7
8052#define     SKL_CDCLK_PREPARE_FOR_CHANGE        0x3
8053#define     SKL_CDCLK_READY_FOR_CHANGE          0x1
8054#define   GEN6_PCODE_WRITE_MIN_FREQ_TABLE       0x8
8055#define   GEN6_PCODE_READ_MIN_FREQ_TABLE        0x9
8056#define   GEN6_READ_OC_PARAMS                   0xc
8057#define   GEN6_PCODE_READ_D_COMP                0x10
8058#define   GEN6_PCODE_WRITE_D_COMP               0x11
8059#define   HSW_PCODE_DE_WRITE_FREQ_REQ           0x17
8060#define   DISPLAY_IPS_CONTROL                   0x19
8061            /* See also IPS_CTL */
8062#define     IPS_PCODE_CONTROL                   (1 << 30)
8063#define   HSW_PCODE_DYNAMIC_DUTY_CYCLE_CONTROL  0x1A
8064#define   GEN9_PCODE_SAGV_CONTROL               0x21
8065#define     GEN9_SAGV_DISABLE                   0x0
8066#define     GEN9_SAGV_IS_DISABLED               0x1
8067#define     GEN9_SAGV_ENABLE                    0x3
8068#define GEN6_PCODE_DATA                         _MMIO(0x138128)
8069#define   GEN6_PCODE_FREQ_IA_RATIO_SHIFT        8
8070#define   GEN6_PCODE_FREQ_RING_RATIO_SHIFT      16
8071#define GEN6_PCODE_DATA1                        _MMIO(0x13812C)
8072
8073#define GEN6_GT_CORE_STATUS             _MMIO(0x138060)
8074#define   GEN6_CORE_CPD_STATE_MASK      (7<<4)
8075#define   GEN6_RCn_MASK                 7
8076#define   GEN6_RC0                      0
8077#define   GEN6_RC3                      2
8078#define   GEN6_RC6                      3
8079#define   GEN6_RC7                      4
8080
8081#define GEN8_GT_SLICE_INFO              _MMIO(0x138064)
8082#define   GEN8_LSLICESTAT_MASK          0x7
8083
8084#define CHV_POWER_SS0_SIG1              _MMIO(0xa720)
8085#define CHV_POWER_SS1_SIG1              _MMIO(0xa728)
8086#define   CHV_SS_PG_ENABLE              (1<<1)
8087#define   CHV_EU08_PG_ENABLE            (1<<9)
8088#define   CHV_EU19_PG_ENABLE            (1<<17)
8089#define   CHV_EU210_PG_ENABLE           (1<<25)
8090
8091#define CHV_POWER_SS0_SIG2              _MMIO(0xa724)
8092#define CHV_POWER_SS1_SIG2              _MMIO(0xa72c)
8093#define   CHV_EU311_PG_ENABLE           (1<<1)
8094
8095#define GEN9_SLICE_PGCTL_ACK(slice)     _MMIO(0x804c + (slice)*0x4)
8096#define GEN10_SLICE_PGCTL_ACK(slice)    _MMIO(0x804c + ((slice) / 3) * 0x34 + \
8097                                              ((slice) % 3) * 0x4)
8098#define   GEN9_PGCTL_SLICE_ACK          (1 << 0)
8099#define   GEN9_PGCTL_SS_ACK(subslice)   (1 << (2 + (subslice)*2))
8100#define   GEN10_PGCTL_VALID_SS_MASK(slice) ((slice) == 0 ? 0x7F : 0x1F)
8101
8102#define GEN9_SS01_EU_PGCTL_ACK(slice)   _MMIO(0x805c + (slice)*0x8)
8103#define GEN10_SS01_EU_PGCTL_ACK(slice)  _MMIO(0x805c + ((slice) / 3) * 0x30 + \
8104                                              ((slice) % 3) * 0x8)
8105#define GEN9_SS23_EU_PGCTL_ACK(slice)   _MMIO(0x8060 + (slice)*0x8)
8106#define GEN10_SS23_EU_PGCTL_ACK(slice)  _MMIO(0x8060 + ((slice) / 3) * 0x30 + \
8107                                              ((slice) % 3) * 0x8)
8108#define   GEN9_PGCTL_SSA_EU08_ACK       (1 << 0)
8109#define   GEN9_PGCTL_SSA_EU19_ACK       (1 << 2)
8110#define   GEN9_PGCTL_SSA_EU210_ACK      (1 << 4)
8111#define   GEN9_PGCTL_SSA_EU311_ACK      (1 << 6)
8112#define   GEN9_PGCTL_SSB_EU08_ACK       (1 << 8)
8113#define   GEN9_PGCTL_SSB_EU19_ACK       (1 << 10)
8114#define   GEN9_PGCTL_SSB_EU210_ACK      (1 << 12)
8115#define   GEN9_PGCTL_SSB_EU311_ACK      (1 << 14)
8116
8117#define GEN7_MISCCPCTL                          _MMIO(0x9424)
8118#define   GEN7_DOP_CLOCK_GATE_ENABLE            (1<<0)
8119#define   GEN8_DOP_CLOCK_GATE_CFCLK_ENABLE      (1<<2)
8120#define   GEN8_DOP_CLOCK_GATE_GUC_ENABLE        (1<<4)
8121#define   GEN8_DOP_CLOCK_GATE_MEDIA_ENABLE     (1<<6)
8122
8123#define GEN8_GARBCNTL                   _MMIO(0xB004)
8124#define   GEN9_GAPS_TSV_CREDIT_DISABLE  (1<<7)
8125
8126/* IVYBRIDGE DPF */
8127#define GEN7_L3CDERRST1(slice)          _MMIO(0xB008 + (slice) * 0x200) /* L3CD Error Status 1 */
8128#define   GEN7_L3CDERRST1_ROW_MASK      (0x7ff<<14)
8129#define   GEN7_PARITY_ERROR_VALID       (1<<13)
8130#define   GEN7_L3CDERRST1_BANK_MASK     (3<<11)
8131#define   GEN7_L3CDERRST1_SUBBANK_MASK  (7<<8)
8132#define GEN7_PARITY_ERROR_ROW(reg) \
8133                ((reg & GEN7_L3CDERRST1_ROW_MASK) >> 14)
8134#define GEN7_PARITY_ERROR_BANK(reg) \
8135                ((reg & GEN7_L3CDERRST1_BANK_MASK) >> 11)
8136#define GEN7_PARITY_ERROR_SUBBANK(reg) \
8137                ((reg & GEN7_L3CDERRST1_SUBBANK_MASK) >> 8)
8138#define   GEN7_L3CDERRST1_ENABLE        (1<<7)
8139
8140#define GEN7_L3LOG(slice, i)            _MMIO(0xB070 + (slice) * 0x200 + (i) * 4)
8141#define GEN7_L3LOG_SIZE                 0x80
8142
8143#define GEN7_HALF_SLICE_CHICKEN1        _MMIO(0xe100) /* IVB GT1 + VLV */
8144#define GEN7_HALF_SLICE_CHICKEN1_GT2    _MMIO(0xf100)
8145#define   GEN7_MAX_PS_THREAD_DEP                (8<<12)
8146#define   GEN7_SINGLE_SUBSCAN_DISPATCH_ENABLE   (1<<10)
8147#define   GEN7_SBE_SS_CACHE_DISPATCH_PORT_SHARING_DISABLE       (1<<4)
8148#define   GEN7_PSD_SINGLE_PORT_DISPATCH_ENABLE  (1<<3)
8149
8150#define GEN9_HALF_SLICE_CHICKEN5        _MMIO(0xe188)
8151#define   GEN9_DG_MIRROR_FIX_ENABLE     (1<<5)
8152#define   GEN9_CCS_TLB_PREFETCH_ENABLE  (1<<3)
8153
8154#define GEN8_ROW_CHICKEN                _MMIO(0xe4f0)
8155#define   FLOW_CONTROL_ENABLE           (1<<15)
8156#define   PARTIAL_INSTRUCTION_SHOOTDOWN_DISABLE (1<<8)
8157#define   STALL_DOP_GATING_DISABLE              (1<<5)
8158#define   THROTTLE_12_5                         (7<<2)
8159#define   DISABLE_EARLY_EOT                     (1<<1)
8160
8161#define GEN7_ROW_CHICKEN2               _MMIO(0xe4f4)
8162#define GEN7_ROW_CHICKEN2_GT2           _MMIO(0xf4f4)
8163#define   DOP_CLOCK_GATING_DISABLE      (1<<0)
8164#define   PUSH_CONSTANT_DEREF_DISABLE   (1<<8)
8165
8166#define HSW_ROW_CHICKEN3                _MMIO(0xe49c)
8167#define  HSW_ROW_CHICKEN3_L3_GLOBAL_ATOMICS_DISABLE    (1 << 6)
8168
8169#define HALF_SLICE_CHICKEN2             _MMIO(0xe180)
8170#define   GEN8_ST_PO_DISABLE            (1<<13)
8171
8172#define HALF_SLICE_CHICKEN3             _MMIO(0xe184)
8173#define   HSW_SAMPLE_C_PERFORMANCE      (1<<9)
8174#define   GEN8_CENTROID_PIXEL_OPT_DIS   (1<<8)
8175#define   GEN9_DISABLE_OCL_OOB_SUPPRESS_LOGIC   (1<<5)
8176#define   CNL_FAST_ANISO_L1_BANKING_FIX (1<<4)
8177#define   GEN8_SAMPLER_POWER_BYPASS_DIS (1<<1)
8178
8179#define GEN9_HALF_SLICE_CHICKEN7        _MMIO(0xe194)
8180#define   GEN9_SAMPLER_HASH_COMPRESSED_READ_ADDR        (1<<8)
8181#define   GEN9_ENABLE_YV12_BUGFIX       (1<<4)
8182#define   GEN9_ENABLE_GPGPU_PREEMPTION  (1<<2)
8183
8184/* Audio */
8185#define G4X_AUD_VID_DID                 _MMIO(dev_priv->info.display_mmio_offset + 0x62020)
8186#define   INTEL_AUDIO_DEVCL             0x808629FB
8187#define   INTEL_AUDIO_DEVBLC            0x80862801
8188#define   INTEL_AUDIO_DEVCTG            0x80862802
8189
8190#define G4X_AUD_CNTL_ST                 _MMIO(0x620B4)
8191#define   G4X_ELDV_DEVCL_DEVBLC         (1 << 13)
8192#define   G4X_ELDV_DEVCTG               (1 << 14)
8193#define   G4X_ELD_ADDR_MASK             (0xf << 5)
8194#define   G4X_ELD_ACK                   (1 << 4)
8195#define G4X_HDMIW_HDMIEDID              _MMIO(0x6210C)
8196
8197#define _IBX_HDMIW_HDMIEDID_A           0xE2050
8198#define _IBX_HDMIW_HDMIEDID_B           0xE2150
8199#define IBX_HDMIW_HDMIEDID(pipe)        _MMIO_PIPE(pipe, _IBX_HDMIW_HDMIEDID_A, \
8200                                                  _IBX_HDMIW_HDMIEDID_B)
8201#define _IBX_AUD_CNTL_ST_A              0xE20B4
8202#define _IBX_AUD_CNTL_ST_B              0xE21B4
8203#define IBX_AUD_CNTL_ST(pipe)           _MMIO_PIPE(pipe, _IBX_AUD_CNTL_ST_A, \
8204                                                  _IBX_AUD_CNTL_ST_B)
8205#define   IBX_ELD_BUFFER_SIZE_MASK      (0x1f << 10)
8206#define   IBX_ELD_ADDRESS_MASK          (0x1f << 5)
8207#define   IBX_ELD_ACK                   (1 << 4)
8208#define IBX_AUD_CNTL_ST2                _MMIO(0xE20C0)
8209#define   IBX_CP_READY(port)            ((1 << 1) << (((port) - 1) * 4))
8210#define   IBX_ELD_VALID(port)           ((1 << 0) << (((port) - 1) * 4))
8211
8212#define _CPT_HDMIW_HDMIEDID_A           0xE5050
8213#define _CPT_HDMIW_HDMIEDID_B           0xE5150
8214#define CPT_HDMIW_HDMIEDID(pipe)        _MMIO_PIPE(pipe, _CPT_HDMIW_HDMIEDID_A, _CPT_HDMIW_HDMIEDID_B)
8215#define _CPT_AUD_CNTL_ST_A              0xE50B4
8216#define _CPT_AUD_CNTL_ST_B              0xE51B4
8217#define CPT_AUD_CNTL_ST(pipe)           _MMIO_PIPE(pipe, _CPT_AUD_CNTL_ST_A, _CPT_AUD_CNTL_ST_B)
8218#define CPT_AUD_CNTRL_ST2               _MMIO(0xE50C0)
8219
8220#define _VLV_HDMIW_HDMIEDID_A           (VLV_DISPLAY_BASE + 0x62050)
8221#define _VLV_HDMIW_HDMIEDID_B           (VLV_DISPLAY_BASE + 0x62150)
8222#define VLV_HDMIW_HDMIEDID(pipe)        _MMIO_PIPE(pipe, _VLV_HDMIW_HDMIEDID_A, _VLV_HDMIW_HDMIEDID_B)
8223#define _VLV_AUD_CNTL_ST_A              (VLV_DISPLAY_BASE + 0x620B4)
8224#define _VLV_AUD_CNTL_ST_B              (VLV_DISPLAY_BASE + 0x621B4)
8225#define VLV_AUD_CNTL_ST(pipe)           _MMIO_PIPE(pipe, _VLV_AUD_CNTL_ST_A, _VLV_AUD_CNTL_ST_B)
8226#define VLV_AUD_CNTL_ST2                _MMIO(VLV_DISPLAY_BASE + 0x620C0)
8227
8228/* These are the 4 32-bit write offset registers for each stream
8229 * output buffer.  It determines the offset from the
8230 * 3DSTATE_SO_BUFFERs that the next streamed vertex output goes to.
8231 */
8232#define GEN7_SO_WRITE_OFFSET(n)         _MMIO(0x5280 + (n) * 4)
8233
8234#define _IBX_AUD_CONFIG_A               0xe2000
8235#define _IBX_AUD_CONFIG_B               0xe2100
8236#define IBX_AUD_CFG(pipe)               _MMIO_PIPE(pipe, _IBX_AUD_CONFIG_A, _IBX_AUD_CONFIG_B)
8237#define _CPT_AUD_CONFIG_A               0xe5000
8238#define _CPT_AUD_CONFIG_B               0xe5100
8239#define CPT_AUD_CFG(pipe)               _MMIO_PIPE(pipe, _CPT_AUD_CONFIG_A, _CPT_AUD_CONFIG_B)
8240#define _VLV_AUD_CONFIG_A               (VLV_DISPLAY_BASE + 0x62000)
8241#define _VLV_AUD_CONFIG_B               (VLV_DISPLAY_BASE + 0x62100)
8242#define VLV_AUD_CFG(pipe)               _MMIO_PIPE(pipe, _VLV_AUD_CONFIG_A, _VLV_AUD_CONFIG_B)
8243
8244#define   AUD_CONFIG_N_VALUE_INDEX              (1 << 29)
8245#define   AUD_CONFIG_N_PROG_ENABLE              (1 << 28)
8246#define   AUD_CONFIG_UPPER_N_SHIFT              20
8247#define   AUD_CONFIG_UPPER_N_MASK               (0xff << 20)
8248#define   AUD_CONFIG_LOWER_N_SHIFT              4
8249#define   AUD_CONFIG_LOWER_N_MASK               (0xfff << 4)
8250#define   AUD_CONFIG_N_MASK                     (AUD_CONFIG_UPPER_N_MASK | AUD_CONFIG_LOWER_N_MASK)
8251#define   AUD_CONFIG_N(n) \
8252        (((((n) >> 12) & 0xff) << AUD_CONFIG_UPPER_N_SHIFT) |   \
8253         (((n) & 0xfff) << AUD_CONFIG_LOWER_N_SHIFT))
8254#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_SHIFT     16
8255#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK      (0xf << 16)
8256#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_25175     (0 << 16)
8257#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_25200     (1 << 16)
8258#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_27000     (2 << 16)
8259#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_27027     (3 << 16)
8260#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_54000     (4 << 16)
8261#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_54054     (5 << 16)
8262#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_74176     (6 << 16)
8263#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_74250     (7 << 16)
8264#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_148352    (8 << 16)
8265#define   AUD_CONFIG_PIXEL_CLOCK_HDMI_148500    (9 << 16)
8266#define   AUD_CONFIG_DISABLE_NCTS               (1 << 3)
8267
8268/* HSW Audio */
8269#define _HSW_AUD_CONFIG_A               0x65000
8270#define _HSW_AUD_CONFIG_B               0x65100
8271#define HSW_AUD_CFG(pipe)               _MMIO_PIPE(pipe, _HSW_AUD_CONFIG_A, _HSW_AUD_CONFIG_B)
8272
8273#define _HSW_AUD_MISC_CTRL_A            0x65010
8274#define _HSW_AUD_MISC_CTRL_B            0x65110
8275#define HSW_AUD_MISC_CTRL(pipe)         _MMIO_PIPE(pipe, _HSW_AUD_MISC_CTRL_A, _HSW_AUD_MISC_CTRL_B)
8276
8277#define _HSW_AUD_M_CTS_ENABLE_A         0x65028
8278#define _HSW_AUD_M_CTS_ENABLE_B         0x65128
8279#define HSW_AUD_M_CTS_ENABLE(pipe)      _MMIO_PIPE(pipe, _HSW_AUD_M_CTS_ENABLE_A, _HSW_AUD_M_CTS_ENABLE_B)
8280#define   AUD_M_CTS_M_VALUE_INDEX       (1 << 21)
8281#define   AUD_M_CTS_M_PROG_ENABLE       (1 << 20)
8282#define   AUD_CONFIG_M_MASK             0xfffff
8283
8284#define _HSW_AUD_DIP_ELD_CTRL_ST_A      0x650b4
8285#define _HSW_AUD_DIP_ELD_CTRL_ST_B      0x651b4
8286#define HSW_AUD_DIP_ELD_CTRL(pipe)      _MMIO_PIPE(pipe, _HSW_AUD_DIP_ELD_CTRL_ST_A, _HSW_AUD_DIP_ELD_CTRL_ST_B)
8287
8288/* Audio Digital Converter */
8289#define _HSW_AUD_DIG_CNVT_1             0x65080
8290#define _HSW_AUD_DIG_CNVT_2             0x65180
8291#define AUD_DIG_CNVT(pipe)              _MMIO_PIPE(pipe, _HSW_AUD_DIG_CNVT_1, _HSW_AUD_DIG_CNVT_2)
8292#define DIP_PORT_SEL_MASK               0x3
8293
8294#define _HSW_AUD_EDID_DATA_A            0x65050
8295#define _HSW_AUD_EDID_DATA_B            0x65150
8296#define HSW_AUD_EDID_DATA(pipe)         _MMIO_PIPE(pipe, _HSW_AUD_EDID_DATA_A, _HSW_AUD_EDID_DATA_B)
8297
8298#define HSW_AUD_PIPE_CONV_CFG           _MMIO(0x6507c)
8299#define HSW_AUD_PIN_ELD_CP_VLD          _MMIO(0x650c0)
8300#define   AUDIO_INACTIVE(trans)         ((1 << 3) << ((trans) * 4))
8301#define   AUDIO_OUTPUT_ENABLE(trans)    ((1 << 2) << ((trans) * 4))
8302#define   AUDIO_CP_READY(trans)         ((1 << 1) << ((trans) * 4))
8303#define   AUDIO_ELD_VALID(trans)        ((1 << 0) << ((trans) * 4))
8304
8305#define HSW_AUD_CHICKENBIT                      _MMIO(0x65f10)
8306#define   SKL_AUD_CODEC_WAKE_SIGNAL             (1 << 15)
8307
8308/* HSW Power Wells */
8309#define _HSW_PWR_WELL_CTL1                      0x45400
8310#define _HSW_PWR_WELL_CTL2                      0x45404
8311#define _HSW_PWR_WELL_CTL3                      0x45408
8312#define _HSW_PWR_WELL_CTL4                      0x4540C
8313
8314/*
8315 * Each power well control register contains up to 16 (request, status) HW
8316 * flag tuples. The register index and HW flag shift is determined by the
8317 * power well ID (see i915_power_well_id). There are 4 possible sources of
8318 * power well requests each source having its own set of control registers:
8319 * BIOS, DRIVER, KVMR, DEBUG.
8320 */
8321#define _HSW_PW_REG_IDX(pw)                     ((pw) >> 4)
8322#define _HSW_PW_SHIFT(pw)                       (((pw) & 0xf) * 2)
8323/* TODO: Add all PWR_WELL_CTL registers below for new platforms */
8324#define HSW_PWR_WELL_CTL_BIOS(pw)       _MMIO(_PICK(_HSW_PW_REG_IDX(pw),       \
8325                                                    _HSW_PWR_WELL_CTL1))
8326#define HSW_PWR_WELL_CTL_DRIVER(pw)     _MMIO(_PICK(_HSW_PW_REG_IDX(pw),       \
8327                                                    _HSW_PWR_WELL_CTL2))
8328#define HSW_PWR_WELL_CTL_KVMR           _MMIO(_HSW_PWR_WELL_CTL3)
8329#define HSW_PWR_WELL_CTL_DEBUG(pw)      _MMIO(_PICK(_HSW_PW_REG_IDX(pw),       \
8330                                                    _HSW_PWR_WELL_CTL4))
8331
8332#define   HSW_PWR_WELL_CTL_REQ(pw)              (1 << (_HSW_PW_SHIFT(pw) + 1))
8333#define   HSW_PWR_WELL_CTL_STATE(pw)            (1 << _HSW_PW_SHIFT(pw))
8334#define HSW_PWR_WELL_CTL5                       _MMIO(0x45410)
8335#define   HSW_PWR_WELL_ENABLE_SINGLE_STEP       (1<<31)
8336#define   HSW_PWR_WELL_PWR_GATE_OVERRIDE        (1<<20)
8337#define   HSW_PWR_WELL_FORCE_ON                 (1<<19)
8338#define HSW_PWR_WELL_CTL6                       _MMIO(0x45414)
8339
8340/* SKL Fuse Status */
8341enum skl_power_gate {
8342        SKL_PG0,
8343        SKL_PG1,
8344        SKL_PG2,
8345};
8346
8347#define SKL_FUSE_STATUS                         _MMIO(0x42000)
8348#define  SKL_FUSE_DOWNLOAD_STATUS               (1<<31)
8349/* PG0 (HW control->no power well ID), PG1..PG2 (SKL_DISP_PW1..SKL_DISP_PW2) */
8350#define  SKL_PW_TO_PG(pw)                       ((pw) - SKL_DISP_PW_1 + SKL_PG1)
8351#define  SKL_FUSE_PG_DIST_STATUS(pg)            (1 << (27 - (pg)))
8352
8353/* Per-pipe DDI Function Control */
8354#define _TRANS_DDI_FUNC_CTL_A           0x60400
8355#define _TRANS_DDI_FUNC_CTL_B           0x61400
8356#define _TRANS_DDI_FUNC_CTL_C           0x62400
8357#define _TRANS_DDI_FUNC_CTL_EDP         0x6F400
8358#define TRANS_DDI_FUNC_CTL(tran) _MMIO_TRANS2(tran, _TRANS_DDI_FUNC_CTL_A)
8359
8360#define  TRANS_DDI_FUNC_ENABLE          (1<<31)
8361/* Those bits are ignored by pipe EDP since it can only connect to DDI A */
8362#define  TRANS_DDI_PORT_MASK            (7<<28)
8363#define  TRANS_DDI_PORT_SHIFT           28
8364#define  TRANS_DDI_SELECT_PORT(x)       ((x)<<28)
8365#define  TRANS_DDI_PORT_NONE            (0<<28)
8366#define  TRANS_DDI_MODE_SELECT_MASK     (7<<24)
8367#define  TRANS_DDI_MODE_SELECT_HDMI     (0<<24)
8368#define  TRANS_DDI_MODE_SELECT_DVI      (1<<24)
8369#define  TRANS_DDI_MODE_SELECT_DP_SST   (2<<24)
8370#define  TRANS_DDI_MODE_SELECT_DP_MST   (3<<24)
8371#define  TRANS_DDI_MODE_SELECT_FDI      (4<<24)
8372#define  TRANS_DDI_BPC_MASK             (7<<20)
8373#define  TRANS_DDI_BPC_8                (0<<20)
8374#define  TRANS_DDI_BPC_10               (1<<20)
8375#define  TRANS_DDI_BPC_6                (2<<20)
8376#define  TRANS_DDI_BPC_12               (3<<20)
8377#define  TRANS_DDI_PVSYNC               (1<<17)
8378#define  TRANS_DDI_PHSYNC               (1<<16)
8379#define  TRANS_DDI_EDP_INPUT_MASK       (7<<12)
8380#define  TRANS_DDI_EDP_INPUT_A_ON       (0<<12)
8381#define  TRANS_DDI_EDP_INPUT_A_ONOFF    (4<<12)
8382#define  TRANS_DDI_EDP_INPUT_B_ONOFF    (5<<12)
8383#define  TRANS_DDI_EDP_INPUT_C_ONOFF    (6<<12)
8384#define  TRANS_DDI_DP_VC_PAYLOAD_ALLOC  (1<<8)
8385#define  TRANS_DDI_HDMI_SCRAMBLER_CTS_ENABLE (1<<7)
8386#define  TRANS_DDI_HDMI_SCRAMBLER_RESET_FREQ (1<<6)
8387#define  TRANS_DDI_BFI_ENABLE           (1<<4)
8388#define  TRANS_DDI_HIGH_TMDS_CHAR_RATE  (1<<4)
8389#define  TRANS_DDI_HDMI_SCRAMBLING      (1<<0)
8390#define  TRANS_DDI_HDMI_SCRAMBLING_MASK (TRANS_DDI_HDMI_SCRAMBLER_CTS_ENABLE \
8391                                        | TRANS_DDI_HDMI_SCRAMBLER_RESET_FREQ \
8392                                        | TRANS_DDI_HDMI_SCRAMBLING)
8393
8394/* DisplayPort Transport Control */
8395#define _DP_TP_CTL_A                    0x64040
8396#define _DP_TP_CTL_B                    0x64140
8397#define DP_TP_CTL(port) _MMIO_PORT(port, _DP_TP_CTL_A, _DP_TP_CTL_B)
8398#define  DP_TP_CTL_ENABLE                       (1<<31)
8399#define  DP_TP_CTL_MODE_SST                     (0<<27)
8400#define  DP_TP_CTL_MODE_MST                     (1<<27)
8401#define  DP_TP_CTL_FORCE_ACT                    (1<<25)
8402#define  DP_TP_CTL_ENHANCED_FRAME_ENABLE        (1<<18)
8403#define  DP_TP_CTL_FDI_AUTOTRAIN                (1<<15)
8404#define  DP_TP_CTL_LINK_TRAIN_MASK              (7<<8)
8405#define  DP_TP_CTL_LINK_TRAIN_PAT1              (0<<8)
8406#define  DP_TP_CTL_LINK_TRAIN_PAT2              (1<<8)
8407#define  DP_TP_CTL_LINK_TRAIN_PAT3              (4<<8)
8408#define  DP_TP_CTL_LINK_TRAIN_IDLE              (2<<8)
8409#define  DP_TP_CTL_LINK_TRAIN_NORMAL            (3<<8)
8410#define  DP_TP_CTL_SCRAMBLE_DISABLE             (1<<7)
8411
8412/* DisplayPort Transport Status */
8413#define _DP_TP_STATUS_A                 0x64044
8414#define _DP_TP_STATUS_B                 0x64144
8415#define DP_TP_STATUS(port) _MMIO_PORT(port, _DP_TP_STATUS_A, _DP_TP_STATUS_B)
8416#define  DP_TP_STATUS_IDLE_DONE                 (1<<25)
8417#define  DP_TP_STATUS_ACT_SENT                  (1<<24)
8418#define  DP_TP_STATUS_MODE_STATUS_MST           (1<<23)
8419#define  DP_TP_STATUS_AUTOTRAIN_DONE            (1<<12)
8420#define  DP_TP_STATUS_PAYLOAD_MAPPING_VC2       (3 << 8)
8421#define  DP_TP_STATUS_PAYLOAD_MAPPING_VC1       (3 << 4)
8422#define  DP_TP_STATUS_PAYLOAD_MAPPING_VC0       (3 << 0)
8423
8424/* DDI Buffer Control */
8425#define _DDI_BUF_CTL_A                          0x64000
8426#define _DDI_BUF_CTL_B                          0x64100
8427#define DDI_BUF_CTL(port) _MMIO_PORT(port, _DDI_BUF_CTL_A, _DDI_BUF_CTL_B)
8428#define  DDI_BUF_CTL_ENABLE                     (1<<31)
8429#define  DDI_BUF_TRANS_SELECT(n)        ((n) << 24)
8430#define  DDI_BUF_EMP_MASK                       (0xf<<24)
8431#define  DDI_BUF_PORT_REVERSAL                  (1<<16)
8432#define  DDI_BUF_IS_IDLE                        (1<<7)
8433#define  DDI_A_4_LANES                          (1<<4)
8434#define  DDI_PORT_WIDTH(width)                  (((width) - 1) << 1)
8435#define  DDI_PORT_WIDTH_MASK                    (7 << 1)
8436#define  DDI_PORT_WIDTH_SHIFT                   1
8437#define  DDI_INIT_DISPLAY_DETECTED              (1<<0)
8438
8439/* DDI Buffer Translations */
8440#define _DDI_BUF_TRANS_A                0x64E00
8441#define _DDI_BUF_TRANS_B                0x64E60
8442#define DDI_BUF_TRANS_LO(port, i)       _MMIO(_PORT(port, _DDI_BUF_TRANS_A, _DDI_BUF_TRANS_B) + (i) * 8)
8443#define  DDI_BUF_BALANCE_LEG_ENABLE     (1 << 31)
8444#define DDI_BUF_TRANS_HI(port, i)       _MMIO(_PORT(port, _DDI_BUF_TRANS_A, _DDI_BUF_TRANS_B) + (i) * 8 + 4)
8445
8446/* Sideband Interface (SBI) is programmed indirectly, via
8447 * SBI_ADDR, which contains the register offset; and SBI_DATA,
8448 * which contains the payload */
8449#define SBI_ADDR                        _MMIO(0xC6000)
8450#define SBI_DATA                        _MMIO(0xC6004)
8451#define SBI_CTL_STAT                    _MMIO(0xC6008)
8452#define  SBI_CTL_DEST_ICLK              (0x0<<16)
8453#define  SBI_CTL_DEST_MPHY              (0x1<<16)
8454#define  SBI_CTL_OP_IORD                (0x2<<8)
8455#define  SBI_CTL_OP_IOWR                (0x3<<8)
8456#define  SBI_CTL_OP_CRRD                (0x6<<8)
8457#define  SBI_CTL_OP_CRWR                (0x7<<8)
8458#define  SBI_RESPONSE_FAIL              (0x1<<1)
8459#define  SBI_RESPONSE_SUCCESS           (0x0<<1)
8460#define  SBI_BUSY                       (0x1<<0)
8461#define  SBI_READY                      (0x0<<0)
8462
8463/* SBI offsets */
8464#define  SBI_SSCDIVINTPHASE                     0x0200
8465#define  SBI_SSCDIVINTPHASE6                    0x0600
8466#define   SBI_SSCDIVINTPHASE_DIVSEL_SHIFT       1
8467#define   SBI_SSCDIVINTPHASE_DIVSEL_MASK        (0x7f<<1)
8468#define   SBI_SSCDIVINTPHASE_DIVSEL(x)          ((x)<<1)
8469#define   SBI_SSCDIVINTPHASE_INCVAL_SHIFT       8
8470#define   SBI_SSCDIVINTPHASE_INCVAL_MASK        (0x7f<<8)
8471#define   SBI_SSCDIVINTPHASE_INCVAL(x)          ((x)<<8)
8472#define   SBI_SSCDIVINTPHASE_DIR(x)             ((x)<<15)
8473#define   SBI_SSCDIVINTPHASE_PROPAGATE          (1<<0)
8474#define  SBI_SSCDITHPHASE                       0x0204
8475#define  SBI_SSCCTL                             0x020c
8476#define  SBI_SSCCTL6                            0x060C
8477#define   SBI_SSCCTL_PATHALT                    (1<<3)
8478#define   SBI_SSCCTL_DISABLE                    (1<<0)
8479#define  SBI_SSCAUXDIV6                         0x0610
8480#define   SBI_SSCAUXDIV_FINALDIV2SEL_SHIFT      4
8481#define   SBI_SSCAUXDIV_FINALDIV2SEL_MASK       (1<<4)
8482#define   SBI_SSCAUXDIV_FINALDIV2SEL(x)         ((x)<<4)
8483#define  SBI_DBUFF0                             0x2a00
8484#define  SBI_GEN0                               0x1f00
8485#define   SBI_GEN0_CFG_BUFFENABLE_DISABLE       (1<<0)
8486
8487/* LPT PIXCLK_GATE */
8488#define PIXCLK_GATE                     _MMIO(0xC6020)
8489#define  PIXCLK_GATE_UNGATE             (1<<0)
8490#define  PIXCLK_GATE_GATE               (0<<0)
8491
8492/* SPLL */
8493#define SPLL_CTL                        _MMIO(0x46020)
8494#define  SPLL_PLL_ENABLE                (1<<31)
8495#define  SPLL_PLL_SSC                   (1<<28)
8496#define  SPLL_PLL_NON_SSC               (2<<28)
8497#define  SPLL_PLL_LCPLL                 (3<<28)
8498#define  SPLL_PLL_REF_MASK              (3<<28)
8499#define  SPLL_PLL_FREQ_810MHz           (0<<26)
8500#define  SPLL_PLL_FREQ_1350MHz          (1<<26)
8501#define  SPLL_PLL_FREQ_2700MHz          (2<<26)
8502#define  SPLL_PLL_FREQ_MASK             (3<<26)
8503
8504/* WRPLL */
8505#define _WRPLL_CTL1                     0x46040
8506#define _WRPLL_CTL2                     0x46060
8507#define WRPLL_CTL(pll)                  _MMIO_PIPE(pll, _WRPLL_CTL1, _WRPLL_CTL2)
8508#define  WRPLL_PLL_ENABLE               (1<<31)
8509#define  WRPLL_PLL_SSC                  (1<<28)
8510#define  WRPLL_PLL_NON_SSC              (2<<28)
8511#define  WRPLL_PLL_LCPLL                (3<<28)
8512#define  WRPLL_PLL_REF_MASK             (3<<28)
8513/* WRPLL divider programming */
8514#define  WRPLL_DIVIDER_REFERENCE(x)     ((x)<<0)
8515#define  WRPLL_DIVIDER_REF_MASK         (0xff)
8516#define  WRPLL_DIVIDER_POST(x)          ((x)<<8)
8517#define  WRPLL_DIVIDER_POST_MASK        (0x3f<<8)
8518#define  WRPLL_DIVIDER_POST_SHIFT       8
8519#define  WRPLL_DIVIDER_FEEDBACK(x)      ((x)<<16)
8520#define  WRPLL_DIVIDER_FB_SHIFT         16
8521#define  WRPLL_DIVIDER_FB_MASK          (0xff<<16)
8522
8523/* Port clock selection */
8524#define _PORT_CLK_SEL_A                 0x46100
8525#define _PORT_CLK_SEL_B                 0x46104
8526#define PORT_CLK_SEL(port) _MMIO_PORT(port, _PORT_CLK_SEL_A, _PORT_CLK_SEL_B)
8527#define  PORT_CLK_SEL_LCPLL_2700        (0<<29)
8528#define  PORT_CLK_SEL_LCPLL_1350        (1<<29)
8529#define  PORT_CLK_SEL_LCPLL_810         (2<<29)
8530#define  PORT_CLK_SEL_SPLL              (3<<29)
8531#define  PORT_CLK_SEL_WRPLL(pll)        (((pll)+4)<<29)
8532#define  PORT_CLK_SEL_WRPLL1            (4<<29)
8533#define  PORT_CLK_SEL_WRPLL2            (5<<29)
8534#define  PORT_CLK_SEL_NONE              (7<<29)
8535#define  PORT_CLK_SEL_MASK              (7<<29)
8536
8537/* Transcoder clock selection */
8538#define _TRANS_CLK_SEL_A                0x46140
8539#define _TRANS_CLK_SEL_B                0x46144
8540#define TRANS_CLK_SEL(tran) _MMIO_TRANS(tran, _TRANS_CLK_SEL_A, _TRANS_CLK_SEL_B)
8541/* For each transcoder, we need to select the corresponding port clock */
8542#define  TRANS_CLK_SEL_DISABLED         (0x0<<29)
8543#define  TRANS_CLK_SEL_PORT(x)          (((x)+1)<<29)
8544
8545#define CDCLK_FREQ                      _MMIO(0x46200)
8546
8547#define _TRANSA_MSA_MISC                0x60410
8548#define _TRANSB_MSA_MISC                0x61410
8549#define _TRANSC_MSA_MISC                0x62410
8550#define _TRANS_EDP_MSA_MISC             0x6f410
8551#define TRANS_MSA_MISC(tran) _MMIO_TRANS2(tran, _TRANSA_MSA_MISC)
8552
8553#define  TRANS_MSA_SYNC_CLK             (1<<0)
8554#define  TRANS_MSA_6_BPC                (0<<5)
8555#define  TRANS_MSA_8_BPC                (1<<5)
8556#define  TRANS_MSA_10_BPC               (2<<5)
8557#define  TRANS_MSA_12_BPC               (3<<5)
8558#define  TRANS_MSA_16_BPC               (4<<5)
8559
8560/* LCPLL Control */
8561#define LCPLL_CTL                       _MMIO(0x130040)
8562#define  LCPLL_PLL_DISABLE              (1<<31)
8563#define  LCPLL_PLL_LOCK                 (1<<30)
8564#define  LCPLL_CLK_FREQ_MASK            (3<<26)
8565#define  LCPLL_CLK_FREQ_450             (0<<26)
8566#define  LCPLL_CLK_FREQ_54O_BDW         (1<<26)
8567#define  LCPLL_CLK_FREQ_337_5_BDW       (2<<26)
8568#define  LCPLL_CLK_FREQ_675_BDW         (3<<26)
8569#define  LCPLL_CD_CLOCK_DISABLE         (1<<25)
8570#define  LCPLL_ROOT_CD_CLOCK_DISABLE    (1<<24)
8571#define  LCPLL_CD2X_CLOCK_DISABLE       (1<<23)
8572#define  LCPLL_POWER_DOWN_ALLOW         (1<<22)
8573#define  LCPLL_CD_SOURCE_FCLK           (1<<21)
8574#define  LCPLL_CD_SOURCE_FCLK_DONE      (1<<19)
8575
8576/*
8577 * SKL Clocks
8578 */
8579
8580/* CDCLK_CTL */
8581#define CDCLK_CTL                       _MMIO(0x46000)
8582#define  CDCLK_FREQ_SEL_MASK            (3<<26)
8583#define  CDCLK_FREQ_450_432             (0<<26)
8584#define  CDCLK_FREQ_540                 (1<<26)
8585#define  CDCLK_FREQ_337_308             (2<<26)
8586#define  CDCLK_FREQ_675_617             (3<<26)
8587#define  BXT_CDCLK_CD2X_DIV_SEL_MASK    (3<<22)
8588#define  BXT_CDCLK_CD2X_DIV_SEL_1       (0<<22)
8589#define  BXT_CDCLK_CD2X_DIV_SEL_1_5     (1<<22)
8590#define  BXT_CDCLK_CD2X_DIV_SEL_2       (2<<22)
8591#define  BXT_CDCLK_CD2X_DIV_SEL_4       (3<<22)
8592#define  BXT_CDCLK_CD2X_PIPE(pipe)      ((pipe)<<20)
8593#define  CDCLK_DIVMUX_CD_OVERRIDE       (1<<19)
8594#define  BXT_CDCLK_CD2X_PIPE_NONE       BXT_CDCLK_CD2X_PIPE(3)
8595#define  BXT_CDCLK_SSA_PRECHARGE_ENABLE (1<<16)
8596#define  CDCLK_FREQ_DECIMAL_MASK        (0x7ff)
8597
8598/* LCPLL_CTL */
8599#define LCPLL1_CTL              _MMIO(0x46010)
8600#define LCPLL2_CTL              _MMIO(0x46014)
8601#define  LCPLL_PLL_ENABLE       (1<<31)
8602
8603/* DPLL control1 */
8604#define DPLL_CTRL1              _MMIO(0x6C058)
8605#define  DPLL_CTRL1_HDMI_MODE(id)               (1<<((id)*6+5))
8606#define  DPLL_CTRL1_SSC(id)                     (1<<((id)*6+4))
8607#define  DPLL_CTRL1_LINK_RATE_MASK(id)          (7<<((id)*6+1))
8608#define  DPLL_CTRL1_LINK_RATE_SHIFT(id)         ((id)*6+1)
8609#define  DPLL_CTRL1_LINK_RATE(linkrate, id)     ((linkrate)<<((id)*6+1))
8610#define  DPLL_CTRL1_OVERRIDE(id)                (1<<((id)*6))
8611#define  DPLL_CTRL1_LINK_RATE_2700              0
8612#define  DPLL_CTRL1_LINK_RATE_1350              1
8613#define  DPLL_CTRL1_LINK_RATE_810               2
8614#define  DPLL_CTRL1_LINK_RATE_1620              3
8615#define  DPLL_CTRL1_LINK_RATE_1080              4
8616#define  DPLL_CTRL1_LINK_RATE_2160              5
8617
8618/* DPLL control2 */
8619#define DPLL_CTRL2                              _MMIO(0x6C05C)
8620#define  DPLL_CTRL2_DDI_CLK_OFF(port)           (1<<((port)+15))
8621#define  DPLL_CTRL2_DDI_CLK_SEL_MASK(port)      (3<<((port)*3+1))
8622#define  DPLL_CTRL2_DDI_CLK_SEL_SHIFT(port)    ((port)*3+1)
8623#define  DPLL_CTRL2_DDI_CLK_SEL(clk, port)      ((clk)<<((port)*3+1))
8624#define  DPLL_CTRL2_DDI_SEL_OVERRIDE(port)     (1<<((port)*3))
8625
8626/* DPLL Status */
8627#define DPLL_STATUS     _MMIO(0x6C060)
8628#define  DPLL_LOCK(id) (1<<((id)*8))
8629
8630/* DPLL cfg */
8631#define _DPLL1_CFGCR1   0x6C040
8632#define _DPLL2_CFGCR1   0x6C048
8633#define _DPLL3_CFGCR1   0x6C050
8634#define  DPLL_CFGCR1_FREQ_ENABLE        (1<<31)
8635#define  DPLL_CFGCR1_DCO_FRACTION_MASK  (0x7fff<<9)
8636#define  DPLL_CFGCR1_DCO_FRACTION(x)    ((x)<<9)
8637#define  DPLL_CFGCR1_DCO_INTEGER_MASK   (0x1ff)
8638
8639#define _DPLL1_CFGCR2   0x6C044
8640#define _DPLL2_CFGCR2   0x6C04C
8641#define _DPLL3_CFGCR2   0x6C054
8642#define  DPLL_CFGCR2_QDIV_RATIO_MASK    (0xff<<8)
8643#define  DPLL_CFGCR2_QDIV_RATIO(x)      ((x)<<8)
8644#define  DPLL_CFGCR2_QDIV_MODE(x)       ((x)<<7)
8645#define  DPLL_CFGCR2_KDIV_MASK          (3<<5)
8646#define  DPLL_CFGCR2_KDIV(x)            ((x)<<5)
8647#define  DPLL_CFGCR2_KDIV_5 (0<<5)
8648#define  DPLL_CFGCR2_KDIV_2 (1<<5)
8649#define  DPLL_CFGCR2_KDIV_3 (2<<5)
8650#define  DPLL_CFGCR2_KDIV_1 (3<<5)
8651#define  DPLL_CFGCR2_PDIV_MASK          (7<<2)
8652#define  DPLL_CFGCR2_PDIV(x)            ((x)<<2)
8653#define  DPLL_CFGCR2_PDIV_1 (0<<2)
8654#define  DPLL_CFGCR2_PDIV_2 (1<<2)
8655#define  DPLL_CFGCR2_PDIV_3 (2<<2)
8656#define  DPLL_CFGCR2_PDIV_7 (4<<2)
8657#define  DPLL_CFGCR2_CENTRAL_FREQ_MASK  (3)
8658
8659#define DPLL_CFGCR1(id) _MMIO_PIPE((id) - SKL_DPLL1, _DPLL1_CFGCR1, _DPLL2_CFGCR1)
8660#define DPLL_CFGCR2(id) _MMIO_PIPE((id) - SKL_DPLL1, _DPLL1_CFGCR2, _DPLL2_CFGCR2)
8661
8662/*
8663 * CNL Clocks
8664 */
8665#define DPCLKA_CFGCR0                           _MMIO(0x6C200)
8666#define  DPCLKA_CFGCR0_DDI_CLK_OFF(port)        (1 << ((port)+10))
8667#define  DPCLKA_CFGCR0_DDI_CLK_SEL_MASK(port)   (3 << ((port)*2))
8668#define  DPCLKA_CFGCR0_DDI_CLK_SEL_SHIFT(port)  ((port)*2)
8669#define  DPCLKA_CFGCR0_DDI_CLK_SEL(pll, port)   ((pll) << ((port)*2))
8670
8671/* CNL PLL */
8672#define DPLL0_ENABLE            0x46010
8673#define DPLL1_ENABLE            0x46014
8674#define  PLL_ENABLE             (1 << 31)
8675#define  PLL_LOCK               (1 << 30)
8676#define  PLL_POWER_ENABLE       (1 << 27)
8677#define  PLL_POWER_STATE        (1 << 26)
8678#define CNL_DPLL_ENABLE(pll)    _MMIO_PLL(pll, DPLL0_ENABLE, DPLL1_ENABLE)
8679
8680#define _CNL_DPLL0_CFGCR0               0x6C000
8681#define _CNL_DPLL1_CFGCR0               0x6C080
8682#define  DPLL_CFGCR0_HDMI_MODE          (1 << 30)
8683#define  DPLL_CFGCR0_SSC_ENABLE         (1 << 29)
8684#define  DPLL_CFGCR0_LINK_RATE_MASK     (0xf << 25)
8685#define  DPLL_CFGCR0_LINK_RATE_2700     (0 << 25)
8686#define  DPLL_CFGCR0_LINK_RATE_1350     (1 << 25)
8687#define  DPLL_CFGCR0_LINK_RATE_810      (2 << 25)
8688#define  DPLL_CFGCR0_LINK_RATE_1620     (3 << 25)
8689#define  DPLL_CFGCR0_LINK_RATE_1080     (4 << 25)
8690#define  DPLL_CFGCR0_LINK_RATE_2160     (5 << 25)
8691#define  DPLL_CFGCR0_LINK_RATE_3240     (6 << 25)
8692#define  DPLL_CFGCR0_LINK_RATE_4050     (7 << 25)
8693#define  DPLL_CFGCR0_DCO_FRACTION_MASK  (0x7fff << 10)
8694#define  DPLL_CFGCR0_DCO_FRACTION_SHIFT (10)
8695#define  DPLL_CFGCR0_DCO_FRACTION(x)    ((x) << 10)
8696#define  DPLL_CFGCR0_DCO_INTEGER_MASK   (0x3ff)
8697#define CNL_DPLL_CFGCR0(pll)            _MMIO_PLL(pll, _CNL_DPLL0_CFGCR0, _CNL_DPLL1_CFGCR0)
8698
8699#define _CNL_DPLL0_CFGCR1               0x6C004
8700#define _CNL_DPLL1_CFGCR1               0x6C084
8701#define  DPLL_CFGCR1_QDIV_RATIO_MASK    (0xff << 10)
8702#define  DPLL_CFGCR1_QDIV_RATIO_SHIFT   (10)
8703#define  DPLL_CFGCR1_QDIV_RATIO(x)      ((x) << 10)
8704#define  DPLL_CFGCR1_QDIV_MODE(x)       ((x) << 9)
8705#define  DPLL_CFGCR1_KDIV_MASK          (7 << 6)
8706#define  DPLL_CFGCR1_KDIV(x)            ((x) << 6)
8707#define  DPLL_CFGCR1_KDIV_1             (1 << 6)
8708#define  DPLL_CFGCR1_KDIV_2             (2 << 6)
8709#define  DPLL_CFGCR1_KDIV_4             (4 << 6)
8710#define  DPLL_CFGCR1_PDIV_MASK          (0xf << 2)
8711#define  DPLL_CFGCR1_PDIV(x)            ((x) << 2)
8712#define  DPLL_CFGCR1_PDIV_2             (1 << 2)
8713#define  DPLL_CFGCR1_PDIV_3             (2 << 2)
8714#define  DPLL_CFGCR1_PDIV_5             (4 << 2)
8715#define  DPLL_CFGCR1_PDIV_7             (8 << 2)
8716#define  DPLL_CFGCR1_CENTRAL_FREQ       (3 << 0)
8717#define CNL_DPLL_CFGCR1(pll)            _MMIO_PLL(pll, _CNL_DPLL0_CFGCR1, _CNL_DPLL1_CFGCR1)
8718
8719/* BXT display engine PLL */
8720#define BXT_DE_PLL_CTL                  _MMIO(0x6d000)
8721#define   BXT_DE_PLL_RATIO(x)           (x)     /* {60,65,100} * 19.2MHz */
8722#define   BXT_DE_PLL_RATIO_MASK         0xff
8723
8724#define BXT_DE_PLL_ENABLE               _MMIO(0x46070)
8725#define   BXT_DE_PLL_PLL_ENABLE         (1 << 31)
8726#define   BXT_DE_PLL_LOCK               (1 << 30)
8727#define   CNL_CDCLK_PLL_RATIO(x)        (x)
8728#define   CNL_CDCLK_PLL_RATIO_MASK      0xff
8729
8730/* GEN9 DC */
8731#define DC_STATE_EN                     _MMIO(0x45504)
8732#define  DC_STATE_DISABLE               0
8733#define  DC_STATE_EN_UPTO_DC5           (1<<0)
8734#define  DC_STATE_EN_DC9                (1<<3)
8735#define  DC_STATE_EN_UPTO_DC6           (2<<0)
8736#define  DC_STATE_EN_UPTO_DC5_DC6_MASK   0x3
8737
8738#define  DC_STATE_DEBUG                  _MMIO(0x45520)
8739#define  DC_STATE_DEBUG_MASK_CORES      (1<<0)
8740#define  DC_STATE_DEBUG_MASK_MEMORY_UP  (1<<1)
8741
8742/* Please see hsw_read_dcomp() and hsw_write_dcomp() before using this register,
8743 * since on HSW we can't write to it using I915_WRITE. */
8744#define D_COMP_HSW                      _MMIO(MCHBAR_MIRROR_BASE_SNB + 0x5F0C)
8745#define D_COMP_BDW                      _MMIO(0x138144)
8746#define  D_COMP_RCOMP_IN_PROGRESS       (1<<9)
8747#define  D_COMP_COMP_FORCE              (1<<8)
8748#define  D_COMP_COMP_DISABLE            (1<<0)
8749
8750/* Pipe WM_LINETIME - watermark line time */
8751#define _PIPE_WM_LINETIME_A             0x45270
8752#define _PIPE_WM_LINETIME_B             0x45274
8753#define PIPE_WM_LINETIME(pipe) _MMIO_PIPE(pipe, _PIPE_WM_LINETIME_A, _PIPE_WM_LINETIME_B)
8754#define   PIPE_WM_LINETIME_MASK                 (0x1ff)
8755#define   PIPE_WM_LINETIME_TIME(x)              ((x))
8756#define   PIPE_WM_LINETIME_IPS_LINETIME_MASK    (0x1ff<<16)
8757#define   PIPE_WM_LINETIME_IPS_LINETIME(x)      ((x)<<16)
8758
8759/* SFUSE_STRAP */
8760#define SFUSE_STRAP                     _MMIO(0xc2014)
8761#define  SFUSE_STRAP_FUSE_LOCK          (1<<13)
8762#define  SFUSE_STRAP_RAW_FREQUENCY      (1<<8)
8763#define  SFUSE_STRAP_DISPLAY_DISABLED   (1<<7)
8764#define  SFUSE_STRAP_CRT_DISABLED       (1<<6)
8765#define  SFUSE_STRAP_DDIB_DETECTED      (1<<2)
8766#define  SFUSE_STRAP_DDIC_DETECTED      (1<<1)
8767#define  SFUSE_STRAP_DDID_DETECTED      (1<<0)
8768
8769#define WM_MISC                         _MMIO(0x45260)
8770#define  WM_MISC_DATA_PARTITION_5_6     (1 << 0)
8771
8772#define WM_DBG                          _MMIO(0x45280)
8773#define  WM_DBG_DISALLOW_MULTIPLE_LP    (1<<0)
8774#define  WM_DBG_DISALLOW_MAXFIFO        (1<<1)
8775#define  WM_DBG_DISALLOW_SPRITE         (1<<2)
8776
8777/* pipe CSC */
8778#define _PIPE_A_CSC_COEFF_RY_GY 0x49010
8779#define _PIPE_A_CSC_COEFF_BY    0x49014
8780#define _PIPE_A_CSC_COEFF_RU_GU 0x49018
8781#define _PIPE_A_CSC_COEFF_BU    0x4901c
8782#define _PIPE_A_CSC_COEFF_RV_GV 0x49020
8783#define _PIPE_A_CSC_COEFF_BV    0x49024
8784#define _PIPE_A_CSC_MODE        0x49028
8785#define   CSC_BLACK_SCREEN_OFFSET       (1 << 2)
8786#define   CSC_POSITION_BEFORE_GAMMA     (1 << 1)
8787#define   CSC_MODE_YUV_TO_RGB           (1 << 0)
8788#define _PIPE_A_CSC_PREOFF_HI   0x49030
8789#define _PIPE_A_CSC_PREOFF_ME   0x49034
8790#define _PIPE_A_CSC_PREOFF_LO   0x49038
8791#define _PIPE_A_CSC_POSTOFF_HI  0x49040
8792#define _PIPE_A_CSC_POSTOFF_ME  0x49044
8793#define _PIPE_A_CSC_POSTOFF_LO  0x49048
8794
8795#define _PIPE_B_CSC_COEFF_RY_GY 0x49110
8796#define _PIPE_B_CSC_COEFF_BY    0x49114
8797#define _PIPE_B_CSC_COEFF_RU_GU 0x49118
8798#define _PIPE_B_CSC_COEFF_BU    0x4911c
8799#define _PIPE_B_CSC_COEFF_RV_GV 0x49120
8800#define _PIPE_B_CSC_COEFF_BV    0x49124
8801#define _PIPE_B_CSC_MODE        0x49128
8802#define _PIPE_B_CSC_PREOFF_HI   0x49130
8803#define _PIPE_B_CSC_PREOFF_ME   0x49134
8804#define _PIPE_B_CSC_PREOFF_LO   0x49138
8805#define _PIPE_B_CSC_POSTOFF_HI  0x49140
8806#define _PIPE_B_CSC_POSTOFF_ME  0x49144
8807#define _PIPE_B_CSC_POSTOFF_LO  0x49148
8808
8809#define PIPE_CSC_COEFF_RY_GY(pipe)      _MMIO_PIPE(pipe, _PIPE_A_CSC_COEFF_RY_GY, _PIPE_B_CSC_COEFF_RY_GY)
8810#define PIPE_CSC_COEFF_BY(pipe)         _MMIO_PIPE(pipe, _PIPE_A_CSC_COEFF_BY, _PIPE_B_CSC_COEFF_BY)
8811#define PIPE_CSC_COEFF_RU_GU(pipe)      _MMIO_PIPE(pipe, _PIPE_A_CSC_COEFF_RU_GU, _PIPE_B_CSC_COEFF_RU_GU)
8812#define PIPE_CSC_COEFF_BU(pipe)         _MMIO_PIPE(pipe, _PIPE_A_CSC_COEFF_BU, _PIPE_B_CSC_COEFF_BU)
8813#define PIPE_CSC_COEFF_RV_GV(pipe)      _MMIO_PIPE(pipe, _PIPE_A_CSC_COEFF_RV_GV, _PIPE_B_CSC_COEFF_RV_GV)
8814#define PIPE_CSC_COEFF_BV(pipe)         _MMIO_PIPE(pipe, _PIPE_A_CSC_COEFF_BV, _PIPE_B_CSC_COEFF_BV)
8815#define PIPE_CSC_MODE(pipe)             _MMIO_PIPE(pipe, _PIPE_A_CSC_MODE, _PIPE_B_CSC_MODE)
8816#define PIPE_CSC_PREOFF_HI(pipe)        _MMIO_PIPE(pipe, _PIPE_A_CSC_PREOFF_HI, _PIPE_B_CSC_PREOFF_HI)
8817#define PIPE_CSC_PREOFF_ME(pipe)        _MMIO_PIPE(pipe, _PIPE_A_CSC_PREOFF_ME, _PIPE_B_CSC_PREOFF_ME)
8818#define PIPE_CSC_PREOFF_LO(pipe)        _MMIO_PIPE(pipe, _PIPE_A_CSC_PREOFF_LO, _PIPE_B_CSC_PREOFF_LO)
8819#define PIPE_CSC_POSTOFF_HI(pipe)       _MMIO_PIPE(pipe, _PIPE_A_CSC_POSTOFF_HI, _PIPE_B_CSC_POSTOFF_HI)
8820#define PIPE_CSC_POSTOFF_ME(pipe)       _MMIO_PIPE(pipe, _PIPE_A_CSC_POSTOFF_ME, _PIPE_B_CSC_POSTOFF_ME)
8821#define PIPE_CSC_POSTOFF_LO(pipe)       _MMIO_PIPE(pipe, _PIPE_A_CSC_POSTOFF_LO, _PIPE_B_CSC_POSTOFF_LO)
8822
8823/* pipe degamma/gamma LUTs on IVB+ */
8824#define _PAL_PREC_INDEX_A       0x4A400
8825#define _PAL_PREC_INDEX_B       0x4AC00
8826#define _PAL_PREC_INDEX_C       0x4B400
8827#define   PAL_PREC_10_12_BIT            (0 << 31)
8828#define   PAL_PREC_SPLIT_MODE           (1 << 31)
8829#define   PAL_PREC_AUTO_INCREMENT       (1 << 15)
8830#define   PAL_PREC_INDEX_VALUE_MASK     (0x3ff << 0)
8831#define _PAL_PREC_DATA_A        0x4A404
8832#define _PAL_PREC_DATA_B        0x4AC04
8833#define _PAL_PREC_DATA_C        0x4B404
8834#define _PAL_PREC_GC_MAX_A      0x4A410
8835#define _PAL_PREC_GC_MAX_B      0x4AC10
8836#define _PAL_PREC_GC_MAX_C      0x4B410
8837#define _PAL_PREC_EXT_GC_MAX_A  0x4A420
8838#define _PAL_PREC_EXT_GC_MAX_B  0x4AC20
8839#define _PAL_PREC_EXT_GC_MAX_C  0x4B420
8840#define _PAL_PREC_EXT2_GC_MAX_A 0x4A430
8841#define _PAL_PREC_EXT2_GC_MAX_B 0x4AC30
8842#define _PAL_PREC_EXT2_GC_MAX_C 0x4B430
8843
8844#define PREC_PAL_INDEX(pipe)            _MMIO_PIPE(pipe, _PAL_PREC_INDEX_A, _PAL_PREC_INDEX_B)
8845#define PREC_PAL_DATA(pipe)             _MMIO_PIPE(pipe, _PAL_PREC_DATA_A, _PAL_PREC_DATA_B)
8846#define PREC_PAL_GC_MAX(pipe, i)        _MMIO(_PIPE(pipe, _PAL_PREC_GC_MAX_A, _PAL_PREC_GC_MAX_B) + (i) * 4)
8847#define PREC_PAL_EXT_GC_MAX(pipe, i)    _MMIO(_PIPE(pipe, _PAL_PREC_EXT_GC_MAX_A, _PAL_PREC_EXT_GC_MAX_B) + (i) * 4)
8848
8849#define _PRE_CSC_GAMC_INDEX_A   0x4A484
8850#define _PRE_CSC_GAMC_INDEX_B   0x4AC84
8851#define _PRE_CSC_GAMC_INDEX_C   0x4B484
8852#define   PRE_CSC_GAMC_AUTO_INCREMENT   (1 << 10)
8853#define _PRE_CSC_GAMC_DATA_A    0x4A488
8854#define _PRE_CSC_GAMC_DATA_B    0x4AC88
8855#define _PRE_CSC_GAMC_DATA_C    0x4B488
8856
8857#define PRE_CSC_GAMC_INDEX(pipe)        _MMIO_PIPE(pipe, _PRE_CSC_GAMC_INDEX_A, _PRE_CSC_GAMC_INDEX_B)
8858#define PRE_CSC_GAMC_DATA(pipe)         _MMIO_PIPE(pipe, _PRE_CSC_GAMC_DATA_A, _PRE_CSC_GAMC_DATA_B)
8859
8860/* pipe CSC & degamma/gamma LUTs on CHV */
8861#define _CGM_PIPE_A_CSC_COEFF01 (VLV_DISPLAY_BASE + 0x67900)
8862#define _CGM_PIPE_A_CSC_COEFF23 (VLV_DISPLAY_BASE + 0x67904)
8863#define _CGM_PIPE_A_CSC_COEFF45 (VLV_DISPLAY_BASE + 0x67908)
8864#define _CGM_PIPE_A_CSC_COEFF67 (VLV_DISPLAY_BASE + 0x6790C)
8865#define _CGM_PIPE_A_CSC_COEFF8  (VLV_DISPLAY_BASE + 0x67910)
8866#define _CGM_PIPE_A_DEGAMMA     (VLV_DISPLAY_BASE + 0x66000)
8867#define _CGM_PIPE_A_GAMMA       (VLV_DISPLAY_BASE + 0x67000)
8868#define _CGM_PIPE_A_MODE        (VLV_DISPLAY_BASE + 0x67A00)
8869#define   CGM_PIPE_MODE_GAMMA   (1 << 2)
8870#define   CGM_PIPE_MODE_CSC     (1 << 1)
8871#define   CGM_PIPE_MODE_DEGAMMA (1 << 0)
8872
8873#define _CGM_PIPE_B_CSC_COEFF01 (VLV_DISPLAY_BASE + 0x69900)
8874#define _CGM_PIPE_B_CSC_COEFF23 (VLV_DISPLAY_BASE + 0x69904)
8875#define _CGM_PIPE_B_CSC_COEFF45 (VLV_DISPLAY_BASE + 0x69908)
8876#define _CGM_PIPE_B_CSC_COEFF67 (VLV_DISPLAY_BASE + 0x6990C)
8877#define _CGM_PIPE_B_CSC_COEFF8  (VLV_DISPLAY_BASE + 0x69910)
8878#define _CGM_PIPE_B_DEGAMMA     (VLV_DISPLAY_BASE + 0x68000)
8879#define _CGM_PIPE_B_GAMMA       (VLV_DISPLAY_BASE + 0x69000)
8880#define _CGM_PIPE_B_MODE        (VLV_DISPLAY_BASE + 0x69A00)
8881
8882#define CGM_PIPE_CSC_COEFF01(pipe)      _MMIO_PIPE(pipe, _CGM_PIPE_A_CSC_COEFF01, _CGM_PIPE_B_CSC_COEFF01)
8883#define CGM_PIPE_CSC_COEFF23(pipe)      _MMIO_PIPE(pipe, _CGM_PIPE_A_CSC_COEFF23, _CGM_PIPE_B_CSC_COEFF23)
8884#define CGM_PIPE_CSC_COEFF45(pipe)      _MMIO_PIPE(pipe, _CGM_PIPE_A_CSC_COEFF45, _CGM_PIPE_B_CSC_COEFF45)
8885#define CGM_PIPE_CSC_COEFF67(pipe)      _MMIO_PIPE(pipe, _CGM_PIPE_A_CSC_COEFF67, _CGM_PIPE_B_CSC_COEFF67)
8886#define CGM_PIPE_CSC_COEFF8(pipe)       _MMIO_PIPE(pipe, _CGM_PIPE_A_CSC_COEFF8, _CGM_PIPE_B_CSC_COEFF8)
8887#define CGM_PIPE_DEGAMMA(pipe, i, w)    _MMIO(_PIPE(pipe, _CGM_PIPE_A_DEGAMMA, _CGM_PIPE_B_DEGAMMA) + (i) * 8 + (w) * 4)
8888#define CGM_PIPE_GAMMA(pipe, i, w)      _MMIO(_PIPE(pipe, _CGM_PIPE_A_GAMMA, _CGM_PIPE_B_GAMMA) + (i) * 8 + (w) * 4)
8889#define CGM_PIPE_MODE(pipe)             _MMIO_PIPE(pipe, _CGM_PIPE_A_MODE, _CGM_PIPE_B_MODE)
8890
8891/* MIPI DSI registers */
8892
8893#define _MIPI_PORT(port, a, c)  (((port) == PORT_A) ? a : c)    /* ports A and C only */
8894#define _MMIO_MIPI(port, a, c)  _MMIO(_MIPI_PORT(port, a, c))
8895
8896#define MIPIO_TXESC_CLK_DIV1                    _MMIO(0x160004)
8897#define  GLK_TX_ESC_CLK_DIV1_MASK                       0x3FF
8898#define MIPIO_TXESC_CLK_DIV2                    _MMIO(0x160008)
8899#define  GLK_TX_ESC_CLK_DIV2_MASK                       0x3FF
8900
8901/* Gen4+ Timestamp and Pipe Frame time stamp registers */
8902#define GEN4_TIMESTAMP          _MMIO(0x2358)
8903#define ILK_TIMESTAMP_HI        _MMIO(0x70070)
8904#define IVB_TIMESTAMP_CTR       _MMIO(0x44070)
8905
8906#define GEN9_TIMESTAMP_OVERRIDE                         _MMIO(0x44074)
8907#define  GEN9_TIMESTAMP_OVERRIDE_US_COUNTER_DIVIDER_SHIFT       0
8908#define  GEN9_TIMESTAMP_OVERRIDE_US_COUNTER_DIVIDER_MASK        0x3ff
8909#define  GEN9_TIMESTAMP_OVERRIDE_US_COUNTER_DENOMINATOR_SHIFT   12
8910#define  GEN9_TIMESTAMP_OVERRIDE_US_COUNTER_DENOMINATOR_MASK    (0xf << 12)
8911
8912#define _PIPE_FRMTMSTMP_A               0x70048
8913#define PIPE_FRMTMSTMP(pipe)            \
8914                        _MMIO_PIPE2(pipe, _PIPE_FRMTMSTMP_A)
8915
8916/* BXT MIPI clock controls */
8917#define BXT_MAX_VAR_OUTPUT_KHZ                  39500
8918
8919#define BXT_MIPI_CLOCK_CTL                      _MMIO(0x46090)
8920#define  BXT_MIPI1_DIV_SHIFT                    26
8921#define  BXT_MIPI2_DIV_SHIFT                    10
8922#define  BXT_MIPI_DIV_SHIFT(port)               \
8923                        _MIPI_PORT(port, BXT_MIPI1_DIV_SHIFT, \
8924                                        BXT_MIPI2_DIV_SHIFT)
8925
8926/* TX control divider to select actual TX clock output from (8x/var) */
8927#define  BXT_MIPI1_TX_ESCLK_SHIFT               26
8928#define  BXT_MIPI2_TX_ESCLK_SHIFT               10
8929#define  BXT_MIPI_TX_ESCLK_SHIFT(port)          \
8930                        _MIPI_PORT(port, BXT_MIPI1_TX_ESCLK_SHIFT, \
8931                                        BXT_MIPI2_TX_ESCLK_SHIFT)
8932#define  BXT_MIPI1_TX_ESCLK_FIXDIV_MASK         (0x3F << 26)
8933#define  BXT_MIPI2_TX_ESCLK_FIXDIV_MASK         (0x3F << 10)
8934#define  BXT_MIPI_TX_ESCLK_FIXDIV_MASK(port)    \
8935                        _MIPI_PORT(port, BXT_MIPI1_TX_ESCLK_FIXDIV_MASK, \
8936                                        BXT_MIPI2_TX_ESCLK_FIXDIV_MASK)
8937#define  BXT_MIPI_TX_ESCLK_DIVIDER(port, val)   \
8938                ((val & 0x3F) << BXT_MIPI_TX_ESCLK_SHIFT(port))
8939/* RX upper control divider to select actual RX clock output from 8x */
8940#define  BXT_MIPI1_RX_ESCLK_UPPER_SHIFT         21
8941#define  BXT_MIPI2_RX_ESCLK_UPPER_SHIFT         5
8942#define  BXT_MIPI_RX_ESCLK_UPPER_SHIFT(port)            \
8943                        _MIPI_PORT(port, BXT_MIPI1_RX_ESCLK_UPPER_SHIFT, \
8944                                        BXT_MIPI2_RX_ESCLK_UPPER_SHIFT)
8945#define  BXT_MIPI1_RX_ESCLK_UPPER_FIXDIV_MASK           (3 << 21)
8946#define  BXT_MIPI2_RX_ESCLK_UPPER_FIXDIV_MASK           (3 << 5)
8947#define  BXT_MIPI_RX_ESCLK_UPPER_FIXDIV_MASK(port)      \
8948                        _MIPI_PORT(port, BXT_MIPI1_RX_ESCLK_UPPER_FIXDIV_MASK, \
8949                                        BXT_MIPI2_RX_ESCLK_UPPER_FIXDIV_MASK)
8950#define  BXT_MIPI_RX_ESCLK_UPPER_DIVIDER(port, val)     \
8951                ((val & 3) << BXT_MIPI_RX_ESCLK_UPPER_SHIFT(port))
8952/* 8/3X divider to select the actual 8/3X clock output from 8x */
8953#define  BXT_MIPI1_8X_BY3_SHIFT                19
8954#define  BXT_MIPI2_8X_BY3_SHIFT                3
8955#define  BXT_MIPI_8X_BY3_SHIFT(port)          \
8956                        _MIPI_PORT(port, BXT_MIPI1_8X_BY3_SHIFT, \
8957                                        BXT_MIPI2_8X_BY3_SHIFT)
8958#define  BXT_MIPI1_8X_BY3_DIVIDER_MASK         (3 << 19)
8959#define  BXT_MIPI2_8X_BY3_DIVIDER_MASK         (3 << 3)
8960#define  BXT_MIPI_8X_BY3_DIVIDER_MASK(port)    \
8961                        _MIPI_PORT(port, BXT_MIPI1_8X_BY3_DIVIDER_MASK, \
8962                                                BXT_MIPI2_8X_BY3_DIVIDER_MASK)
8963#define  BXT_MIPI_8X_BY3_DIVIDER(port, val)    \
8964                        ((val & 3) << BXT_MIPI_8X_BY3_SHIFT(port))
8965/* RX lower control divider to select actual RX clock output from 8x */
8966#define  BXT_MIPI1_RX_ESCLK_LOWER_SHIFT         16
8967#define  BXT_MIPI2_RX_ESCLK_LOWER_SHIFT         0
8968#define  BXT_MIPI_RX_ESCLK_LOWER_SHIFT(port)            \
8969                        _MIPI_PORT(port, BXT_MIPI1_RX_ESCLK_LOWER_SHIFT, \
8970                                        BXT_MIPI2_RX_ESCLK_LOWER_SHIFT)
8971#define  BXT_MIPI1_RX_ESCLK_LOWER_FIXDIV_MASK           (3 << 16)
8972#define  BXT_MIPI2_RX_ESCLK_LOWER_FIXDIV_MASK           (3 << 0)
8973#define  BXT_MIPI_RX_ESCLK_LOWER_FIXDIV_MASK(port)      \
8974                        _MIPI_PORT(port, BXT_MIPI1_RX_ESCLK_LOWER_FIXDIV_MASK, \
8975                                        BXT_MIPI2_RX_ESCLK_LOWER_FIXDIV_MASK)
8976#define  BXT_MIPI_RX_ESCLK_LOWER_DIVIDER(port, val)     \
8977                ((val & 3) << BXT_MIPI_RX_ESCLK_LOWER_SHIFT(port))
8978
8979#define RX_DIVIDER_BIT_1_2                     0x3
8980#define RX_DIVIDER_BIT_3_4                     0xC
8981
8982/* BXT MIPI mode configure */
8983#define  _BXT_MIPIA_TRANS_HACTIVE                       0x6B0F8
8984#define  _BXT_MIPIC_TRANS_HACTIVE                       0x6B8F8
8985#define  BXT_MIPI_TRANS_HACTIVE(tc)     _MMIO_MIPI(tc, \
8986                _BXT_MIPIA_TRANS_HACTIVE, _BXT_MIPIC_TRANS_HACTIVE)
8987
8988#define  _BXT_MIPIA_TRANS_VACTIVE                       0x6B0FC
8989#define  _BXT_MIPIC_TRANS_VACTIVE                       0x6B8FC
8990#define  BXT_MIPI_TRANS_VACTIVE(tc)     _MMIO_MIPI(tc, \
8991                _BXT_MIPIA_TRANS_VACTIVE, _BXT_MIPIC_TRANS_VACTIVE)
8992
8993#define  _BXT_MIPIA_TRANS_VTOTAL                        0x6B100
8994#define  _BXT_MIPIC_TRANS_VTOTAL                        0x6B900
8995#define  BXT_MIPI_TRANS_VTOTAL(tc)      _MMIO_MIPI(tc, \
8996                _BXT_MIPIA_TRANS_VTOTAL, _BXT_MIPIC_TRANS_VTOTAL)
8997
8998#define BXT_DSI_PLL_CTL                 _MMIO(0x161000)
8999#define  BXT_DSI_PLL_PVD_RATIO_SHIFT    16
9000#define  BXT_DSI_PLL_PVD_RATIO_MASK     (3 << BXT_DSI_PLL_PVD_RATIO_SHIFT)
9001#define  BXT_DSI_PLL_PVD_RATIO_1        (1 << BXT_DSI_PLL_PVD_RATIO_SHIFT)
9002#define  BXT_DSIC_16X_BY1               (0 << 10)
9003#define  BXT_DSIC_16X_BY2               (1 << 10)
9004#define  BXT_DSIC_16X_BY3               (2 << 10)
9005#define  BXT_DSIC_16X_BY4               (3 << 10)
9006#define  BXT_DSIC_16X_MASK              (3 << 10)
9007#define  BXT_DSIA_16X_BY1               (0 << 8)
9008#define  BXT_DSIA_16X_BY2               (1 << 8)
9009#define  BXT_DSIA_16X_BY3               (2 << 8)
9010#define  BXT_DSIA_16X_BY4               (3 << 8)
9011#define  BXT_DSIA_16X_MASK              (3 << 8)
9012#define  BXT_DSI_FREQ_SEL_SHIFT         8
9013#define  BXT_DSI_FREQ_SEL_MASK          (0xF << BXT_DSI_FREQ_SEL_SHIFT)
9014
9015#define BXT_DSI_PLL_RATIO_MAX           0x7D
9016#define BXT_DSI_PLL_RATIO_MIN           0x22
9017#define GLK_DSI_PLL_RATIO_MAX           0x6F
9018#define GLK_DSI_PLL_RATIO_MIN           0x22
9019#define BXT_DSI_PLL_RATIO_MASK          0xFF
9020#define BXT_REF_CLOCK_KHZ               19200
9021
9022#define BXT_DSI_PLL_ENABLE              _MMIO(0x46080)
9023#define  BXT_DSI_PLL_DO_ENABLE          (1 << 31)
9024#define  BXT_DSI_PLL_LOCKED             (1 << 30)
9025
9026#define _MIPIA_PORT_CTRL                        (VLV_DISPLAY_BASE + 0x61190)
9027#define _MIPIC_PORT_CTRL                        (VLV_DISPLAY_BASE + 0x61700)
9028#define MIPI_PORT_CTRL(port)    _MMIO_MIPI(port, _MIPIA_PORT_CTRL, _MIPIC_PORT_CTRL)
9029
9030 /* BXT port control */
9031#define _BXT_MIPIA_PORT_CTRL                            0x6B0C0
9032#define _BXT_MIPIC_PORT_CTRL                            0x6B8C0
9033#define BXT_MIPI_PORT_CTRL(tc)  _MMIO_MIPI(tc, _BXT_MIPIA_PORT_CTRL, _BXT_MIPIC_PORT_CTRL)
9034
9035#define BXT_P_DSI_REGULATOR_CFG                 _MMIO(0x160020)
9036#define  STAP_SELECT                                    (1 << 0)
9037
9038#define BXT_P_DSI_REGULATOR_TX_CTRL             _MMIO(0x160054)
9039#define  HS_IO_CTRL_SELECT                              (1 << 0)
9040
9041#define  DPI_ENABLE                                     (1 << 31) /* A + C */
9042#define  MIPIA_MIPI4DPHY_DELAY_COUNT_SHIFT              27
9043#define  MIPIA_MIPI4DPHY_DELAY_COUNT_MASK               (0xf << 27)
9044#define  DUAL_LINK_MODE_SHIFT                           26
9045#define  DUAL_LINK_MODE_MASK                            (1 << 26)
9046#define  DUAL_LINK_MODE_FRONT_BACK                      (0 << 26)
9047#define  DUAL_LINK_MODE_PIXEL_ALTERNATIVE               (1 << 26)
9048#define  DITHERING_ENABLE                               (1 << 25) /* A + C */
9049#define  FLOPPED_HSTX                                   (1 << 23)
9050#define  DE_INVERT                                      (1 << 19) /* XXX */
9051#define  MIPIA_FLISDSI_DELAY_COUNT_SHIFT                18
9052#define  MIPIA_FLISDSI_DELAY_COUNT_MASK                 (0xf << 18)
9053#define  AFE_LATCHOUT                                   (1 << 17)
9054#define  LP_OUTPUT_HOLD                                 (1 << 16)
9055#define  MIPIC_FLISDSI_DELAY_COUNT_HIGH_SHIFT           15
9056#define  MIPIC_FLISDSI_DELAY_COUNT_HIGH_MASK            (1 << 15)
9057#define  MIPIC_MIPI4DPHY_DELAY_COUNT_SHIFT              11
9058#define  MIPIC_MIPI4DPHY_DELAY_COUNT_MASK               (0xf << 11)
9059#define  CSB_SHIFT                                      9
9060#define  CSB_MASK                                       (3 << 9)
9061#define  CSB_20MHZ                                      (0 << 9)
9062#define  CSB_10MHZ                                      (1 << 9)
9063#define  CSB_40MHZ                                      (2 << 9)
9064#define  BANDGAP_MASK                                   (1 << 8)
9065#define  BANDGAP_PNW_CIRCUIT                            (0 << 8)
9066#define  BANDGAP_LNC_CIRCUIT                            (1 << 8)
9067#define  MIPIC_FLISDSI_DELAY_COUNT_LOW_SHIFT            5
9068#define  MIPIC_FLISDSI_DELAY_COUNT_LOW_MASK             (7 << 5)
9069#define  TEARING_EFFECT_DELAY                           (1 << 4) /* A + C */
9070#define  TEARING_EFFECT_SHIFT                           2 /* A + C */
9071#define  TEARING_EFFECT_MASK                            (3 << 2)
9072#define  TEARING_EFFECT_OFF                             (0 << 2)
9073#define  TEARING_EFFECT_DSI                             (1 << 2)
9074#define  TEARING_EFFECT_GPIO                            (2 << 2)
9075#define  LANE_CONFIGURATION_SHIFT                       0
9076#define  LANE_CONFIGURATION_MASK                        (3 << 0)
9077#define  LANE_CONFIGURATION_4LANE                       (0 << 0)
9078#define  LANE_CONFIGURATION_DUAL_LINK_A                 (1 << 0)
9079#define  LANE_CONFIGURATION_DUAL_LINK_B                 (2 << 0)
9080
9081#define _MIPIA_TEARING_CTRL                     (VLV_DISPLAY_BASE + 0x61194)
9082#define _MIPIC_TEARING_CTRL                     (VLV_DISPLAY_BASE + 0x61704)
9083#define MIPI_TEARING_CTRL(port)                 _MMIO_MIPI(port, _MIPIA_TEARING_CTRL, _MIPIC_TEARING_CTRL)
9084#define  TEARING_EFFECT_DELAY_SHIFT                     0
9085#define  TEARING_EFFECT_DELAY_MASK                      (0xffff << 0)
9086
9087/* XXX: all bits reserved */
9088#define _MIPIA_AUTOPWG                  (VLV_DISPLAY_BASE + 0x611a0)
9089
9090/* MIPI DSI Controller and D-PHY registers */
9091
9092#define _MIPIA_DEVICE_READY             (dev_priv->mipi_mmio_base + 0xb000)
9093#define _MIPIC_DEVICE_READY             (dev_priv->mipi_mmio_base + 0xb800)
9094#define MIPI_DEVICE_READY(port)         _MMIO_MIPI(port, _MIPIA_DEVICE_READY, _MIPIC_DEVICE_READY)
9095#define  BUS_POSSESSION                                 (1 << 3) /* set to give bus to receiver */
9096#define  ULPS_STATE_MASK                                (3 << 1)
9097#define  ULPS_STATE_ENTER                               (2 << 1)
9098#define  ULPS_STATE_EXIT                                (1 << 1)
9099#define  ULPS_STATE_NORMAL_OPERATION                    (0 << 1)
9100#define  DEVICE_READY                                   (1 << 0)
9101
9102#define _MIPIA_INTR_STAT                (dev_priv->mipi_mmio_base + 0xb004)
9103#define _MIPIC_INTR_STAT                (dev_priv->mipi_mmio_base + 0xb804)
9104#define MIPI_INTR_STAT(port)            _MMIO_MIPI(port, _MIPIA_INTR_STAT, _MIPIC_INTR_STAT)
9105#define _MIPIA_INTR_EN                  (dev_priv->mipi_mmio_base + 0xb008)
9106#define _MIPIC_INTR_EN                  (dev_priv->mipi_mmio_base + 0xb808)
9107#define MIPI_INTR_EN(port)              _MMIO_MIPI(port, _MIPIA_INTR_EN, _MIPIC_INTR_EN)
9108#define  TEARING_EFFECT                                 (1 << 31)
9109#define  SPL_PKT_SENT_INTERRUPT                         (1 << 30)
9110#define  GEN_READ_DATA_AVAIL                            (1 << 29)
9111#define  LP_GENERIC_WR_FIFO_FULL                        (1 << 28)
9112#define  HS_GENERIC_WR_FIFO_FULL                        (1 << 27)
9113#define  RX_PROT_VIOLATION                              (1 << 26)
9114#define  RX_INVALID_TX_LENGTH                           (1 << 25)
9115#define  ACK_WITH_NO_ERROR                              (1 << 24)
9116#define  TURN_AROUND_ACK_TIMEOUT                        (1 << 23)
9117#define  LP_RX_TIMEOUT                                  (1 << 22)
9118#define  HS_TX_TIMEOUT                                  (1 << 21)
9119#define  DPI_FIFO_UNDERRUN                              (1 << 20)
9120#define  LOW_CONTENTION                                 (1 << 19)
9121#define  HIGH_CONTENTION                                (1 << 18)
9122#define  TXDSI_VC_ID_INVALID                            (1 << 17)
9123#define  TXDSI_DATA_TYPE_NOT_RECOGNISED                 (1 << 16)
9124#define  TXCHECKSUM_ERROR                               (1 << 15)
9125#define  TXECC_MULTIBIT_ERROR                           (1 << 14)
9126#define  TXECC_SINGLE_BIT_ERROR                         (1 << 13)
9127#define  TXFALSE_CONTROL_ERROR                          (1 << 12)
9128#define  RXDSI_VC_ID_INVALID                            (1 << 11)
9129#define  RXDSI_DATA_TYPE_NOT_REGOGNISED                 (1 << 10)
9130#define  RXCHECKSUM_ERROR                               (1 << 9)
9131#define  RXECC_MULTIBIT_ERROR                           (1 << 8)
9132#define  RXECC_SINGLE_BIT_ERROR                         (1 << 7)
9133#define  RXFALSE_CONTROL_ERROR                          (1 << 6)
9134#define  RXHS_RECEIVE_TIMEOUT_ERROR                     (1 << 5)
9135#define  RX_LP_TX_SYNC_ERROR                            (1 << 4)
9136#define  RXEXCAPE_MODE_ENTRY_ERROR                      (1 << 3)
9137#define  RXEOT_SYNC_ERROR                               (1 << 2)
9138#define  RXSOT_SYNC_ERROR                               (1 << 1)
9139#define  RXSOT_ERROR                                    (1 << 0)
9140
9141#define _MIPIA_DSI_FUNC_PRG             (dev_priv->mipi_mmio_base + 0xb00c)
9142#define _MIPIC_DSI_FUNC_PRG             (dev_priv->mipi_mmio_base + 0xb80c)
9143#define MIPI_DSI_FUNC_PRG(port)         _MMIO_MIPI(port, _MIPIA_DSI_FUNC_PRG, _MIPIC_DSI_FUNC_PRG)
9144#define  CMD_MODE_DATA_WIDTH_MASK                       (7 << 13)
9145#define  CMD_MODE_NOT_SUPPORTED                         (0 << 13)
9146#define  CMD_MODE_DATA_WIDTH_16_BIT                     (1 << 13)
9147#define  CMD_MODE_DATA_WIDTH_9_BIT                      (2 << 13)
9148#define  CMD_MODE_DATA_WIDTH_8_BIT                      (3 << 13)
9149#define  CMD_MODE_DATA_WIDTH_OPTION1                    (4 << 13)
9150#define  CMD_MODE_DATA_WIDTH_OPTION2                    (5 << 13)
9151#define  VID_MODE_FORMAT_MASK                           (0xf << 7)
9152#define  VID_MODE_NOT_SUPPORTED                         (0 << 7)
9153#define  VID_MODE_FORMAT_RGB565                         (1 << 7)
9154#define  VID_MODE_FORMAT_RGB666_PACKED                  (2 << 7)
9155#define  VID_MODE_FORMAT_RGB666                         (3 << 7)
9156#define  VID_MODE_FORMAT_RGB888                         (4 << 7)
9157#define  CMD_MODE_CHANNEL_NUMBER_SHIFT                  5
9158#define  CMD_MODE_CHANNEL_NUMBER_MASK                   (3 << 5)
9159#define  VID_MODE_CHANNEL_NUMBER_SHIFT                  3
9160#define  VID_MODE_CHANNEL_NUMBER_MASK                   (3 << 3)
9161#define  DATA_LANES_PRG_REG_SHIFT                       0
9162#define  DATA_LANES_PRG_REG_MASK                        (7 << 0)
9163
9164#define _MIPIA_HS_TX_TIMEOUT            (dev_priv->mipi_mmio_base + 0xb010)
9165#define _MIPIC_HS_TX_TIMEOUT            (dev_priv->mipi_mmio_base + 0xb810)
9166#define MIPI_HS_TX_TIMEOUT(port)        _MMIO_MIPI(port, _MIPIA_HS_TX_TIMEOUT, _MIPIC_HS_TX_TIMEOUT)
9167#define  HIGH_SPEED_TX_TIMEOUT_COUNTER_MASK             0xffffff
9168
9169#define _MIPIA_LP_RX_TIMEOUT            (dev_priv->mipi_mmio_base + 0xb014)
9170#define _MIPIC_LP_RX_TIMEOUT            (dev_priv->mipi_mmio_base + 0xb814)
9171#define MIPI_LP_RX_TIMEOUT(port)        _MMIO_MIPI(port, _MIPIA_LP_RX_TIMEOUT, _MIPIC_LP_RX_TIMEOUT)
9172#define  LOW_POWER_RX_TIMEOUT_COUNTER_MASK              0xffffff
9173
9174#define _MIPIA_TURN_AROUND_TIMEOUT      (dev_priv->mipi_mmio_base + 0xb018)
9175#define _MIPIC_TURN_AROUND_TIMEOUT      (dev_priv->mipi_mmio_base + 0xb818)
9176#define MIPI_TURN_AROUND_TIMEOUT(port)  _MMIO_MIPI(port, _MIPIA_TURN_AROUND_TIMEOUT, _MIPIC_TURN_AROUND_TIMEOUT)
9177#define  TURN_AROUND_TIMEOUT_MASK                       0x3f
9178
9179#define _MIPIA_DEVICE_RESET_TIMER       (dev_priv->mipi_mmio_base + 0xb01c)
9180#define _MIPIC_DEVICE_RESET_TIMER       (dev_priv->mipi_mmio_base + 0xb81c)
9181#define MIPI_DEVICE_RESET_TIMER(port)   _MMIO_MIPI(port, _MIPIA_DEVICE_RESET_TIMER, _MIPIC_DEVICE_RESET_TIMER)
9182#define  DEVICE_RESET_TIMER_MASK                        0xffff
9183
9184#define _MIPIA_DPI_RESOLUTION           (dev_priv->mipi_mmio_base + 0xb020)
9185#define _MIPIC_DPI_RESOLUTION           (dev_priv->mipi_mmio_base + 0xb820)
9186#define MIPI_DPI_RESOLUTION(port)       _MMIO_MIPI(port, _MIPIA_DPI_RESOLUTION, _MIPIC_DPI_RESOLUTION)
9187#define  VERTICAL_ADDRESS_SHIFT                         16
9188#define  VERTICAL_ADDRESS_MASK                          (0xffff << 16)
9189#define  HORIZONTAL_ADDRESS_SHIFT                       0
9190#define  HORIZONTAL_ADDRESS_MASK                        0xffff
9191
9192#define _MIPIA_DBI_FIFO_THROTTLE        (dev_priv->mipi_mmio_base + 0xb024)
9193#define _MIPIC_DBI_FIFO_THROTTLE        (dev_priv->mipi_mmio_base + 0xb824)
9194#define MIPI_DBI_FIFO_THROTTLE(port)    _MMIO_MIPI(port, _MIPIA_DBI_FIFO_THROTTLE, _MIPIC_DBI_FIFO_THROTTLE)
9195#define  DBI_FIFO_EMPTY_HALF                            (0 << 0)
9196#define  DBI_FIFO_EMPTY_QUARTER                         (1 << 0)
9197#define  DBI_FIFO_EMPTY_7_LOCATIONS                     (2 << 0)
9198
9199/* regs below are bits 15:0 */
9200#define _MIPIA_HSYNC_PADDING_COUNT      (dev_priv->mipi_mmio_base + 0xb028)
9201#define _MIPIC_HSYNC_PADDING_COUNT      (dev_priv->mipi_mmio_base + 0xb828)
9202#define MIPI_HSYNC_PADDING_COUNT(port)  _MMIO_MIPI(port, _MIPIA_HSYNC_PADDING_COUNT, _MIPIC_HSYNC_PADDING_COUNT)
9203
9204#define _MIPIA_HBP_COUNT                (dev_priv->mipi_mmio_base + 0xb02c)
9205#define _MIPIC_HBP_COUNT                (dev_priv->mipi_mmio_base + 0xb82c)
9206#define MIPI_HBP_COUNT(port)            _MMIO_MIPI(port, _MIPIA_HBP_COUNT, _MIPIC_HBP_COUNT)
9207
9208#define _MIPIA_HFP_COUNT                (dev_priv->mipi_mmio_base + 0xb030)
9209#define _MIPIC_HFP_COUNT                (dev_priv->mipi_mmio_base + 0xb830)
9210#define MIPI_HFP_COUNT(port)            _MMIO_MIPI(port, _MIPIA_HFP_COUNT, _MIPIC_HFP_COUNT)
9211
9212#define _MIPIA_HACTIVE_AREA_COUNT       (dev_priv->mipi_mmio_base + 0xb034)
9213#define _MIPIC_HACTIVE_AREA_COUNT       (dev_priv->mipi_mmio_base + 0xb834)
9214#define MIPI_HACTIVE_AREA_COUNT(port)   _MMIO_MIPI(port, _MIPIA_HACTIVE_AREA_COUNT, _MIPIC_HACTIVE_AREA_COUNT)
9215
9216#define _MIPIA_VSYNC_PADDING_COUNT      (dev_priv->mipi_mmio_base + 0xb038)
9217#define _MIPIC_VSYNC_PADDING_COUNT      (dev_priv->mipi_mmio_base + 0xb838)
9218#define MIPI_VSYNC_PADDING_COUNT(port)  _MMIO_MIPI(port, _MIPIA_VSYNC_PADDING_COUNT, _MIPIC_VSYNC_PADDING_COUNT)
9219
9220#define _MIPIA_VBP_COUNT                (dev_priv->mipi_mmio_base + 0xb03c)
9221#define _MIPIC_VBP_COUNT                (dev_priv->mipi_mmio_base + 0xb83c)
9222#define MIPI_VBP_COUNT(port)            _MMIO_MIPI(port, _MIPIA_VBP_COUNT, _MIPIC_VBP_COUNT)
9223
9224#define _MIPIA_VFP_COUNT                (dev_priv->mipi_mmio_base + 0xb040)
9225#define _MIPIC_VFP_COUNT                (dev_priv->mipi_mmio_base + 0xb840)
9226#define MIPI_VFP_COUNT(port)            _MMIO_MIPI(port, _MIPIA_VFP_COUNT, _MIPIC_VFP_COUNT)
9227
9228#define _MIPIA_HIGH_LOW_SWITCH_COUNT    (dev_priv->mipi_mmio_base + 0xb044)
9229#define _MIPIC_HIGH_LOW_SWITCH_COUNT    (dev_priv->mipi_mmio_base + 0xb844)
9230#define MIPI_HIGH_LOW_SWITCH_COUNT(port)        _MMIO_MIPI(port,        _MIPIA_HIGH_LOW_SWITCH_COUNT, _MIPIC_HIGH_LOW_SWITCH_COUNT)
9231
9232/* regs above are bits 15:0 */
9233
9234#define _MIPIA_DPI_CONTROL              (dev_priv->mipi_mmio_base + 0xb048)
9235#define _MIPIC_DPI_CONTROL              (dev_priv->mipi_mmio_base + 0xb848)
9236#define MIPI_DPI_CONTROL(port)          _MMIO_MIPI(port, _MIPIA_DPI_CONTROL, _MIPIC_DPI_CONTROL)
9237#define  DPI_LP_MODE                                    (1 << 6)
9238#define  BACKLIGHT_OFF                                  (1 << 5)
9239#define  BACKLIGHT_ON                                   (1 << 4)
9240#define  COLOR_MODE_OFF                                 (1 << 3)
9241#define  COLOR_MODE_ON                                  (1 << 2)
9242#define  TURN_ON                                        (1 << 1)
9243#define  SHUTDOWN                                       (1 << 0)
9244
9245#define _MIPIA_DPI_DATA                 (dev_priv->mipi_mmio_base + 0xb04c)
9246#define _MIPIC_DPI_DATA                 (dev_priv->mipi_mmio_base + 0xb84c)
9247#define MIPI_DPI_DATA(port)             _MMIO_MIPI(port, _MIPIA_DPI_DATA, _MIPIC_DPI_DATA)
9248#define  COMMAND_BYTE_SHIFT                             0
9249#define  COMMAND_BYTE_MASK                              (0x3f << 0)
9250
9251#define _MIPIA_INIT_COUNT               (dev_priv->mipi_mmio_base + 0xb050)
9252#define _MIPIC_INIT_COUNT               (dev_priv->mipi_mmio_base + 0xb850)
9253#define MIPI_INIT_COUNT(port)           _MMIO_MIPI(port, _MIPIA_INIT_COUNT, _MIPIC_INIT_COUNT)
9254#define  MASTER_INIT_TIMER_SHIFT                        0
9255#define  MASTER_INIT_TIMER_MASK                         (0xffff << 0)
9256
9257#define _MIPIA_MAX_RETURN_PKT_SIZE      (dev_priv->mipi_mmio_base + 0xb054)
9258#define _MIPIC_MAX_RETURN_PKT_SIZE      (dev_priv->mipi_mmio_base + 0xb854)
9259#define MIPI_MAX_RETURN_PKT_SIZE(port)  _MMIO_MIPI(port, \
9260                        _MIPIA_MAX_RETURN_PKT_SIZE, _MIPIC_MAX_RETURN_PKT_SIZE)
9261#define  MAX_RETURN_PKT_SIZE_SHIFT                      0
9262#define  MAX_RETURN_PKT_SIZE_MASK                       (0x3ff << 0)
9263
9264#define _MIPIA_VIDEO_MODE_FORMAT        (dev_priv->mipi_mmio_base + 0xb058)
9265#define _MIPIC_VIDEO_MODE_FORMAT        (dev_priv->mipi_mmio_base + 0xb858)
9266#define MIPI_VIDEO_MODE_FORMAT(port)    _MMIO_MIPI(port, _MIPIA_VIDEO_MODE_FORMAT, _MIPIC_VIDEO_MODE_FORMAT)
9267#define  RANDOM_DPI_DISPLAY_RESOLUTION                  (1 << 4)
9268#define  DISABLE_VIDEO_BTA                              (1 << 3)
9269#define  IP_TG_CONFIG                                   (1 << 2)
9270#define  VIDEO_MODE_NON_BURST_WITH_SYNC_PULSE           (1 << 0)
9271#define  VIDEO_MODE_NON_BURST_WITH_SYNC_EVENTS          (2 << 0)
9272#define  VIDEO_MODE_BURST                               (3 << 0)
9273
9274#define _MIPIA_EOT_DISABLE              (dev_priv->mipi_mmio_base + 0xb05c)
9275#define _MIPIC_EOT_DISABLE              (dev_priv->mipi_mmio_base + 0xb85c)
9276#define MIPI_EOT_DISABLE(port)          _MMIO_MIPI(port, _MIPIA_EOT_DISABLE, _MIPIC_EOT_DISABLE)
9277#define  BXT_DEFEATURE_DPI_FIFO_CTR                     (1 << 9)
9278#define  BXT_DPHY_DEFEATURE_EN                          (1 << 8)
9279#define  LP_RX_TIMEOUT_ERROR_RECOVERY_DISABLE           (1 << 7)
9280#define  HS_RX_TIMEOUT_ERROR_RECOVERY_DISABLE           (1 << 6)
9281#define  LOW_CONTENTION_RECOVERY_DISABLE                (1 << 5)
9282#define  HIGH_CONTENTION_RECOVERY_DISABLE               (1 << 4)
9283#define  TXDSI_TYPE_NOT_RECOGNISED_ERROR_RECOVERY_DISABLE (1 << 3)
9284#define  TXECC_MULTIBIT_ERROR_RECOVERY_DISABLE          (1 << 2)
9285#define  CLOCKSTOP                                      (1 << 1)
9286#define  EOT_DISABLE                                    (1 << 0)
9287
9288#define _MIPIA_LP_BYTECLK               (dev_priv->mipi_mmio_base + 0xb060)
9289#define _MIPIC_LP_BYTECLK               (dev_priv->mipi_mmio_base + 0xb860)
9290#define MIPI_LP_BYTECLK(port)           _MMIO_MIPI(port, _MIPIA_LP_BYTECLK, _MIPIC_LP_BYTECLK)
9291#define  LP_BYTECLK_SHIFT                               0
9292#define  LP_BYTECLK_MASK                                (0xffff << 0)
9293
9294#define _MIPIA_TLPX_TIME_COUNT          (dev_priv->mipi_mmio_base + 0xb0a4)
9295#define _MIPIC_TLPX_TIME_COUNT          (dev_priv->mipi_mmio_base + 0xb8a4)
9296#define MIPI_TLPX_TIME_COUNT(port)       _MMIO_MIPI(port, _MIPIA_TLPX_TIME_COUNT, _MIPIC_TLPX_TIME_COUNT)
9297
9298#define _MIPIA_CLK_LANE_TIMING          (dev_priv->mipi_mmio_base + 0xb098)
9299#define _MIPIC_CLK_LANE_TIMING          (dev_priv->mipi_mmio_base + 0xb898)
9300#define MIPI_CLK_LANE_TIMING(port)       _MMIO_MIPI(port, _MIPIA_CLK_LANE_TIMING, _MIPIC_CLK_LANE_TIMING)
9301
9302/* bits 31:0 */
9303#define _MIPIA_LP_GEN_DATA              (dev_priv->mipi_mmio_base + 0xb064)
9304#define _MIPIC_LP_GEN_DATA              (dev_priv->mipi_mmio_base + 0xb864)
9305#define MIPI_LP_GEN_DATA(port)          _MMIO_MIPI(port, _MIPIA_LP_GEN_DATA, _MIPIC_LP_GEN_DATA)
9306
9307/* bits 31:0 */
9308#define _MIPIA_HS_GEN_DATA              (dev_priv->mipi_mmio_base + 0xb068)
9309#define _MIPIC_HS_GEN_DATA              (dev_priv->mipi_mmio_base + 0xb868)
9310#define MIPI_HS_GEN_DATA(port)          _MMIO_MIPI(port, _MIPIA_HS_GEN_DATA, _MIPIC_HS_GEN_DATA)
9311
9312#define _MIPIA_LP_GEN_CTRL              (dev_priv->mipi_mmio_base + 0xb06c)
9313#define _MIPIC_LP_GEN_CTRL              (dev_priv->mipi_mmio_base + 0xb86c)
9314#define MIPI_LP_GEN_CTRL(port)          _MMIO_MIPI(port, _MIPIA_LP_GEN_CTRL, _MIPIC_LP_GEN_CTRL)
9315#define _MIPIA_HS_GEN_CTRL              (dev_priv->mipi_mmio_base + 0xb070)
9316#define _MIPIC_HS_GEN_CTRL              (dev_priv->mipi_mmio_base + 0xb870)
9317#define MIPI_HS_GEN_CTRL(port)          _MMIO_MIPI(port, _MIPIA_HS_GEN_CTRL, _MIPIC_HS_GEN_CTRL)
9318#define  LONG_PACKET_WORD_COUNT_SHIFT                   8
9319#define  LONG_PACKET_WORD_COUNT_MASK                    (0xffff << 8)
9320#define  SHORT_PACKET_PARAM_SHIFT                       8
9321#define  SHORT_PACKET_PARAM_MASK                        (0xffff << 8)
9322#define  VIRTUAL_CHANNEL_SHIFT                          6
9323#define  VIRTUAL_CHANNEL_MASK                           (3 << 6)
9324#define  DATA_TYPE_SHIFT                                0
9325#define  DATA_TYPE_MASK                                 (0x3f << 0)
9326/* data type values, see include/video/mipi_display.h */
9327
9328#define _MIPIA_GEN_FIFO_STAT            (dev_priv->mipi_mmio_base + 0xb074)
9329#define _MIPIC_GEN_FIFO_STAT            (dev_priv->mipi_mmio_base + 0xb874)
9330#define MIPI_GEN_FIFO_STAT(port)        _MMIO_MIPI(port, _MIPIA_GEN_FIFO_STAT, _MIPIC_GEN_FIFO_STAT)
9331#define  DPI_FIFO_EMPTY                                 (1 << 28)
9332#define  DBI_FIFO_EMPTY                                 (1 << 27)
9333#define  LP_CTRL_FIFO_EMPTY                             (1 << 26)
9334#define  LP_CTRL_FIFO_HALF_EMPTY                        (1 << 25)
9335#define  LP_CTRL_FIFO_FULL                              (1 << 24)
9336#define  HS_CTRL_FIFO_EMPTY                             (1 << 18)
9337#define  HS_CTRL_FIFO_HALF_EMPTY                        (1 << 17)
9338#define  HS_CTRL_FIFO_FULL                              (1 << 16)
9339#define  LP_DATA_FIFO_EMPTY                             (1 << 10)
9340#define  LP_DATA_FIFO_HALF_EMPTY                        (1 << 9)
9341#define  LP_DATA_FIFO_FULL                              (1 << 8)
9342#define  HS_DATA_FIFO_EMPTY                             (1 << 2)
9343#define  HS_DATA_FIFO_HALF_EMPTY                        (1 << 1)
9344#define  HS_DATA_FIFO_FULL                              (1 << 0)
9345
9346#define _MIPIA_HS_LS_DBI_ENABLE         (dev_priv->mipi_mmio_base + 0xb078)
9347#define _MIPIC_HS_LS_DBI_ENABLE         (dev_priv->mipi_mmio_base + 0xb878)
9348#define MIPI_HS_LP_DBI_ENABLE(port)     _MMIO_MIPI(port, _MIPIA_HS_LS_DBI_ENABLE, _MIPIC_HS_LS_DBI_ENABLE)
9349#define  DBI_HS_LP_MODE_MASK                            (1 << 0)
9350#define  DBI_LP_MODE                                    (1 << 0)
9351#define  DBI_HS_MODE                                    (0 << 0)
9352
9353#define _MIPIA_DPHY_PARAM               (dev_priv->mipi_mmio_base + 0xb080)
9354#define _MIPIC_DPHY_PARAM               (dev_priv->mipi_mmio_base + 0xb880)
9355#define MIPI_DPHY_PARAM(port)           _MMIO_MIPI(port, _MIPIA_DPHY_PARAM, _MIPIC_DPHY_PARAM)
9356#define  EXIT_ZERO_COUNT_SHIFT                          24
9357#define  EXIT_ZERO_COUNT_MASK                           (0x3f << 24)
9358#define  TRAIL_COUNT_SHIFT                              16
9359#define  TRAIL_COUNT_MASK                               (0x1f << 16)
9360#define  CLK_ZERO_COUNT_SHIFT                           8
9361#define  CLK_ZERO_COUNT_MASK                            (0xff << 8)
9362#define  PREPARE_COUNT_SHIFT                            0
9363#define  PREPARE_COUNT_MASK                             (0x3f << 0)
9364
9365/* bits 31:0 */
9366#define _MIPIA_DBI_BW_CTRL              (dev_priv->mipi_mmio_base + 0xb084)
9367#define _MIPIC_DBI_BW_CTRL              (dev_priv->mipi_mmio_base + 0xb884)
9368#define MIPI_DBI_BW_CTRL(port)          _MMIO_MIPI(port, _MIPIA_DBI_BW_CTRL, _MIPIC_DBI_BW_CTRL)
9369
9370#define _MIPIA_CLK_LANE_SWITCH_TIME_CNT         (dev_priv->mipi_mmio_base + 0xb088)
9371#define _MIPIC_CLK_LANE_SWITCH_TIME_CNT         (dev_priv->mipi_mmio_base + 0xb888)
9372#define MIPI_CLK_LANE_SWITCH_TIME_CNT(port)     _MMIO_MIPI(port, _MIPIA_CLK_LANE_SWITCH_TIME_CNT, _MIPIC_CLK_LANE_SWITCH_TIME_CNT)
9373#define  LP_HS_SSW_CNT_SHIFT                            16
9374#define  LP_HS_SSW_CNT_MASK                             (0xffff << 16)
9375#define  HS_LP_PWR_SW_CNT_SHIFT                         0
9376#define  HS_LP_PWR_SW_CNT_MASK                          (0xffff << 0)
9377
9378#define _MIPIA_STOP_STATE_STALL         (dev_priv->mipi_mmio_base + 0xb08c)
9379#define _MIPIC_STOP_STATE_STALL         (dev_priv->mipi_mmio_base + 0xb88c)
9380#define MIPI_STOP_STATE_STALL(port)     _MMIO_MIPI(port, _MIPIA_STOP_STATE_STALL, _MIPIC_STOP_STATE_STALL)
9381#define  STOP_STATE_STALL_COUNTER_SHIFT                 0
9382#define  STOP_STATE_STALL_COUNTER_MASK                  (0xff << 0)
9383
9384#define _MIPIA_INTR_STAT_REG_1          (dev_priv->mipi_mmio_base + 0xb090)
9385#define _MIPIC_INTR_STAT_REG_1          (dev_priv->mipi_mmio_base + 0xb890)
9386#define MIPI_INTR_STAT_REG_1(port)      _MMIO_MIPI(port, _MIPIA_INTR_STAT_REG_1, _MIPIC_INTR_STAT_REG_1)
9387#define _MIPIA_INTR_EN_REG_1            (dev_priv->mipi_mmio_base + 0xb094)
9388#define _MIPIC_INTR_EN_REG_1            (dev_priv->mipi_mmio_base + 0xb894)
9389#define MIPI_INTR_EN_REG_1(port)        _MMIO_MIPI(port, _MIPIA_INTR_EN_REG_1, _MIPIC_INTR_EN_REG_1)
9390#define  RX_CONTENTION_DETECTED                         (1 << 0)
9391
9392/* XXX: only pipe A ?!? */
9393#define MIPIA_DBI_TYPEC_CTRL            (dev_priv->mipi_mmio_base + 0xb100)
9394#define  DBI_TYPEC_ENABLE                               (1 << 31)
9395#define  DBI_TYPEC_WIP                                  (1 << 30)
9396#define  DBI_TYPEC_OPTION_SHIFT                         28
9397#define  DBI_TYPEC_OPTION_MASK                          (3 << 28)
9398#define  DBI_TYPEC_FREQ_SHIFT                           24
9399#define  DBI_TYPEC_FREQ_MASK                            (0xf << 24)
9400#define  DBI_TYPEC_OVERRIDE                             (1 << 8)
9401#define  DBI_TYPEC_OVERRIDE_COUNTER_SHIFT               0
9402#define  DBI_TYPEC_OVERRIDE_COUNTER_MASK                (0xff << 0)
9403
9404
9405/* MIPI adapter registers */
9406
9407#define _MIPIA_CTRL                     (dev_priv->mipi_mmio_base + 0xb104)
9408#define _MIPIC_CTRL                     (dev_priv->mipi_mmio_base + 0xb904)
9409#define MIPI_CTRL(port)                 _MMIO_MIPI(port, _MIPIA_CTRL, _MIPIC_CTRL)
9410#define  ESCAPE_CLOCK_DIVIDER_SHIFT                     5 /* A only */
9411#define  ESCAPE_CLOCK_DIVIDER_MASK                      (3 << 5)
9412#define  ESCAPE_CLOCK_DIVIDER_1                         (0 << 5)
9413#define  ESCAPE_CLOCK_DIVIDER_2                         (1 << 5)
9414#define  ESCAPE_CLOCK_DIVIDER_4                         (2 << 5)
9415#define  READ_REQUEST_PRIORITY_SHIFT                    3
9416#define  READ_REQUEST_PRIORITY_MASK                     (3 << 3)
9417#define  READ_REQUEST_PRIORITY_LOW                      (0 << 3)
9418#define  READ_REQUEST_PRIORITY_HIGH                     (3 << 3)
9419#define  RGB_FLIP_TO_BGR                                (1 << 2)
9420
9421#define  BXT_PIPE_SELECT_SHIFT                          7
9422#define  BXT_PIPE_SELECT_MASK                           (7 << 7)
9423#define  BXT_PIPE_SELECT(pipe)                          ((pipe) << 7)
9424#define  GLK_PHY_STATUS_PORT_READY                      (1 << 31) /* RO */
9425#define  GLK_ULPS_NOT_ACTIVE                            (1 << 30) /* RO */
9426#define  GLK_MIPIIO_RESET_RELEASED                      (1 << 28)
9427#define  GLK_CLOCK_LANE_STOP_STATE                      (1 << 27) /* RO */
9428#define  GLK_DATA_LANE_STOP_STATE                       (1 << 26) /* RO */
9429#define  GLK_LP_WAKE                                    (1 << 22)
9430#define  GLK_LP11_LOW_PWR_MODE                          (1 << 21)
9431#define  GLK_LP00_LOW_PWR_MODE                          (1 << 20)
9432#define  GLK_FIREWALL_ENABLE                            (1 << 16)
9433#define  BXT_PIXEL_OVERLAP_CNT_MASK                     (0xf << 10)
9434#define  BXT_PIXEL_OVERLAP_CNT_SHIFT                    10
9435#define  BXT_DSC_ENABLE                                 (1 << 3)
9436#define  BXT_RGB_FLIP                                   (1 << 2)
9437#define  GLK_MIPIIO_PORT_POWERED                        (1 << 1) /* RO */
9438#define  GLK_MIPIIO_ENABLE                              (1 << 0)
9439
9440#define _MIPIA_DATA_ADDRESS             (dev_priv->mipi_mmio_base + 0xb108)
9441#define _MIPIC_DATA_ADDRESS             (dev_priv->mipi_mmio_base + 0xb908)
9442#define MIPI_DATA_ADDRESS(port)         _MMIO_MIPI(port, _MIPIA_DATA_ADDRESS, _MIPIC_DATA_ADDRESS)
9443#define  DATA_MEM_ADDRESS_SHIFT                         5
9444#define  DATA_MEM_ADDRESS_MASK                          (0x7ffffff << 5)
9445#define  DATA_VALID                                     (1 << 0)
9446
9447#define _MIPIA_DATA_LENGTH              (dev_priv->mipi_mmio_base + 0xb10c)
9448#define _MIPIC_DATA_LENGTH              (dev_priv->mipi_mmio_base + 0xb90c)
9449#define MIPI_DATA_LENGTH(port)          _MMIO_MIPI(port, _MIPIA_DATA_LENGTH, _MIPIC_DATA_LENGTH)
9450#define  DATA_LENGTH_SHIFT                              0
9451#define  DATA_LENGTH_MASK                               (0xfffff << 0)
9452
9453#define _MIPIA_COMMAND_ADDRESS          (dev_priv->mipi_mmio_base + 0xb110)
9454#define _MIPIC_COMMAND_ADDRESS          (dev_priv->mipi_mmio_base + 0xb910)
9455#define MIPI_COMMAND_ADDRESS(port)      _MMIO_MIPI(port, _MIPIA_COMMAND_ADDRESS, _MIPIC_COMMAND_ADDRESS)
9456#define  COMMAND_MEM_ADDRESS_SHIFT                      5
9457#define  COMMAND_MEM_ADDRESS_MASK                       (0x7ffffff << 5)
9458#define  AUTO_PWG_ENABLE                                (1 << 2)
9459#define  MEMORY_WRITE_DATA_FROM_PIPE_RENDERING          (1 << 1)
9460#define  COMMAND_VALID                                  (1 << 0)
9461
9462#define _MIPIA_COMMAND_LENGTH           (dev_priv->mipi_mmio_base + 0xb114)
9463#define _MIPIC_COMMAND_LENGTH           (dev_priv->mipi_mmio_base + 0xb914)
9464#define MIPI_COMMAND_LENGTH(port)       _MMIO_MIPI(port, _MIPIA_COMMAND_LENGTH, _MIPIC_COMMAND_LENGTH)
9465#define  COMMAND_LENGTH_SHIFT(n)                        (8 * (n)) /* n: 0...3 */
9466#define  COMMAND_LENGTH_MASK(n)                         (0xff << (8 * (n)))
9467
9468#define _MIPIA_READ_DATA_RETURN0        (dev_priv->mipi_mmio_base + 0xb118)
9469#define _MIPIC_READ_DATA_RETURN0        (dev_priv->mipi_mmio_base + 0xb918)
9470#define MIPI_READ_DATA_RETURN(port, n) _MMIO(_MIPI(port, _MIPIA_READ_DATA_RETURN0, _MIPIC_READ_DATA_RETURN0) + 4 * (n)) /* n: 0...7 */
9471
9472#define _MIPIA_READ_DATA_VALID          (dev_priv->mipi_mmio_base + 0xb138)
9473#define _MIPIC_READ_DATA_VALID          (dev_priv->mipi_mmio_base + 0xb938)
9474#define MIPI_READ_DATA_VALID(port)      _MMIO_MIPI(port, _MIPIA_READ_DATA_VALID, _MIPIC_READ_DATA_VALID)
9475#define  READ_DATA_VALID(n)                             (1 << (n))
9476
9477/* For UMS only (deprecated): */
9478#define _PALETTE_A (dev_priv->info.display_mmio_offset + 0xa000)
9479#define _PALETTE_B (dev_priv->info.display_mmio_offset + 0xa800)
9480
9481/* MOCS (Memory Object Control State) registers */
9482#define GEN9_LNCFCMOCS(i)       _MMIO(0xb020 + (i) * 4) /* L3 Cache Control */
9483
9484#define GEN9_GFX_MOCS(i)        _MMIO(0xc800 + (i) * 4) /* Graphics MOCS registers */
9485#define GEN9_MFX0_MOCS(i)       _MMIO(0xc900 + (i) * 4) /* Media 0 MOCS registers */
9486#define GEN9_MFX1_MOCS(i)       _MMIO(0xca00 + (i) * 4) /* Media 1 MOCS registers */
9487#define GEN9_VEBOX_MOCS(i)      _MMIO(0xcb00 + (i) * 4) /* Video MOCS registers */
9488#define GEN9_BLT_MOCS(i)        _MMIO(0xcc00 + (i) * 4) /* Blitter MOCS registers */
9489
9490/* gamt regs */
9491#define GEN8_L3_LRA_1_GPGPU _MMIO(0x4dd4)
9492#define   GEN8_L3_LRA_1_GPGPU_DEFAULT_VALUE_BDW  0x67F1427F /* max/min for LRA1/2 */
9493#define   GEN8_L3_LRA_1_GPGPU_DEFAULT_VALUE_CHV  0x5FF101FF /* max/min for LRA1/2 */
9494#define   GEN9_L3_LRA_1_GPGPU_DEFAULT_VALUE_SKL  0x67F1427F /*    "        " */
9495#define   GEN9_L3_LRA_1_GPGPU_DEFAULT_VALUE_BXT  0x5FF101FF /*    "        " */
9496
9497#define MMCD_MISC_CTRL          _MMIO(0x4ddc) /* skl+ */
9498#define  MMCD_PCLA              (1 << 31)
9499#define  MMCD_HOTSPOT_EN        (1 << 27)
9500
9501#endif /* _I915_REG_H_ */
9502