aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/i915_gem.c
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2010-03-08 07:35:02 -0500
committerEric Anholt <eric@anholt.net>2010-03-25 14:06:17 -0400
commit23010e43b353c2cdc9725cbedc7e364708039bf7 (patch)
treec0615881eabefb7b26a7f7dba23a5e00ea5a2398 /drivers/gpu/drm/i915/i915_gem.c
parent8d06a1e1e9c69244f08beb7d17146483f9dcd120 (diff)
drm/i915: introduce to_intel_bo helper
This is a purely cosmetic change to make changes in this area easier. And hey, it's not only clearer and typechecked, but actually shorter, too! [anholt: To clarify, this is a change to let us later make drm_i915_gem_object subclass drm_gem_object, instead of having drm_gem_object have a pointer to i915's private data] Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> Acked-by: Dave Airlie <airlied@gmail.com> Signed-off-by: Eric Anholt <eric@anholt.net>
Diffstat (limited to 'drivers/gpu/drm/i915/i915_gem.c')
-rw-r--r--drivers/gpu/drm/i915/i915_gem.c132
1 files changed, 66 insertions, 66 deletions
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
index 933e865a8929..b85727ce308e 100644
--- a/drivers/gpu/drm/i915/i915_gem.c
+++ b/drivers/gpu/drm/i915/i915_gem.c
@@ -162,7 +162,7 @@ fast_shmem_read(struct page **pages,
162static int i915_gem_object_needs_bit17_swizzle(struct drm_gem_object *obj) 162static int i915_gem_object_needs_bit17_swizzle(struct drm_gem_object *obj)
163{ 163{
164 drm_i915_private_t *dev_priv = obj->dev->dev_private; 164 drm_i915_private_t *dev_priv = obj->dev->dev_private;
165 struct drm_i915_gem_object *obj_priv = obj->driver_private; 165 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
166 166
167 return dev_priv->mm.bit_6_swizzle_x == I915_BIT_6_SWIZZLE_9_10_17 && 167 return dev_priv->mm.bit_6_swizzle_x == I915_BIT_6_SWIZZLE_9_10_17 &&
168 obj_priv->tiling_mode != I915_TILING_NONE; 168 obj_priv->tiling_mode != I915_TILING_NONE;
@@ -263,7 +263,7 @@ i915_gem_shmem_pread_fast(struct drm_device *dev, struct drm_gem_object *obj,
263 struct drm_i915_gem_pread *args, 263 struct drm_i915_gem_pread *args,
264 struct drm_file *file_priv) 264 struct drm_file *file_priv)
265{ 265{
266 struct drm_i915_gem_object *obj_priv = obj->driver_private; 266 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
267 ssize_t remain; 267 ssize_t remain;
268 loff_t offset, page_base; 268 loff_t offset, page_base;
269 char __user *user_data; 269 char __user *user_data;
@@ -284,7 +284,7 @@ i915_gem_shmem_pread_fast(struct drm_device *dev, struct drm_gem_object *obj,
284 if (ret != 0) 284 if (ret != 0)
285 goto fail_put_pages; 285 goto fail_put_pages;
286 286
287 obj_priv = obj->driver_private; 287 obj_priv = to_intel_bo(obj);
288 offset = args->offset; 288 offset = args->offset;
289 289
290 while (remain > 0) { 290 while (remain > 0) {
@@ -353,7 +353,7 @@ i915_gem_shmem_pread_slow(struct drm_device *dev, struct drm_gem_object *obj,
353 struct drm_i915_gem_pread *args, 353 struct drm_i915_gem_pread *args,
354 struct drm_file *file_priv) 354 struct drm_file *file_priv)
355{ 355{
356 struct drm_i915_gem_object *obj_priv = obj->driver_private; 356 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
357 struct mm_struct *mm = current->mm; 357 struct mm_struct *mm = current->mm;
358 struct page **user_pages; 358 struct page **user_pages;
359 ssize_t remain; 359 ssize_t remain;
@@ -402,7 +402,7 @@ i915_gem_shmem_pread_slow(struct drm_device *dev, struct drm_gem_object *obj,
402 if (ret != 0) 402 if (ret != 0)
403 goto fail_put_pages; 403 goto fail_put_pages;
404 404
405 obj_priv = obj->driver_private; 405 obj_priv = to_intel_bo(obj);
406 offset = args->offset; 406 offset = args->offset;
407 407
408 while (remain > 0) { 408 while (remain > 0) {
@@ -478,7 +478,7 @@ i915_gem_pread_ioctl(struct drm_device *dev, void *data,
478 obj = drm_gem_object_lookup(dev, file_priv, args->handle); 478 obj = drm_gem_object_lookup(dev, file_priv, args->handle);
479 if (obj == NULL) 479 if (obj == NULL)
480 return -EBADF; 480 return -EBADF;
481 obj_priv = obj->driver_private; 481 obj_priv = to_intel_bo(obj);
482 482
483 /* Bounds check source. 483 /* Bounds check source.
484 * 484 *
@@ -580,7 +580,7 @@ i915_gem_gtt_pwrite_fast(struct drm_device *dev, struct drm_gem_object *obj,
580 struct drm_i915_gem_pwrite *args, 580 struct drm_i915_gem_pwrite *args,
581 struct drm_file *file_priv) 581 struct drm_file *file_priv)
582{ 582{
583 struct drm_i915_gem_object *obj_priv = obj->driver_private; 583 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
584 drm_i915_private_t *dev_priv = dev->dev_private; 584 drm_i915_private_t *dev_priv = dev->dev_private;
585 ssize_t remain; 585 ssize_t remain;
586 loff_t offset, page_base; 586 loff_t offset, page_base;
@@ -604,7 +604,7 @@ i915_gem_gtt_pwrite_fast(struct drm_device *dev, struct drm_gem_object *obj,
604 if (ret) 604 if (ret)
605 goto fail; 605 goto fail;
606 606
607 obj_priv = obj->driver_private; 607 obj_priv = to_intel_bo(obj);
608 offset = obj_priv->gtt_offset + args->offset; 608 offset = obj_priv->gtt_offset + args->offset;
609 609
610 while (remain > 0) { 610 while (remain > 0) {
@@ -654,7 +654,7 @@ i915_gem_gtt_pwrite_slow(struct drm_device *dev, struct drm_gem_object *obj,
654 struct drm_i915_gem_pwrite *args, 654 struct drm_i915_gem_pwrite *args,
655 struct drm_file *file_priv) 655 struct drm_file *file_priv)
656{ 656{
657 struct drm_i915_gem_object *obj_priv = obj->driver_private; 657 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
658 drm_i915_private_t *dev_priv = dev->dev_private; 658 drm_i915_private_t *dev_priv = dev->dev_private;
659 ssize_t remain; 659 ssize_t remain;
660 loff_t gtt_page_base, offset; 660 loff_t gtt_page_base, offset;
@@ -698,7 +698,7 @@ i915_gem_gtt_pwrite_slow(struct drm_device *dev, struct drm_gem_object *obj,
698 if (ret) 698 if (ret)
699 goto out_unpin_object; 699 goto out_unpin_object;
700 700
701 obj_priv = obj->driver_private; 701 obj_priv = to_intel_bo(obj);
702 offset = obj_priv->gtt_offset + args->offset; 702 offset = obj_priv->gtt_offset + args->offset;
703 703
704 while (remain > 0) { 704 while (remain > 0) {
@@ -760,7 +760,7 @@ i915_gem_shmem_pwrite_fast(struct drm_device *dev, struct drm_gem_object *obj,
760 struct drm_i915_gem_pwrite *args, 760 struct drm_i915_gem_pwrite *args,
761 struct drm_file *file_priv) 761 struct drm_file *file_priv)
762{ 762{
763 struct drm_i915_gem_object *obj_priv = obj->driver_private; 763 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
764 ssize_t remain; 764 ssize_t remain;
765 loff_t offset, page_base; 765 loff_t offset, page_base;
766 char __user *user_data; 766 char __user *user_data;
@@ -780,7 +780,7 @@ i915_gem_shmem_pwrite_fast(struct drm_device *dev, struct drm_gem_object *obj,
780 if (ret != 0) 780 if (ret != 0)
781 goto fail_put_pages; 781 goto fail_put_pages;
782 782
783 obj_priv = obj->driver_private; 783 obj_priv = to_intel_bo(obj);
784 offset = args->offset; 784 offset = args->offset;
785 obj_priv->dirty = 1; 785 obj_priv->dirty = 1;
786 786
@@ -828,7 +828,7 @@ i915_gem_shmem_pwrite_slow(struct drm_device *dev, struct drm_gem_object *obj,
828 struct drm_i915_gem_pwrite *args, 828 struct drm_i915_gem_pwrite *args,
829 struct drm_file *file_priv) 829 struct drm_file *file_priv)
830{ 830{
831 struct drm_i915_gem_object *obj_priv = obj->driver_private; 831 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
832 struct mm_struct *mm = current->mm; 832 struct mm_struct *mm = current->mm;
833 struct page **user_pages; 833 struct page **user_pages;
834 ssize_t remain; 834 ssize_t remain;
@@ -876,7 +876,7 @@ i915_gem_shmem_pwrite_slow(struct drm_device *dev, struct drm_gem_object *obj,
876 if (ret != 0) 876 if (ret != 0)
877 goto fail_put_pages; 877 goto fail_put_pages;
878 878
879 obj_priv = obj->driver_private; 879 obj_priv = to_intel_bo(obj);
880 offset = args->offset; 880 offset = args->offset;
881 obj_priv->dirty = 1; 881 obj_priv->dirty = 1;
882 882
@@ -951,7 +951,7 @@ i915_gem_pwrite_ioctl(struct drm_device *dev, void *data,
951 obj = drm_gem_object_lookup(dev, file_priv, args->handle); 951 obj = drm_gem_object_lookup(dev, file_priv, args->handle);
952 if (obj == NULL) 952 if (obj == NULL)
953 return -EBADF; 953 return -EBADF;
954 obj_priv = obj->driver_private; 954 obj_priv = to_intel_bo(obj);
955 955
956 /* Bounds check destination. 956 /* Bounds check destination.
957 * 957 *
@@ -1033,7 +1033,7 @@ i915_gem_set_domain_ioctl(struct drm_device *dev, void *data,
1033 obj = drm_gem_object_lookup(dev, file_priv, args->handle); 1033 obj = drm_gem_object_lookup(dev, file_priv, args->handle);
1034 if (obj == NULL) 1034 if (obj == NULL)
1035 return -EBADF; 1035 return -EBADF;
1036 obj_priv = obj->driver_private; 1036 obj_priv = to_intel_bo(obj);
1037 1037
1038 mutex_lock(&dev->struct_mutex); 1038 mutex_lock(&dev->struct_mutex);
1039 1039
@@ -1095,7 +1095,7 @@ i915_gem_sw_finish_ioctl(struct drm_device *dev, void *data,
1095 DRM_INFO("%s: sw_finish %d (%p %zd)\n", 1095 DRM_INFO("%s: sw_finish %d (%p %zd)\n",
1096 __func__, args->handle, obj, obj->size); 1096 __func__, args->handle, obj, obj->size);
1097#endif 1097#endif
1098 obj_priv = obj->driver_private; 1098 obj_priv = to_intel_bo(obj);
1099 1099
1100 /* Pinned buffers may be scanout, so flush the cache */ 1100 /* Pinned buffers may be scanout, so flush the cache */
1101 if (obj_priv->pin_count) 1101 if (obj_priv->pin_count)
@@ -1166,7 +1166,7 @@ int i915_gem_fault(struct vm_area_struct *vma, struct vm_fault *vmf)
1166 struct drm_gem_object *obj = vma->vm_private_data; 1166 struct drm_gem_object *obj = vma->vm_private_data;
1167 struct drm_device *dev = obj->dev; 1167 struct drm_device *dev = obj->dev;
1168 struct drm_i915_private *dev_priv = dev->dev_private; 1168 struct drm_i915_private *dev_priv = dev->dev_private;
1169 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1169 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1170 pgoff_t page_offset; 1170 pgoff_t page_offset;
1171 unsigned long pfn; 1171 unsigned long pfn;
1172 int ret = 0; 1172 int ret = 0;
@@ -1233,7 +1233,7 @@ i915_gem_create_mmap_offset(struct drm_gem_object *obj)
1233{ 1233{
1234 struct drm_device *dev = obj->dev; 1234 struct drm_device *dev = obj->dev;
1235 struct drm_gem_mm *mm = dev->mm_private; 1235 struct drm_gem_mm *mm = dev->mm_private;
1236 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1236 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1237 struct drm_map_list *list; 1237 struct drm_map_list *list;
1238 struct drm_local_map *map; 1238 struct drm_local_map *map;
1239 int ret = 0; 1239 int ret = 0;
@@ -1304,7 +1304,7 @@ void
1304i915_gem_release_mmap(struct drm_gem_object *obj) 1304i915_gem_release_mmap(struct drm_gem_object *obj)
1305{ 1305{
1306 struct drm_device *dev = obj->dev; 1306 struct drm_device *dev = obj->dev;
1307 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1307 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1308 1308
1309 if (dev->dev_mapping) 1309 if (dev->dev_mapping)
1310 unmap_mapping_range(dev->dev_mapping, 1310 unmap_mapping_range(dev->dev_mapping,
@@ -1315,7 +1315,7 @@ static void
1315i915_gem_free_mmap_offset(struct drm_gem_object *obj) 1315i915_gem_free_mmap_offset(struct drm_gem_object *obj)
1316{ 1316{
1317 struct drm_device *dev = obj->dev; 1317 struct drm_device *dev = obj->dev;
1318 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1318 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1319 struct drm_gem_mm *mm = dev->mm_private; 1319 struct drm_gem_mm *mm = dev->mm_private;
1320 struct drm_map_list *list; 1320 struct drm_map_list *list;
1321 1321
@@ -1346,7 +1346,7 @@ static uint32_t
1346i915_gem_get_gtt_alignment(struct drm_gem_object *obj) 1346i915_gem_get_gtt_alignment(struct drm_gem_object *obj)
1347{ 1347{
1348 struct drm_device *dev = obj->dev; 1348 struct drm_device *dev = obj->dev;
1349 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1349 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1350 int start, i; 1350 int start, i;
1351 1351
1352 /* 1352 /*
@@ -1405,7 +1405,7 @@ i915_gem_mmap_gtt_ioctl(struct drm_device *dev, void *data,
1405 1405
1406 mutex_lock(&dev->struct_mutex); 1406 mutex_lock(&dev->struct_mutex);
1407 1407
1408 obj_priv = obj->driver_private; 1408 obj_priv = to_intel_bo(obj);
1409 1409
1410 if (obj_priv->madv != I915_MADV_WILLNEED) { 1410 if (obj_priv->madv != I915_MADV_WILLNEED) {
1411 DRM_ERROR("Attempting to mmap a purgeable buffer\n"); 1411 DRM_ERROR("Attempting to mmap a purgeable buffer\n");
@@ -1449,7 +1449,7 @@ i915_gem_mmap_gtt_ioctl(struct drm_device *dev, void *data,
1449void 1449void
1450i915_gem_object_put_pages(struct drm_gem_object *obj) 1450i915_gem_object_put_pages(struct drm_gem_object *obj)
1451{ 1451{
1452 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1452 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1453 int page_count = obj->size / PAGE_SIZE; 1453 int page_count = obj->size / PAGE_SIZE;
1454 int i; 1454 int i;
1455 1455
@@ -1485,7 +1485,7 @@ i915_gem_object_move_to_active(struct drm_gem_object *obj, uint32_t seqno)
1485{ 1485{
1486 struct drm_device *dev = obj->dev; 1486 struct drm_device *dev = obj->dev;
1487 drm_i915_private_t *dev_priv = dev->dev_private; 1487 drm_i915_private_t *dev_priv = dev->dev_private;
1488 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1488 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1489 1489
1490 /* Add a reference if we're newly entering the active list. */ 1490 /* Add a reference if we're newly entering the active list. */
1491 if (!obj_priv->active) { 1491 if (!obj_priv->active) {
@@ -1505,7 +1505,7 @@ i915_gem_object_move_to_flushing(struct drm_gem_object *obj)
1505{ 1505{
1506 struct drm_device *dev = obj->dev; 1506 struct drm_device *dev = obj->dev;
1507 drm_i915_private_t *dev_priv = dev->dev_private; 1507 drm_i915_private_t *dev_priv = dev->dev_private;
1508 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1508 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1509 1509
1510 BUG_ON(!obj_priv->active); 1510 BUG_ON(!obj_priv->active);
1511 list_move_tail(&obj_priv->list, &dev_priv->mm.flushing_list); 1511 list_move_tail(&obj_priv->list, &dev_priv->mm.flushing_list);
@@ -1516,7 +1516,7 @@ i915_gem_object_move_to_flushing(struct drm_gem_object *obj)
1516static void 1516static void
1517i915_gem_object_truncate(struct drm_gem_object *obj) 1517i915_gem_object_truncate(struct drm_gem_object *obj)
1518{ 1518{
1519 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1519 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1520 struct inode *inode; 1520 struct inode *inode;
1521 1521
1522 inode = obj->filp->f_path.dentry->d_inode; 1522 inode = obj->filp->f_path.dentry->d_inode;
@@ -1537,7 +1537,7 @@ i915_gem_object_move_to_inactive(struct drm_gem_object *obj)
1537{ 1537{
1538 struct drm_device *dev = obj->dev; 1538 struct drm_device *dev = obj->dev;
1539 drm_i915_private_t *dev_priv = dev->dev_private; 1539 drm_i915_private_t *dev_priv = dev->dev_private;
1540 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1540 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1541 1541
1542 i915_verify_inactive(dev, __FILE__, __LINE__); 1542 i915_verify_inactive(dev, __FILE__, __LINE__);
1543 if (obj_priv->pin_count != 0) 1543 if (obj_priv->pin_count != 0)
@@ -1964,7 +1964,7 @@ static int
1964i915_gem_object_wait_rendering(struct drm_gem_object *obj) 1964i915_gem_object_wait_rendering(struct drm_gem_object *obj)
1965{ 1965{
1966 struct drm_device *dev = obj->dev; 1966 struct drm_device *dev = obj->dev;
1967 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1967 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
1968 int ret; 1968 int ret;
1969 1969
1970 /* This function only exists to support waiting for existing rendering, 1970 /* This function only exists to support waiting for existing rendering,
@@ -1996,7 +1996,7 @@ i915_gem_object_unbind(struct drm_gem_object *obj)
1996{ 1996{
1997 struct drm_device *dev = obj->dev; 1997 struct drm_device *dev = obj->dev;
1998 drm_i915_private_t *dev_priv = dev->dev_private; 1998 drm_i915_private_t *dev_priv = dev->dev_private;
1999 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1999 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2000 int ret = 0; 2000 int ret = 0;
2001 2001
2002#if WATCH_BUF 2002#if WATCH_BUF
@@ -2172,7 +2172,7 @@ i915_gem_evict_something(struct drm_device *dev, int min_size)
2172#if WATCH_LRU 2172#if WATCH_LRU
2173 DRM_INFO("%s: evicting %p\n", __func__, obj); 2173 DRM_INFO("%s: evicting %p\n", __func__, obj);
2174#endif 2174#endif
2175 obj_priv = obj->driver_private; 2175 obj_priv = to_intel_bo(obj);
2176 BUG_ON(obj_priv->pin_count != 0); 2176 BUG_ON(obj_priv->pin_count != 0);
2177 BUG_ON(obj_priv->active); 2177 BUG_ON(obj_priv->active);
2178 2178
@@ -2243,7 +2243,7 @@ int
2243i915_gem_object_get_pages(struct drm_gem_object *obj, 2243i915_gem_object_get_pages(struct drm_gem_object *obj,
2244 gfp_t gfpmask) 2244 gfp_t gfpmask)
2245{ 2245{
2246 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2246 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2247 int page_count, i; 2247 int page_count, i;
2248 struct address_space *mapping; 2248 struct address_space *mapping;
2249 struct inode *inode; 2249 struct inode *inode;
@@ -2296,7 +2296,7 @@ static void sandybridge_write_fence_reg(struct drm_i915_fence_reg *reg)
2296 struct drm_gem_object *obj = reg->obj; 2296 struct drm_gem_object *obj = reg->obj;
2297 struct drm_device *dev = obj->dev; 2297 struct drm_device *dev = obj->dev;
2298 drm_i915_private_t *dev_priv = dev->dev_private; 2298 drm_i915_private_t *dev_priv = dev->dev_private;
2299 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2299 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2300 int regnum = obj_priv->fence_reg; 2300 int regnum = obj_priv->fence_reg;
2301 uint64_t val; 2301 uint64_t val;
2302 2302
@@ -2318,7 +2318,7 @@ static void i965_write_fence_reg(struct drm_i915_fence_reg *reg)
2318 struct drm_gem_object *obj = reg->obj; 2318 struct drm_gem_object *obj = reg->obj;
2319 struct drm_device *dev = obj->dev; 2319 struct drm_device *dev = obj->dev;
2320 drm_i915_private_t *dev_priv = dev->dev_private; 2320 drm_i915_private_t *dev_priv = dev->dev_private;
2321 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2321 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2322 int regnum = obj_priv->fence_reg; 2322 int regnum = obj_priv->fence_reg;
2323 uint64_t val; 2323 uint64_t val;
2324 2324
@@ -2338,7 +2338,7 @@ static void i915_write_fence_reg(struct drm_i915_fence_reg *reg)
2338 struct drm_gem_object *obj = reg->obj; 2338 struct drm_gem_object *obj = reg->obj;
2339 struct drm_device *dev = obj->dev; 2339 struct drm_device *dev = obj->dev;
2340 drm_i915_private_t *dev_priv = dev->dev_private; 2340 drm_i915_private_t *dev_priv = dev->dev_private;
2341 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2341 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2342 int regnum = obj_priv->fence_reg; 2342 int regnum = obj_priv->fence_reg;
2343 int tile_width; 2343 int tile_width;
2344 uint32_t fence_reg, val; 2344 uint32_t fence_reg, val;
@@ -2380,7 +2380,7 @@ static void i830_write_fence_reg(struct drm_i915_fence_reg *reg)
2380 struct drm_gem_object *obj = reg->obj; 2380 struct drm_gem_object *obj = reg->obj;
2381 struct drm_device *dev = obj->dev; 2381 struct drm_device *dev = obj->dev;
2382 drm_i915_private_t *dev_priv = dev->dev_private; 2382 drm_i915_private_t *dev_priv = dev->dev_private;
2383 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2383 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2384 int regnum = obj_priv->fence_reg; 2384 int regnum = obj_priv->fence_reg;
2385 uint32_t val; 2385 uint32_t val;
2386 uint32_t pitch_val; 2386 uint32_t pitch_val;
@@ -2424,7 +2424,7 @@ static int i915_find_fence_reg(struct drm_device *dev)
2424 if (!reg->obj) 2424 if (!reg->obj)
2425 return i; 2425 return i;
2426 2426
2427 obj_priv = reg->obj->driver_private; 2427 obj_priv = to_intel_bo(reg->obj);
2428 if (!obj_priv->pin_count) 2428 if (!obj_priv->pin_count)
2429 avail++; 2429 avail++;
2430 } 2430 }
@@ -2479,7 +2479,7 @@ i915_gem_object_get_fence_reg(struct drm_gem_object *obj)
2479{ 2479{
2480 struct drm_device *dev = obj->dev; 2480 struct drm_device *dev = obj->dev;
2481 struct drm_i915_private *dev_priv = dev->dev_private; 2481 struct drm_i915_private *dev_priv = dev->dev_private;
2482 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2482 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2483 struct drm_i915_fence_reg *reg = NULL; 2483 struct drm_i915_fence_reg *reg = NULL;
2484 int ret; 2484 int ret;
2485 2485
@@ -2546,7 +2546,7 @@ i915_gem_clear_fence_reg(struct drm_gem_object *obj)
2546{ 2546{
2547 struct drm_device *dev = obj->dev; 2547 struct drm_device *dev = obj->dev;
2548 drm_i915_private_t *dev_priv = dev->dev_private; 2548 drm_i915_private_t *dev_priv = dev->dev_private;
2549 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2549 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2550 2550
2551 if (IS_GEN6(dev)) { 2551 if (IS_GEN6(dev)) {
2552 I915_WRITE64(FENCE_REG_SANDYBRIDGE_0 + 2552 I915_WRITE64(FENCE_REG_SANDYBRIDGE_0 +
@@ -2582,7 +2582,7 @@ int
2582i915_gem_object_put_fence_reg(struct drm_gem_object *obj) 2582i915_gem_object_put_fence_reg(struct drm_gem_object *obj)
2583{ 2583{
2584 struct drm_device *dev = obj->dev; 2584 struct drm_device *dev = obj->dev;
2585 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2585 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2586 2586
2587 if (obj_priv->fence_reg == I915_FENCE_REG_NONE) 2587 if (obj_priv->fence_reg == I915_FENCE_REG_NONE)
2588 return 0; 2588 return 0;
@@ -2620,7 +2620,7 @@ i915_gem_object_bind_to_gtt(struct drm_gem_object *obj, unsigned alignment)
2620{ 2620{
2621 struct drm_device *dev = obj->dev; 2621 struct drm_device *dev = obj->dev;
2622 drm_i915_private_t *dev_priv = dev->dev_private; 2622 drm_i915_private_t *dev_priv = dev->dev_private;
2623 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2623 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2624 struct drm_mm_node *free_space; 2624 struct drm_mm_node *free_space;
2625 gfp_t gfpmask = __GFP_NORETRY | __GFP_NOWARN; 2625 gfp_t gfpmask = __GFP_NORETRY | __GFP_NOWARN;
2626 int ret; 2626 int ret;
@@ -2727,7 +2727,7 @@ i915_gem_object_bind_to_gtt(struct drm_gem_object *obj, unsigned alignment)
2727void 2727void
2728i915_gem_clflush_object(struct drm_gem_object *obj) 2728i915_gem_clflush_object(struct drm_gem_object *obj)
2729{ 2729{
2730 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2730 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2731 2731
2732 /* If we don't have a page list set up, then we're not pinned 2732 /* If we don't have a page list set up, then we're not pinned
2733 * to GPU, and we can ignore the cache flush because it'll happen 2733 * to GPU, and we can ignore the cache flush because it'll happen
@@ -2828,7 +2828,7 @@ i915_gem_object_flush_write_domain(struct drm_gem_object *obj)
2828int 2828int
2829i915_gem_object_set_to_gtt_domain(struct drm_gem_object *obj, int write) 2829i915_gem_object_set_to_gtt_domain(struct drm_gem_object *obj, int write)
2830{ 2830{
2831 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2831 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2832 uint32_t old_write_domain, old_read_domains; 2832 uint32_t old_write_domain, old_read_domains;
2833 int ret; 2833 int ret;
2834 2834
@@ -2878,7 +2878,7 @@ int
2878i915_gem_object_set_to_display_plane(struct drm_gem_object *obj) 2878i915_gem_object_set_to_display_plane(struct drm_gem_object *obj)
2879{ 2879{
2880 struct drm_device *dev = obj->dev; 2880 struct drm_device *dev = obj->dev;
2881 struct drm_i915_gem_object *obj_priv = obj->driver_private; 2881 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
2882 uint32_t old_write_domain, old_read_domains; 2882 uint32_t old_write_domain, old_read_domains;
2883 int ret; 2883 int ret;
2884 2884
@@ -3091,7 +3091,7 @@ static void
3091i915_gem_object_set_to_gpu_domain(struct drm_gem_object *obj) 3091i915_gem_object_set_to_gpu_domain(struct drm_gem_object *obj)
3092{ 3092{
3093 struct drm_device *dev = obj->dev; 3093 struct drm_device *dev = obj->dev;
3094 struct drm_i915_gem_object *obj_priv = obj->driver_private; 3094 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
3095 uint32_t invalidate_domains = 0; 3095 uint32_t invalidate_domains = 0;
3096 uint32_t flush_domains = 0; 3096 uint32_t flush_domains = 0;
3097 uint32_t old_read_domains; 3097 uint32_t old_read_domains;
@@ -3176,7 +3176,7 @@ i915_gem_object_set_to_gpu_domain(struct drm_gem_object *obj)
3176static void 3176static void
3177i915_gem_object_set_to_full_cpu_read_domain(struct drm_gem_object *obj) 3177i915_gem_object_set_to_full_cpu_read_domain(struct drm_gem_object *obj)
3178{ 3178{
3179 struct drm_i915_gem_object *obj_priv = obj->driver_private; 3179 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
3180 3180
3181 if (!obj_priv->page_cpu_valid) 3181 if (!obj_priv->page_cpu_valid)
3182 return; 3182 return;
@@ -3216,7 +3216,7 @@ static int
3216i915_gem_object_set_cpu_read_domain_range(struct drm_gem_object *obj, 3216i915_gem_object_set_cpu_read_domain_range(struct drm_gem_object *obj,
3217 uint64_t offset, uint64_t size) 3217 uint64_t offset, uint64_t size)
3218{ 3218{
3219 struct drm_i915_gem_object *obj_priv = obj->driver_private; 3219 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
3220 uint32_t old_read_domains; 3220 uint32_t old_read_domains;
3221 int i, ret; 3221 int i, ret;
3222 3222
@@ -3285,7 +3285,7 @@ i915_gem_object_pin_and_relocate(struct drm_gem_object *obj,
3285{ 3285{
3286 struct drm_device *dev = obj->dev; 3286 struct drm_device *dev = obj->dev;
3287 drm_i915_private_t *dev_priv = dev->dev_private; 3287 drm_i915_private_t *dev_priv = dev->dev_private;
3288 struct drm_i915_gem_object *obj_priv = obj->driver_private; 3288 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
3289 int i, ret; 3289 int i, ret;
3290 void __iomem *reloc_page; 3290 void __iomem *reloc_page;
3291 bool need_fence; 3291 bool need_fence;
@@ -3336,7 +3336,7 @@ i915_gem_object_pin_and_relocate(struct drm_gem_object *obj,
3336 i915_gem_object_unpin(obj); 3336 i915_gem_object_unpin(obj);
3337 return -EBADF; 3337 return -EBADF;
3338 } 3338 }
3339 target_obj_priv = target_obj->driver_private; 3339 target_obj_priv = to_intel_bo(target_obj);
3340 3340
3341#if WATCH_RELOC 3341#if WATCH_RELOC
3342 DRM_INFO("%s: obj %p offset %08x target %d " 3342 DRM_INFO("%s: obj %p offset %08x target %d "
@@ -3688,7 +3688,7 @@ i915_gem_wait_for_pending_flip(struct drm_device *dev,
3688 prepare_to_wait(&dev_priv->pending_flip_queue, 3688 prepare_to_wait(&dev_priv->pending_flip_queue,
3689 &wait, TASK_INTERRUPTIBLE); 3689 &wait, TASK_INTERRUPTIBLE);
3690 for (i = 0; i < count; i++) { 3690 for (i = 0; i < count; i++) {
3691 obj_priv = object_list[i]->driver_private; 3691 obj_priv = to_intel_bo(object_list[i]);
3692 if (atomic_read(&obj_priv->pending_flip) > 0) 3692 if (atomic_read(&obj_priv->pending_flip) > 0)
3693 break; 3693 break;
3694 } 3694 }
@@ -3797,7 +3797,7 @@ i915_gem_do_execbuffer(struct drm_device *dev, void *data,
3797 goto err; 3797 goto err;
3798 } 3798 }
3799 3799
3800 obj_priv = object_list[i]->driver_private; 3800 obj_priv = to_intel_bo(object_list[i]);
3801 if (obj_priv->in_execbuffer) { 3801 if (obj_priv->in_execbuffer) {
3802 DRM_ERROR("Object %p appears more than once in object list\n", 3802 DRM_ERROR("Object %p appears more than once in object list\n",
3803 object_list[i]); 3803 object_list[i]);
@@ -3923,7 +3923,7 @@ i915_gem_do_execbuffer(struct drm_device *dev, void *data,
3923 3923
3924 for (i = 0; i < args->buffer_count; i++) { 3924 for (i = 0; i < args->buffer_count; i++) {
3925 struct drm_gem_object *obj = object_list[i]; 3925 struct drm_gem_object *obj = object_list[i];
3926 struct drm_i915_gem_object *obj_priv = obj->driver_private; 3926 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
3927 uint32_t old_write_domain = obj->write_domain; 3927 uint32_t old_write_domain = obj->write_domain;
3928 3928
3929 obj->write_domain = obj->pending_write_domain; 3929 obj->write_domain = obj->pending_write_domain;
@@ -3998,7 +3998,7 @@ err:
3998 3998
3999 for (i = 0; i < args->buffer_count; i++) { 3999 for (i = 0; i < args->buffer_count; i++) {
4000 if (object_list[i]) { 4000 if (object_list[i]) {
4001 obj_priv = object_list[i]->driver_private; 4001 obj_priv = to_intel_bo(object_list[i]);
4002 obj_priv->in_execbuffer = false; 4002 obj_priv->in_execbuffer = false;
4003 } 4003 }
4004 drm_gem_object_unreference(object_list[i]); 4004 drm_gem_object_unreference(object_list[i]);
@@ -4176,7 +4176,7 @@ int
4176i915_gem_object_pin(struct drm_gem_object *obj, uint32_t alignment) 4176i915_gem_object_pin(struct drm_gem_object *obj, uint32_t alignment)
4177{ 4177{
4178 struct drm_device *dev = obj->dev; 4178 struct drm_device *dev = obj->dev;
4179 struct drm_i915_gem_object *obj_priv = obj->driver_private; 4179 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
4180 int ret; 4180 int ret;
4181 4181
4182 i915_verify_inactive(dev, __FILE__, __LINE__); 4182 i915_verify_inactive(dev, __FILE__, __LINE__);
@@ -4209,7 +4209,7 @@ i915_gem_object_unpin(struct drm_gem_object *obj)
4209{ 4209{
4210 struct drm_device *dev = obj->dev; 4210 struct drm_device *dev = obj->dev;
4211 drm_i915_private_t *dev_priv = dev->dev_private; 4211 drm_i915_private_t *dev_priv = dev->dev_private;
4212 struct drm_i915_gem_object *obj_priv = obj->driver_private; 4212 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
4213 4213
4214 i915_verify_inactive(dev, __FILE__, __LINE__); 4214 i915_verify_inactive(dev, __FILE__, __LINE__);
4215 obj_priv->pin_count--; 4215 obj_priv->pin_count--;
@@ -4249,7 +4249,7 @@ i915_gem_pin_ioctl(struct drm_device *dev, void *data,
4249 mutex_unlock(&dev->struct_mutex); 4249 mutex_unlock(&dev->struct_mutex);
4250 return -EBADF; 4250 return -EBADF;
4251 } 4251 }
4252 obj_priv = obj->driver_private; 4252 obj_priv = to_intel_bo(obj);
4253 4253
4254 if (obj_priv->madv != I915_MADV_WILLNEED) { 4254 if (obj_priv->madv != I915_MADV_WILLNEED) {
4255 DRM_ERROR("Attempting to pin a purgeable buffer\n"); 4255 DRM_ERROR("Attempting to pin a purgeable buffer\n");
@@ -4306,7 +4306,7 @@ i915_gem_unpin_ioctl(struct drm_device *dev, void *data,
4306 return -EBADF; 4306 return -EBADF;
4307 } 4307 }
4308 4308
4309 obj_priv = obj->driver_private; 4309 obj_priv = to_intel_bo(obj);
4310 if (obj_priv->pin_filp != file_priv) { 4310 if (obj_priv->pin_filp != file_priv) {
4311 DRM_ERROR("Not pinned by caller in i915_gem_pin_ioctl(): %d\n", 4311 DRM_ERROR("Not pinned by caller in i915_gem_pin_ioctl(): %d\n",
4312 args->handle); 4312 args->handle);
@@ -4348,7 +4348,7 @@ i915_gem_busy_ioctl(struct drm_device *dev, void *data,
4348 */ 4348 */
4349 i915_gem_retire_requests(dev); 4349 i915_gem_retire_requests(dev);
4350 4350
4351 obj_priv = obj->driver_private; 4351 obj_priv = to_intel_bo(obj);
4352 /* Don't count being on the flushing list against the object being 4352 /* Don't count being on the flushing list against the object being
4353 * done. Otherwise, a buffer left on the flushing list but not getting 4353 * done. Otherwise, a buffer left on the flushing list but not getting
4354 * flushed (because nobody's flushing that domain) won't ever return 4354 * flushed (because nobody's flushing that domain) won't ever return
@@ -4394,7 +4394,7 @@ i915_gem_madvise_ioctl(struct drm_device *dev, void *data,
4394 } 4394 }
4395 4395
4396 mutex_lock(&dev->struct_mutex); 4396 mutex_lock(&dev->struct_mutex);
4397 obj_priv = obj->driver_private; 4397 obj_priv = to_intel_bo(obj);
4398 4398
4399 if (obj_priv->pin_count) { 4399 if (obj_priv->pin_count) {
4400 drm_gem_object_unreference(obj); 4400 drm_gem_object_unreference(obj);
@@ -4455,7 +4455,7 @@ int i915_gem_init_object(struct drm_gem_object *obj)
4455void i915_gem_free_object(struct drm_gem_object *obj) 4455void i915_gem_free_object(struct drm_gem_object *obj)
4456{ 4456{
4457 struct drm_device *dev = obj->dev; 4457 struct drm_device *dev = obj->dev;
4458 struct drm_i915_gem_object *obj_priv = obj->driver_private; 4458 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
4459 4459
4460 trace_i915_gem_object_destroy(obj); 4460 trace_i915_gem_object_destroy(obj);
4461 4461
@@ -4564,7 +4564,7 @@ i915_gem_init_hws(struct drm_device *dev)
4564 DRM_ERROR("Failed to allocate status page\n"); 4564 DRM_ERROR("Failed to allocate status page\n");
4565 return -ENOMEM; 4565 return -ENOMEM;
4566 } 4566 }
4567 obj_priv = obj->driver_private; 4567 obj_priv = to_intel_bo(obj);
4568 obj_priv->agp_type = AGP_USER_CACHED_MEMORY; 4568 obj_priv->agp_type = AGP_USER_CACHED_MEMORY;
4569 4569
4570 ret = i915_gem_object_pin(obj, 4096); 4570 ret = i915_gem_object_pin(obj, 4096);
@@ -4608,7 +4608,7 @@ i915_gem_cleanup_hws(struct drm_device *dev)
4608 return; 4608 return;
4609 4609
4610 obj = dev_priv->hws_obj; 4610 obj = dev_priv->hws_obj;
4611 obj_priv = obj->driver_private; 4611 obj_priv = to_intel_bo(obj);
4612 4612
4613 kunmap(obj_priv->pages[0]); 4613 kunmap(obj_priv->pages[0]);
4614 i915_gem_object_unpin(obj); 4614 i915_gem_object_unpin(obj);
@@ -4642,7 +4642,7 @@ i915_gem_init_ringbuffer(struct drm_device *dev)
4642 i915_gem_cleanup_hws(dev); 4642 i915_gem_cleanup_hws(dev);
4643 return -ENOMEM; 4643 return -ENOMEM;
4644 } 4644 }
4645 obj_priv = obj->driver_private; 4645 obj_priv = to_intel_bo(obj);
4646 4646
4647 ret = i915_gem_object_pin(obj, 4096); 4647 ret = i915_gem_object_pin(obj, 4096);
4648 if (ret != 0) { 4648 if (ret != 0) {
@@ -4935,7 +4935,7 @@ void i915_gem_detach_phys_object(struct drm_device *dev,
4935 int ret; 4935 int ret;
4936 int page_count; 4936 int page_count;
4937 4937
4938 obj_priv = obj->driver_private; 4938 obj_priv = to_intel_bo(obj);
4939 if (!obj_priv->phys_obj) 4939 if (!obj_priv->phys_obj)
4940 return; 4940 return;
4941 4941
@@ -4974,7 +4974,7 @@ i915_gem_attach_phys_object(struct drm_device *dev,
4974 if (id > I915_MAX_PHYS_OBJECT) 4974 if (id > I915_MAX_PHYS_OBJECT)
4975 return -EINVAL; 4975 return -EINVAL;
4976 4976
4977 obj_priv = obj->driver_private; 4977 obj_priv = to_intel_bo(obj);
4978 4978
4979 if (obj_priv->phys_obj) { 4979 if (obj_priv->phys_obj) {
4980 if (obj_priv->phys_obj->id == id) 4980 if (obj_priv->phys_obj->id == id)
@@ -5025,7 +5025,7 @@ i915_gem_phys_pwrite(struct drm_device *dev, struct drm_gem_object *obj,
5025 struct drm_i915_gem_pwrite *args, 5025 struct drm_i915_gem_pwrite *args,
5026 struct drm_file *file_priv) 5026 struct drm_file *file_priv)
5027{ 5027{
5028 struct drm_i915_gem_object *obj_priv = obj->driver_private; 5028 struct drm_i915_gem_object *obj_priv = to_intel_bo(obj);
5029 void *obj_addr; 5029 void *obj_addr;
5030 int ret; 5030 int ret;
5031 char __user *user_data; 5031 char __user *user_data;