DG1_HZ_READ_SUPPRESSION_OPTIMIZATION_DISABLE);
 }
 
+static void fakewa_disable_nestedbb_mode(struct intel_engine_cs *engine,
+                                        struct i915_wa_list *wal)
+{
+       /*
+        * This is a "fake" workaround defined by software to ensure we
+        * maintain reliable, backward-compatible behavior for userspace with
+        * regards to how nested MI_BATCH_BUFFER_START commands are handled.
+        *
+        * The per-context setting of MI_MODE[12] determines whether the bits
+        * of a nested MI_BATCH_BUFFER_START instruction should be interpreted
+        * in the traditional manner or whether they should instead use a new
+        * tgl+ meaning that breaks backward compatibility, but allows nesting
+        * into 3rd-level batchbuffers.  When this new capability was first
+        * added in TGL, it remained off by default unless a context
+        * intentionally opted in to the new behavior.  However Xe_HPG now
+        * flips this on by default and requires that we explicitly opt out if
+        * we don't want the new behavior.
+        *
+        * From a SW perspective, we want to maintain the backward-compatible
+        * behavior for userspace, so we'll apply a fake workaround to set it
+        * back to the legacy behavior on platforms where the hardware default
+        * is to break compatibility.  At the moment there is no Linux
+        * userspace that utilizes third-level batchbuffers, so this will avoid
+        * userspace from needing to make any changes.  using the legacy
+        * meaning is the correct thing to do.  If/when we have userspace
+        * consumers that want to utilize third-level batch nesting, we can
+        * provide a context parameter to allow them to opt-in.
+        */
+       wa_masked_dis(wal, RING_MI_MODE(engine->mmio_base), TGL_NESTED_BB_EN);
+}
+
 static void
 __intel_engine_init_ctx_wa(struct intel_engine_cs *engine,
                           struct i915_wa_list *wal,
 {
        struct drm_i915_private *i915 = engine->i915;
 
+       wa_init_start(wal, name, engine->name);
+
+       /* Applies to all engines */
+       if (GRAPHICS_VER_FULL(i915) >= IP_VER(12, 55))
+               fakewa_disable_nestedbb_mode(engine, wal);
+
        if (engine->class != RENDER_CLASS)
                return;
 
-       wa_init_start(wal, name, engine->name);
-
        if (IS_DG1(i915))
                dg1_ctx_workarounds_init(engine, wal);
        else if (GRAPHICS_VER(i915) == 12)