123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- /* StarPU --- Runtime system for heterogeneous multicore architectures.
- *
- * Copyright (C) 2013 Simon Archipoff
- *
- * StarPU is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1 of the License, or (at
- * your option) any later version.
- *
- * StarPU 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 Lesser General Public License in COPYING.LGPL for more details.
- */
- #ifndef __STARPU_BITMAP_H__
- #define __STARPU_BITMAP_H__
- struct starpu_bitmap * starpu_bitmap_create(void);
- void starpu_bitmap_destroy(struct starpu_bitmap *);
- void starpu_bitmap_set(struct starpu_bitmap *, int);
- void starpu_bitmap_unset(struct starpu_bitmap *, int);
- void starpu_bitmap_unset_all(struct starpu_bitmap *);
- int starpu_bitmap_get(struct starpu_bitmap *, int);
- /* basicaly compute starpu_bitmap_unset_all(a) ; a = b & c; */
- void starpu_bitmap_unset_and(struct starpu_bitmap * a, struct starpu_bitmap * b, struct starpu_bitmap * c);
- /* this is basically compute a |= b;*/
- void starpu_bitmap_or(struct starpu_bitmap * a,
- struct starpu_bitmap * b);
- //return 1 iff e set in b1 AND e set in b2
- int starpu_bitmap_and_get(struct starpu_bitmap * b1,
- struct starpu_bitmap * b2,
- int e);
- int starpu_bitmap_cardinal(struct starpu_bitmap *);
- //return the index of first bit, -1 if none
- int starpu_bitmap_first(struct starpu_bitmap *);
- int starpu_bitmap_last(struct starpu_bitmap *);
- //return the index of bit right after e, -1 if none
- int starpu_bitmap_next(struct starpu_bitmap *, int e);
- #endif
|