diff options
author | Christoph Bumiller <e0425955@student.tuwien.ac.at> | 2011-03-31 16:36:31 +0200 |
---|---|---|
committer | Christoph Bumiller <e0425955@student.tuwien.ac.at> | 2011-03-31 16:51:32 +0200 |
commit | c3526585b79f6865bfedd15a7336027597555ec7 (patch) | |
tree | af7163eaaae0af552beae79c6ca66f21ea5b6366 | |
parent | 3f625689acd570e4f14cc2ebaa43a425d13954ff (diff) | |
download | external_mesa3d-c3526585b79f6865bfedd15a7336027597555ec7.zip external_mesa3d-c3526585b79f6865bfedd15a7336027597555ec7.tar.gz external_mesa3d-c3526585b79f6865bfedd15a7336027597555ec7.tar.bz2 |
nv50: fix for GPR allocation granularity being 16 bit
-rw-r--r-- | src/gallium/drivers/nv50/nv50_pc_regalloc.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/src/gallium/drivers/nv50/nv50_pc_regalloc.c b/src/gallium/drivers/nv50/nv50_pc_regalloc.c index 657df2c..df3ac54 100644 --- a/src/gallium/drivers/nv50/nv50_pc_regalloc.c +++ b/src/gallium/drivers/nv50/nv50_pc_regalloc.c @@ -971,6 +971,9 @@ pass_allocate_constrained_values(struct nv_pc_pass *ctx) continue; } + /* Compute registers available for this "vector" of consecutive registers. + * Each value (component) has its own independent live interval. + */ for (c = 0; c < vsize; ++c) { nv50_ctor_register_set(ctx->pc, ®s[c]); @@ -978,10 +981,13 @@ pass_allocate_constrained_values(struct nv_pc_pass *ctx) if (val->reg.id >= 0 && livei_have_overlap(val, defs[c])) reg_occupy(®s[c], val); } - mask = 0x11111111; + /* Only 32 bit GPRs will be allocated here, but register set + * granularity for GPRs is 16 bit. + */ + mask = 0x03030303; if (vsize == 2) /* granularity is 2 and not 4 */ - mask |= 0x11111111 << 2; - mask_register_set(®s[c], 0, mask << c); + mask |= 0x03030303 << 4; + mask_register_set(®s[c], 0, mask << (c * 2)); if (defs[c]->livei) insert_ordered_tail(®vals, defs[c]); |