- } else
- ipref = cgp->cg_irotor;
- for (i = 0; i < fs->fs_ipg; i++) {
- ipref++;
- if (ipref >= fs->fs_ipg)
- ipref = 0;
- if (isclr(cgp->cg_iused, ipref)) {
+ }
+ start = cgp->cg_irotor / NBBY;
+ len = howmany(fs->fs_ipg - cgp->cg_irotor, NBBY);
+ loc = skpc(0xff, len, &cgp->cg_iused[start]);
+ if (loc == 0) {
+ printf("cg = %s, irotor = %d, fs = %s\n",
+ cg, cgp->cg_irotor, fs->fs_fsmnt);
+ panic("ialloccg: map corrupted");
+ /* NOTREACHED */
+ }
+ i = start + len - loc;
+ map = cgp->cg_iused[i];
+ ipref = i * NBBY;
+ for (i = 1; i < (1 << NBBY); i <<= 1, ipref++) {
+ if ((map & i) == 0) {