drm_printf(printer, "man size:%llu\n", man->size);
 }
 
+static bool xe_ttm_vram_mgr_intersects(struct ttm_resource_manager *man,
+                                      struct ttm_resource *res,
+                                      const struct ttm_place *place,
+                                      size_t size)
+{
+       struct xe_ttm_vram_mgr *mgr = to_xe_ttm_vram_mgr(man);
+       struct xe_ttm_vram_mgr_resource *vres =
+               to_xe_ttm_vram_mgr_resource(res);
+       struct drm_buddy *mm = &mgr->mm;
+       struct drm_buddy_block *block;
+
+       if (!place->fpfn && !place->lpfn)
+               return true;
+
+       if (!place->fpfn && place->lpfn == mgr->visible_size >> PAGE_SHIFT)
+               return vres->used_visible_size > 0;
+
+       list_for_each_entry(block, &vres->blocks, link) {
+               unsigned long fpfn =
+                       drm_buddy_block_offset(block) >> PAGE_SHIFT;
+               unsigned long lpfn = fpfn +
+                       (drm_buddy_block_size(mm, block) >> PAGE_SHIFT);
+
+               if (place->fpfn < lpfn && place->lpfn > fpfn)
+                       return true;
+       }
+
+       return false;
+}
+
+static bool xe_ttm_vram_mgr_compatible(struct ttm_resource_manager *man,
+                                      struct ttm_resource *res,
+                                      const struct ttm_place *place,
+                                      size_t size)
+{
+       struct xe_ttm_vram_mgr *mgr = to_xe_ttm_vram_mgr(man);
+       struct xe_ttm_vram_mgr_resource *vres =
+               to_xe_ttm_vram_mgr_resource(res);
+       struct drm_buddy *mm = &mgr->mm;
+       struct drm_buddy_block *block;
+
+       if (!place->fpfn && !place->lpfn)
+               return true;
+
+       if (!place->fpfn && place->lpfn == mgr->visible_size >> PAGE_SHIFT)
+               return vres->used_visible_size == size;
+
+       list_for_each_entry(block, &vres->blocks, link) {
+               unsigned long fpfn =
+                       drm_buddy_block_offset(block) >> PAGE_SHIFT;
+               unsigned long lpfn = fpfn +
+                       (drm_buddy_block_size(mm, block) >> PAGE_SHIFT);
+
+               if (fpfn < place->fpfn || lpfn > place->lpfn)
+                       return false;
+       }
+
+       return true;
+}
+
 static const struct ttm_resource_manager_func xe_ttm_vram_mgr_func = {
        .alloc  = xe_ttm_vram_mgr_new,
        .free   = xe_ttm_vram_mgr_del,
+       .intersects = xe_ttm_vram_mgr_intersects,
+       .compatible = xe_ttm_vram_mgr_compatible,
        .debug  = xe_ttm_vram_mgr_debug
 };