* [PATCH] drm/radeon: track global bo name and always return the same
@ 2012-11-27 19:02 j.glisse
2012-11-28 10:19 ` Christian König
0 siblings, 1 reply; 2+ messages in thread
From: j.glisse @ 2012-11-27 19:02 UTC (permalink / raw)
To: dri-devel; +Cc: Jerome Glisse
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(-)
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;
}
--
1.7.11.7
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH] drm/radeon: track global bo name and always return the same
2012-11-27 19:02 [PATCH] drm/radeon: track global bo name and always return the same j.glisse
@ 2012-11-28 10:19 ` Christian König
0 siblings, 0 replies; 2+ messages in thread
From: Christian König @ 2012-11-28 10:19 UTC (permalink / raw)
To: j.glisse; +Cc: Jerome Glisse, dri-devel
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;
> }
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2012-11-28 10:19 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2012-11-27 19:02 [PATCH] drm/radeon: track global bo name and always return the same j.glisse
2012-11-28 10:19 ` Christian König
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).