| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 | /* 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 b2int 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 noneint starpu_bitmap_first(struct starpu_bitmap *);int starpu_bitmap_last(struct starpu_bitmap *);//return the index of bit right after e, -1 if noneint starpu_bitmap_next(struct starpu_bitmap *, int e);int starpu_bitmap_has_next(struct starpu_bitmap * b, int e);#endif
 |