static bool needs_fence_registers(struct context *ctx)
 {
-       return !intel_gt_is_wedged(ctx->engine->gt);
+       struct intel_gt *gt = ctx->engine->gt;
+
+       if (intel_gt_is_wedged(gt))
+               return false;
+
+       return gt->ggtt->num_fences;
 }
 
 static bool needs_mi_store_dword(struct context *ctx)
 
        int tiling;
        int err;
 
+       if (!i915_ggtt_has_aperture(&i915->ggtt))
+               return 0;
+
        /* We want to check the page mapping and fencing of a large object
         * mmapped through the GTT. The object we create is larger than can
         * possibly be mmaped as a whole, and so we must use partial GGTT vma.
        IGT_TIMEOUT(end);
        int err;
 
+       if (!i915_ggtt_has_aperture(&i915->ggtt))
+               return 0;
+
        /*
         * igt_partial_tiling() does an exhastive check of partial tiling
         * chunking, but will undoubtably run out of time. Here, we do a
 
        struct i915_request *rq;
        struct evict_vma arg;
        struct hang h;
+       unsigned int pin_flags;
        int err;
 
+       if (!gt->ggtt->num_fences && flags & EXEC_OBJECT_NEEDS_FENCE)
+               return 0;
+
        if (!engine || !intel_engine_can_store_dword(engine))
                return 0;
 
                goto out_obj;
        }
 
-       err = i915_vma_pin(arg.vma, 0, 0,
-                          i915_vma_is_ggtt(arg.vma) ?
-                          PIN_GLOBAL | PIN_MAPPABLE :
-                          PIN_USER);
+       pin_flags = i915_vma_is_ggtt(arg.vma) ? PIN_GLOBAL : PIN_USER;
+
+       if (flags & EXEC_OBJECT_NEEDS_FENCE)
+               pin_flags |= PIN_MAPPABLE;
+
+       err = i915_vma_pin(arg.vma, 0, 0, pin_flags);
        if (err) {
                i915_request_add(rq);
                goto out_obj;
 
        unsigned long page;
        u32 prng = 0x12345678;
 
+       /* XXX: fsck. needs some more thought... */
+       if (!i915_ggtt_has_aperture(ggtt))
+               return;
+
        for (page = 0; page < size; page += PAGE_SIZE) {
                const dma_addr_t dma = i915->dsm.start + page;
                u32 __iomem *s;
 
        unsigned int *order, n;
        int err;
 
+       if (!i915_ggtt_has_aperture(ggtt))
+               return 0;
+
        obj = i915_gem_object_create_internal(i915, PAGE_SIZE);
        if (IS_ERR(obj))
                return PTR_ERR(obj);