diff options
author | Jeff Law <law@gcc.gnu.org> | 1998-09-04 19:11:54 -0600 |
---|---|---|
committer | Jeff Law <law@gcc.gnu.org> | 1998-09-04 19:11:54 -0600 |
commit | b79f73df6aed1b1411b1b505bc5dd48e9ed78609 (patch) | |
tree | e2a997b294961a00f5d259edefbef93b8501c089 /libchill/cardps.c | |
parent | 1802393487391d209c472f42c92cc2ba4d34469f (diff) | |
download | gcc-b79f73df6aed1b1411b1b505bc5dd48e9ed78609.tar.gz |
* Chill runtime moved into toplevel libchill.
* Makefile.in Revamped due to move. Add multilib support.
* configure.in: Similarly. Use autoconf.
* powerset.h: Do not depend on BITS_PER_UNIT.
From-SVN: r22238
Diffstat (limited to 'libchill/cardps.c')
-rw-r--r-- | libchill/cardps.c | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/libchill/cardps.c b/libchill/cardps.c new file mode 100644 index 00000000000..261241d78c1 --- /dev/null +++ b/libchill/cardps.c @@ -0,0 +1,99 @@ +/* Implement POWERSET runtime actions for CHILL. + Copyright (C) 1992,1993 Free Software Foundation, Inc. + Author: Wilfried Moser, et al + +This file is part of GNU CC. + +GNU CC is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU CC is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GNU CC; see the file COPYING. If not, write to +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ + +#define __CHILL_LIB__ + +#include "config.h" +#include <stdio.h> +#include "powerset.h" + + +/* + * function __cardpowerset + * + * parameters: + * ps powerset + * bitlength length of powerset + * + * returns: + * long number of set bits + * + * exceptions: + * none + * + * abstract: + * returns the number of set bit's in a powerset + * + */ + +/* bit_count[I] is number of '1' bits in I. */ +static +const unsigned char __four_bit_count[16] = { + 0, 1, 1, 2, + 1, 2, 2, 3, + 1, 2, 2, 3, + 2, 3, 3, 4 }; + +long +__cardpowerset (ps, bitlength) + SET_WORD *ps; + unsigned long bitlength; +{ + unsigned long count = 0; + if (bitlength <= SET_CHAR_SIZE) + { + register SET_CHAR c = *((SET_CHAR *)ps); + /* count 4 bits at a time. */ + while (c > 0) + { + count += __four_bit_count[c & 15]; + c >>= 4; + } + return count; + } + else if (bitlength <= SET_SHORT_SIZE) + { + register SET_SHORT c = *((SET_SHORT *)ps); + /* count 4 bits at a time. */ + while (c > 0) + { + count += __four_bit_count[c & 15]; + c >>= 4; + } + return count; + } + else + { + register SET_WORD *p = ps; + SET_WORD *endp = p + BITS_TO_WORDS(bitlength); + + while (p < endp) + { + register SET_WORD c = *p++; + /* count 4 bits at a time. */ + while (c > 0) + { + count += __four_bit_count[c & 15]; + c >>= 4; + } + } + return (count); + } +} |