diff options
author | Tom Stellard <[email protected]> | 2013-10-16 13:43:08 -0400 |
---|---|---|
committer | Tom Stellard <[email protected]> | 2013-11-11 17:21:34 -0500 |
commit | a859131003fc79094cf99c92cc6a11a0f0c659f7 (patch) | |
tree | d87d8471c58ad46f603f2d2ebdac770914f6e74f | |
parent | 88c8f1972976c506e8fb048100ed11fef1ca938b (diff) |
radeonsi/compute: Add Sea Islands support
-rw-r--r-- | src/gallium/drivers/radeonsi/radeonsi_compute.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/src/gallium/drivers/radeonsi/radeonsi_compute.c b/src/gallium/drivers/radeonsi/radeonsi_compute.c index 265dbd7ab59..49caa2c6a87 100644 --- a/src/gallium/drivers/radeonsi/radeonsi_compute.c +++ b/src/gallium/drivers/radeonsi/radeonsi_compute.c @@ -161,9 +161,18 @@ static void radeonsi_launch_grid( si_pm4_add_bo(pm4, buffer, RADEON_USAGE_READWRITE); } - /* XXX: This should be: - * (number of compute units) * 4 * (waves per simd) - 1 */ - si_pm4_set_reg(pm4, R_00B82C_COMPUTE_MAX_WAVE_ID, 0x190 /* Default value */); + /* This register has been moved to R_00CD20_COMPUTE_MAX_WAVE_ID + * and is now per pipe, so it should be handled in the + * kernel if we want to use something other than the default value, + * which is now 0x22f. + */ + if (rctx->b.chip_class <= SI) { + /* XXX: This should be: + * (number of compute units) * 4 * (waves per simd) - 1 */ + + si_pm4_set_reg(pm4, R_00B82C_COMPUTE_MAX_WAVE_ID, + 0x190 /* Default value */); + } shader_va = r600_resource_va(ctx->screen, (void *)shader->bo); si_pm4_add_bo(pm4, shader->bo, RADEON_USAGE_READ); |