From 19498be935328e284c7f0e456fc04cca8d465d4c Mon Sep 17 00:00:00 2001 From: Marek Olšák Date: Wed, 2 Jun 2010 06:07:53 +0200 Subject: r300g: blit directly to/from GTT when transfering textures --- src/gallium/drivers/r300/r300_texture.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'src/gallium/drivers') diff --git a/src/gallium/drivers/r300/r300_texture.c b/src/gallium/drivers/r300/r300_texture.c index 8572334f91..33aa250886 100644 --- a/src/gallium/drivers/r300/r300_texture.c +++ b/src/gallium/drivers/r300/r300_texture.c @@ -918,6 +918,7 @@ struct pipe_resource* r300_texture_create(struct pipe_screen* screen, struct r300_texture* tex = CALLOC_STRUCT(r300_texture); struct r300_screen* rscreen = r300_screen(screen); struct r300_winsys_screen *rws = (struct r300_winsys_screen *)screen->winsys; + enum r300_buffer_domain domain; if (!tex) { return NULL; @@ -959,8 +960,10 @@ struct pipe_resource* r300_texture_create(struct pipe_screen* screen, base->width0, base->height0, base->depth0, base->last_level, util_format_short_name(base->format)); - tex->buffer = rws->buffer_create(rws, 2048, base->bind, R300_DOMAIN_VRAM, - tex->size); + domain = base->flags & R300_RESOURCE_FLAG_TRANSFER ? R300_DOMAIN_GTT : + R300_DOMAIN_VRAM; + + tex->buffer = rws->buffer_create(rws, 2048, base->bind, domain, tex->size); rws->buffer_set_tiling(rws, tex->buffer, tex->pitch[0] * util_format_get_blocksize(tex->b.b.format), -- cgit v1.2.3