void set(unsigned index, unsigned val);
- sel_chan find_free_bit(unsigned start);
+ sel_chan find_free_bit();
sel_chan find_free_chans(unsigned mask);
sel_chan find_free_array(unsigned size, unsigned mask);
}
// free register for ra means the bit is set
-sel_chan regbits::find_free_bit(unsigned start) {
- unsigned elt = start >> bt_index_shift;
- unsigned bit = start & bt_index_mask;
-
- unsigned end = start < MAX_GPR - num_temps ? MAX_GPR - num_temps : MAX_GPR;
+sel_chan regbits::find_free_bit() {
+ unsigned elt = 0;
+ unsigned bit = 0;
- while (elt < end && !dta[elt]) {
+ while (elt < size && !dta[elt])
++elt;
- bit = 0;
- }
- if (elt >= end)
+ if (elt >= size)
return 0;
- // FIXME this seems broken when not starting from 0
+ bit = __builtin_ctz(dta[elt]) + (elt << bt_index_shift);
+
+ assert(bit < MAX_GPR - num_temps);
- bit += __builtin_ctz(dta[elt]);
- return ((elt << bt_index_shift) | bit) + 1;
+ return bit + 1;
}
// find free gpr component to use as indirectly addressable array
unsigned mask = 1 << v->pin_gpr.chan();
c = rb.find_free_chans(mask) + v->pin_gpr.chan();
} else {
- c = rb.find_free_bit(0);
+ c = rb.find_free_bit();
}
assert(c && c.sel() < 128 - ctx.alu_temp_gprs && "color failed");