Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 196463
b: refs/heads/master
c: 1d39704
h: refs/heads/master
i:
  196461: 46b7a3a
  196459: 486ad45
  196455: 0fb3c99
  196447: 586184c
v: v3
  • Loading branch information
Daniel Vetter authored and Dave Airlie committed Apr 20, 2010
1 parent d91ab73 commit 738a7aa
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 11 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 153549b8b63d71a9c5d8cbde887097b995c32bd6
refs/heads/master: 1d397043bcc2c8cdccb584a8ef73131f28f18e4c
39 changes: 29 additions & 10 deletions trunk/drivers/gpu/drm/drm_gem.c
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,31 @@ drm_gem_destroy(struct drm_device *dev)
dev->mm_private = NULL;
}

/**
* Initialize an already allocate GEM object of the specified size with
* shmfs backing store.
*/
int drm_gem_object_init(struct drm_device *dev,
struct drm_gem_object *obj, size_t size)
{
BUG_ON((size & (PAGE_SIZE - 1)) != 0);

obj->dev = dev;
obj->filp = shmem_file_setup("drm mm object", size, VM_NORESERVE);
if (IS_ERR(obj->filp))
return -ENOMEM;

kref_init(&obj->refcount);
kref_init(&obj->handlecount);
obj->size = size;

atomic_inc(&dev->object_count);
atomic_add(obj->size, &dev->object_memory);

return 0;
}
EXPORT_SYMBOL(drm_gem_object_init);

/**
* Allocate a GEM object of the specified size with shmfs backing store
*/
Expand All @@ -131,28 +156,22 @@ drm_gem_object_alloc(struct drm_device *dev, size_t size)
{
struct drm_gem_object *obj;

BUG_ON((size & (PAGE_SIZE - 1)) != 0);

obj = kzalloc(sizeof(*obj), GFP_KERNEL);
if (!obj)
goto free;

obj->dev = dev;
obj->filp = shmem_file_setup("drm mm object", size, VM_NORESERVE);
if (IS_ERR(obj->filp))
if (drm_gem_object_init(dev, obj, size) != 0)
goto free;

kref_init(&obj->refcount);
kref_init(&obj->handlecount);
obj->size = size;
if (dev->driver->gem_init_object != NULL &&
dev->driver->gem_init_object(obj) != 0) {
goto fput;
}
atomic_inc(&dev->object_count);
atomic_add(obj->size, &dev->object_memory);
return obj;
fput:
/* Object_init mangles the global counters - readjust them. */
atomic_dec(&dev->object_count);
atomic_sub(obj->size, &dev->object_memory);
fput(obj->filp);
free:
kfree(obj);
Expand Down
2 changes: 2 additions & 0 deletions trunk/include/drm/drmP.h
Original file line number Diff line number Diff line change
Expand Up @@ -1432,6 +1432,8 @@ void drm_gem_object_free(struct kref *kref);
void drm_gem_object_free_unlocked(struct kref *kref);
struct drm_gem_object *drm_gem_object_alloc(struct drm_device *dev,
size_t size);
int drm_gem_object_init(struct drm_device *dev,
struct drm_gem_object *obj, size_t size);
void drm_gem_object_handle_free(struct kref *kref);
void drm_gem_vm_open(struct vm_area_struct *vma);
void drm_gem_vm_close(struct vm_area_struct *vma);
Expand Down

0 comments on commit 738a7aa

Please sign in to comment.