aboutsummaryrefslogtreecommitdiffhomepage
path: root/ir
diff options
context:
space:
mode:
authorlemon <lsof@mailbox.org>2025-12-16 18:33:59 +0100
committerlemon <lsof@mailbox.org>2025-12-16 18:46:08 +0100
commitb3762f81b1a276f06bace301d56c9e8f6538058d (patch)
tree5fd64ad4973b0b0e18c993c527740b57d589d9fc /ir
parenta00214e6e569e87f82bb7bcce9df7b5365884ba1 (diff)
bitset: better implementation of bsiter() and stuff
Also changed the type to size_t for portability
Diffstat (limited to 'ir')
-rw-r--r--ir/optmem.c2
-rw-r--r--ir/regalloc.c2
2 files changed, 2 insertions, 2 deletions
diff --git a/ir/optmem.c b/ir/optmem.c
index 35544b2..f9ad245 100644
--- a/ir/optmem.c
+++ b/ir/optmem.c
@@ -228,7 +228,7 @@ mem2reg(struct function *fn)
FREQUIRE(FNUSE);
- if (fn->nblk <= 64 * countof(bsbuf[0])) {
+ if (fn->nblk <= BSNBIT * countof(bsbuf[0])) {
sb.sealed = bsbuf[0];
sb.marked = bsbuf[1];
memset(bsbuf[0], 0, BSSIZE(fn->nblk) * sizeof *bsbuf[0]);
diff --git a/ir/regalloc.c b/ir/regalloc.c
index 29d9f88..691793e 100644
--- a/ir/regalloc.c
+++ b/ir/regalloc.c
@@ -194,7 +194,7 @@ allocstk(struct rega *ra)
for (int i = 0; i < BSSIZE(MAXSPILL); ++i) {
if (ra->freestk[i].u != 0) {
- s = i*64 + lowestsetbit(ra->freestk[i].u);
+ s = i*BSNBIT + lowestsetbit(ra->freestk[i].u);
break;
}
}