Subversion Repositories planix.SVN

Rev

Rev 2 | Blame | Compare with Previous | Last modification | View Log | RSS feed

#include        "cc.h"

Bits
bor(Bits a, Bits b)
{
        Bits c;
        int i;

        for(i=0; i<BITS; i++)
                c.b[i] = a.b[i] | b.b[i];
        return c;
}

Bits
band(Bits a, Bits b)
{
        Bits c;
        int i;

        for(i=0; i<BITS; i++)
                c.b[i] = a.b[i] & b.b[i];
        return c;
}

/*
Bits
bnot(Bits a)
{
        Bits c;
        int i;

        for(i=0; i<BITS; i++)
                c.b[i] = ~a.b[i];
        return c;
}
*/

int
bany(Bits *a)
{
        int i;

        for(i=0; i<BITS; i++)
                if(a->b[i])
                        return 1;
        return 0;
}

int
beq(Bits a, Bits b)
{
        int i;

        for(i=0; i<BITS; i++)
                if(a.b[i] != b.b[i])
                        return 0;
        return 1;
}

int
bnum(Bits a)
{
        int i;
        long b;

        for(i=0; i<BITS; i++)
                if(b = a.b[i])
                        return 32*i + bitno(b);
        diag(Z, "bad in bnum");
        return 0;
}

Bits
blsh(uint n)
{
        Bits c;

        c = zbits;
        c.b[n/32] = 1L << (n%32);
        return c;
}

int
bset(Bits a, uint n)
{
        if(a.b[n/32] & (1L << (n%32)))
                return 1;
        return 0;
}