aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristian König <christian.koenig@amd.com>2014-09-04 14:01:54 -0400
committerAlex Deucher <alexander.deucher@amd.com>2014-09-11 10:46:02 -0400
commit298593b609ecbf9e8a99e8a41c8c46acb3528468 (patch)
treed1735a89f8f998c61e624bbc1fbc1306512867b3
parent57d20a43c9b30663bdbacde8294a902edef35a84 (diff)
drm/radeon: allow concurrent buffer reads
Signed-off-by: Christian König <christian.koenig@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
-rw-r--r--drivers/gpu/drm/radeon/radeon_cs.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_cs.c b/drivers/gpu/drm/radeon/radeon_cs.c
index ec4840cb8a07..f662de41ba49 100644
--- a/drivers/gpu/drm/radeon/radeon_cs.c
+++ b/drivers/gpu/drm/radeon/radeon_cs.c
@@ -183,7 +183,7 @@ static int radeon_cs_parser_relocs(struct radeon_cs_parser *p)
183 } 183 }
184 184
185 p->relocs[i].tv.bo = &p->relocs[i].robj->tbo; 185 p->relocs[i].tv.bo = &p->relocs[i].robj->tbo;
186 p->relocs[i].tv.shared = false; 186 p->relocs[i].tv.shared = !r->write_domain;
187 p->relocs[i].handle = r->handle; 187 p->relocs[i].handle = r->handle;
188 188
189 radeon_cs_buckets_add(&buckets, &p->relocs[i].tv.head, 189 radeon_cs_buckets_add(&buckets, &p->relocs[i].tv.head,
@@ -260,7 +260,8 @@ static void radeon_cs_sync_rings(struct radeon_cs_parser *p)
260 continue; 260 continue;
261 261
262 resv = p->relocs[i].robj->tbo.resv; 262 resv = p->relocs[i].robj->tbo.resv;
263 radeon_semaphore_sync_resv(p->ib.semaphore, resv, false); 263 radeon_semaphore_sync_resv(p->ib.semaphore, resv,
264 p->relocs[i].tv.shared);
264 } 265 }
265} 266}
266 267