summaryrefslogtreecommitdiffstats
path: root/src/gallium/drivers
diff options
context:
space:
mode:
authorDave Airlie <[email protected]>2010-09-03 13:53:39 +1000
committerDave Airlie <[email protected]>2010-09-03 13:53:39 +1000
commit9ef228ee2d74a32e01ac0fcf0776d92d904369f4 (patch)
tree18d0a3023c1b88751586f244a8da1324f2a32e7b /src/gallium/drivers
parentb5fcf8274916afdf29aca5e8db7611687b03abe4 (diff)
r600g: reduce size of r600 context structure to !insane
Its now about 7.8k, and might actually fit in a cache.
Diffstat (limited to 'src/gallium/drivers')
-rw-r--r--src/gallium/drivers/r600/r600_context.c23
-rw-r--r--src/gallium/drivers/r600/r600_context.h9
2 files changed, 29 insertions, 3 deletions
diff --git a/src/gallium/drivers/r600/r600_context.c b/src/gallium/drivers/r600/r600_context.c
index 7a0e5b4049f..9525f15197f 100644
--- a/src/gallium/drivers/r600/r600_context.c
+++ b/src/gallium/drivers/r600/r600_context.c
@@ -53,6 +53,11 @@ static void r600_destroy_context(struct pipe_context *context)
rctx->stencil_ref = r600_context_state_decref(rctx->stencil_ref);
rctx->viewport = r600_context_state_decref(rctx->viewport);
rctx->framebuffer = r600_context_state_decref(rctx->framebuffer);
+
+ free(rctx->ps_constant);
+ free(rctx->vs_constant);
+ free(rctx->vs_resource);
+
radeon_ctx_fini(&rctx->ctx);
FREE(rctx);
}
@@ -354,6 +359,24 @@ struct pipe_context *r600_create_context(struct pipe_screen *screen, void *priv)
r600_init_config(rctx);
+ rctx->vs_constant = (struct radeon_state *)calloc(R600_MAX_CONSTANT, sizeof(struct radeon_state));
+ if (!rctx->vs_constant) {
+ FREE(rctx);
+ return NULL;
+ }
+
+ rctx->ps_constant = (struct radeon_state *)calloc(R600_MAX_CONSTANT, sizeof(struct radeon_state));
+ if (!rctx->ps_constant) {
+ FREE(rctx);
+ return NULL;
+ }
+
+ rctx->vs_resource = (struct radeon_state *)calloc(R600_MAX_RESOURCE, sizeof(struct radeon_state));
+ if (!rctx->vs_resource) {
+ FREE(rctx);
+ return NULL;
+ }
+
radeon_ctx_init(&rctx->ctx, rscreen->rw);
radeon_draw_init(&rctx->draw, rscreen->rw);
return &rctx->context;
diff --git a/src/gallium/drivers/r600/r600_context.h b/src/gallium/drivers/r600/r600_context.h
index 6294f7ad47b..1c32ced7dc3 100644
--- a/src/gallium/drivers/r600/r600_context.h
+++ b/src/gallium/drivers/r600/r600_context.h
@@ -121,6 +121,9 @@ struct r600_context_hw_states {
struct radeon_state cb_cntl;
};
+#define R600_MAX_CONSTANT 256 /* magic */
+#define R600_MAX_RESOURCE 160 /* magic */
+
struct r600_context {
struct pipe_context context;
struct r600_screen *screen;
@@ -130,10 +133,10 @@ struct r600_context {
struct radeon_draw draw;
struct radeon_state config;
/* FIXME get rid of those vs_resource,vs/ps_constant */
- struct radeon_state vs_resource[160];
+ struct radeon_state *vs_resource;
unsigned vs_nresource;
- struct radeon_state vs_constant[256];
- struct radeon_state ps_constant[256];
+ struct radeon_state *vs_constant;
+ struct radeon_state *ps_constant;
/* hw states */
struct r600_context_hw_states hw_states;
/* pipe states */