WARN(!intel_irqs_enabled(dev_priv), "IRQs disabled");
  
 -      if (i915_seqno_passed(ring->get_seqno(ring, true), seqno))
 +      if (i915_gem_request_completed(req, true))
                return 0;
  
-       timeout_expire = timeout ? jiffies + nsecs_to_jiffies((u64)*timeout) : 0;
+       timeout_expire = timeout ?
+               jiffies + nsecs_to_jiffies_timeout((u64)*timeout) : 0;
  
        if (INTEL_INFO(dev)->gen >= 6 && ring->id == RCS && can_wait_boost(file_priv)) {
                gen6_rps_boost(dev_priv);
 
  #define _PORT(port, a, b) ((a) + (port)*((b)-(a)))
  #define _PIPE3(pipe, a, b, c) ((pipe) == PIPE_A ? (a) : \
                               (pipe) == PIPE_B ? (b) : (c))
 +#define _PORT3(port, a, b, c) ((port) == PORT_A ? (a) : \
 +                             (port) == PORT_B ? (b) : (c))
  
- #define _MASKED_BIT_ENABLE(a) (((a) << 16) | (a))
- #define _MASKED_BIT_DISABLE(a) ((a) << 16)
+ #define _MASKED_FIELD(mask, value) ({                                    \
+       if (__builtin_constant_p(mask))                                    \
+               BUILD_BUG_ON_MSG(((mask) & 0xffff0000), "Incorrect mask"); \
+       if (__builtin_constant_p(value))                                   \
+               BUILD_BUG_ON_MSG((value) & 0xffff0000, "Incorrect value"); \
+       if (__builtin_constant_p(mask) && __builtin_constant_p(value))     \
+               BUILD_BUG_ON_MSG((value) & ~(mask),                        \
+                                "Incorrect value for mask");              \
+       (mask) << 16 | (value); })
+ #define _MASKED_BIT_ENABLE(a) ({ typeof(a) _a = (a); _MASKED_FIELD(_a, _a); })
+ #define _MASKED_BIT_DISABLE(a)        (_MASKED_FIELD((a), 0))
+ 
+ 
  
  /* PCI config space */
  
 
  void intel_init_audio(struct drm_device *dev);
  void intel_audio_codec_enable(struct intel_encoder *encoder);
  void intel_audio_codec_disable(struct intel_encoder *encoder);
+ void i915_audio_component_init(struct drm_i915_private *dev_priv);
+ void i915_audio_component_cleanup(struct drm_i915_private *dev_priv);
  
  /* intel_display.c */
 -const char *intel_output_name(int output);
  bool intel_has_pending_fb_unpin(struct drm_device *dev);
  int intel_pch_rawclk(struct drm_device *dev);
  void intel_mark_busy(struct drm_device *dev);
 
         * to keep in mind (see 3DSTATE_PS and 3DSTATE_WM).
         */
        I915_WRITE(GEN7_GT_MODE,
-                  GEN6_WIZ_HASHING_MASK | GEN6_WIZ_HASHING_16x4);
+                  _MASKED_FIELD(GEN6_WIZ_HASHING_MASK, GEN6_WIZ_HASHING_16x4));
  
 +      /* WaSampleCChickenBitEnable:hsw */
 +      I915_WRITE(HALF_SLICE_CHICKEN3,
 +                 _MASKED_BIT_ENABLE(HSW_SAMPLE_C_PERFORMANCE));
 +
        /* WaSwitchSolVfFArbitrationPriority:hsw */
        I915_WRITE(GAM_ECOCHK, I915_READ(GAM_ECOCHK) | HSW_ECOCHK_ARB_PRIO_SOL);
  
 
        return 0;
  }
  
 +static int intel_rcs_ctx_init(struct intel_engine_cs *ring,
 +                            struct intel_context *ctx)
 +{
 +      int ret;
 +
 +      ret = intel_ring_workarounds_emit(ring, ctx);
 +      if (ret != 0)
 +              return ret;
 +
 +      ret = i915_gem_render_state_init(ring);
 +      if (ret)
 +              DRM_ERROR("init render state: %d\n", ret);
 +
 +      return ret;
 +}
 +
  static int wa_add(struct drm_i915_private *dev_priv,
-                 const u32 addr, const u32 val, const u32 mask)
+                 const u32 addr, const u32 mask, const u32 val)
  {
        const u32 idx = dev_priv->workarounds.count;