Skip to content

Commit 18b39fb

Browse files
gurchetansinghkraxel
authored andcommitted
drm/virtio: add virtio_gpu_is_shmem helper
The plan is use have both shmem and virtual "vram" running side-by-side in virtio-gpu. It looks like we'll eventually use struct drm_gem_object as a base class, and we'll need to convert to shmem and vram objects on the fly. As a first step, add a virtio_gpu_is_shmem helper. Thanks to kraxel for suggesting this approach on Gitlab. Suggested-by: Gerd Hoffman <[email protected]> Signed-off-by: Gurchetan Singh <[email protected]> Link: http://patchwork.freedesktop.org/patch/msgid/[email protected] Signed-off-by: Gerd Hoffmann <[email protected]>
1 parent 068a8fe commit 18b39fb

File tree

2 files changed

+10
-2
lines changed

2 files changed

+10
-2
lines changed

drivers/gpu/drm/virtio/virtgpu_drv.h

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -365,6 +365,9 @@ int virtio_gpu_object_create(struct virtio_gpu_device *vgdev,
365365
struct virtio_gpu_object_params *params,
366366
struct virtio_gpu_object **bo_ptr,
367367
struct virtio_gpu_fence *fence);
368+
369+
bool virtio_gpu_is_shmem(struct drm_gem_object *obj);
370+
368371
/* virtgpu_prime.c */
369372
struct drm_gem_object *virtgpu_gem_prime_import_sg_table(
370373
struct drm_device *dev, struct dma_buf_attachment *attach,

drivers/gpu/drm/virtio/virtgpu_object.c

Lines changed: 7 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -95,7 +95,7 @@ static void virtio_gpu_free_object(struct drm_gem_object *obj)
9595
virtio_gpu_cleanup_object(bo);
9696
}
9797

98-
static const struct drm_gem_object_funcs virtio_gpu_gem_funcs = {
98+
static const struct drm_gem_object_funcs virtio_gpu_shmem_funcs = {
9999
.free = virtio_gpu_free_object,
100100
.open = virtio_gpu_gem_object_open,
101101
.close = virtio_gpu_gem_object_close,
@@ -109,6 +109,11 @@ static const struct drm_gem_object_funcs virtio_gpu_gem_funcs = {
109109
.mmap = drm_gem_shmem_mmap,
110110
};
111111

112+
bool virtio_gpu_is_shmem(struct drm_gem_object *obj)
113+
{
114+
return obj->funcs == &virtio_gpu_shmem_funcs;
115+
}
116+
112117
struct drm_gem_object *virtio_gpu_create_object(struct drm_device *dev,
113118
size_t size)
114119
{
@@ -118,7 +123,7 @@ struct drm_gem_object *virtio_gpu_create_object(struct drm_device *dev,
118123
if (!bo)
119124
return NULL;
120125

121-
bo->base.base.funcs = &virtio_gpu_gem_funcs;
126+
bo->base.base.funcs = &virtio_gpu_shmem_funcs;
122127
return &bo->base.base;
123128
}
124129

0 commit comments

Comments
 (0)