diff mbox

drm/radeon: track global bo name and always return the same

Message ID 1354042922-26610-1-git-send-email-j.glisse@gmail.com (mailing list archive)
State New, archived
Headers show

Commit Message

Jerome Glisse Nov. 27, 2012, 7:02 p.m. UTC
From: Jerome Glisse <jglisse@redhat.com>

To avoid kernel rejecting cs if we return different global name
for same bo keep track of global name and always return the same.
Seems to fix issue with suspend/resume failing and repeatly printing
following message :
[drm:radeon_cs_ioctl] *ERROR* Failed to parse relocation -35!

There might still be way for a rogue program to trigger this issue.

Signed-off-by: Jerome Glisse <jglisse@redhat.com>
---
 radeon/radeon_bo_gem.c | 16 +++++++++++-----
 1 file changed, 11 insertions(+), 5 deletions(-)

Comments

Christian König Nov. 28, 2012, 10:19 a.m. UTC | #1
On 27.11.2012 20:02, j.glisse@gmail.com wrote:
> From: Jerome Glisse <jglisse@redhat.com>
>
> To avoid kernel rejecting cs if we return different global name
> for same bo keep track of global name and always return the same.
> Seems to fix issue with suspend/resume failing and repeatly printing
> following message :
> [drm:radeon_cs_ioctl] *ERROR* Failed to parse relocation -35!
>
> There might still be way for a rogue program to trigger this issue.
>
> Signed-off-by: Jerome Glisse <jglisse@redhat.com>

Reviewed-by: Christian König <christian.koenig@amd.com>

> ---
>   radeon/radeon_bo_gem.c | 16 +++++++++++-----
>   1 file changed, 11 insertions(+), 5 deletions(-)
>
> diff --git a/radeon/radeon_bo_gem.c b/radeon/radeon_bo_gem.c
> index 265f177..fca0aaf 100644
> --- a/radeon/radeon_bo_gem.c
> +++ b/radeon/radeon_bo_gem.c
> @@ -47,11 +47,11 @@
>   #include "radeon_bo_gem.h"
>   #include <fcntl.h>
>   struct radeon_bo_gem {
> -    struct radeon_bo_int base;
> -    uint32_t            name;
> -    int                 map_count;
> -    atomic_t            reloc_in_cs;
> -    void *priv_ptr;
> +    struct radeon_bo_int    base;
> +    uint32_t                name;
> +    int                     map_count;
> +    atomic_t                reloc_in_cs;
> +    void                    *priv_ptr;
>   };
>   
>   struct bo_manager_gem {
> @@ -320,15 +320,21 @@ void *radeon_gem_get_reloc_in_cs(struct radeon_bo *bo)
>   
>   int radeon_gem_get_kernel_name(struct radeon_bo *bo, uint32_t *name)
>   {
> +    struct radeon_bo_gem *bo_gem = (struct radeon_bo_gem*)bo;
>       struct radeon_bo_int *boi = (struct radeon_bo_int *)bo;
>       struct drm_gem_flink flink;
>       int r;
>   
> +    if (bo_gem->name) {
> +        *name = bo_gem->name;
> +        return 0;
> +    }
>       flink.handle = bo->handle;
>       r = drmIoctl(boi->bom->fd, DRM_IOCTL_GEM_FLINK, &flink);
>       if (r) {
>           return r;
>       }
> +    bo_gem->name = flink.name;
>       *name = flink.name;
>       return 0;
>   }
diff mbox

Patch

diff --git a/radeon/radeon_bo_gem.c b/radeon/radeon_bo_gem.c
index 265f177..fca0aaf 100644
--- a/radeon/radeon_bo_gem.c
+++ b/radeon/radeon_bo_gem.c
@@ -47,11 +47,11 @@ 
 #include "radeon_bo_gem.h"
 #include <fcntl.h>
 struct radeon_bo_gem {
-    struct radeon_bo_int base;
-    uint32_t            name;
-    int                 map_count;
-    atomic_t            reloc_in_cs;
-    void *priv_ptr;
+    struct radeon_bo_int    base;
+    uint32_t                name;
+    int                     map_count;
+    atomic_t                reloc_in_cs;
+    void                    *priv_ptr;
 };
 
 struct bo_manager_gem {
@@ -320,15 +320,21 @@  void *radeon_gem_get_reloc_in_cs(struct radeon_bo *bo)
 
 int radeon_gem_get_kernel_name(struct radeon_bo *bo, uint32_t *name)
 {
+    struct radeon_bo_gem *bo_gem = (struct radeon_bo_gem*)bo;
     struct radeon_bo_int *boi = (struct radeon_bo_int *)bo;
     struct drm_gem_flink flink;
     int r;
 
+    if (bo_gem->name) {
+        *name = bo_gem->name;
+        return 0;
+    }
     flink.handle = bo->handle;
     r = drmIoctl(boi->bom->fd, DRM_IOCTL_GEM_FLINK, &flink);
     if (r) {
         return r;
     }
+    bo_gem->name = flink.name;
     *name = flink.name;
     return 0;
 }