virbitmap.h 4.6 KB
Newer Older
1
/*
2
 * virbitmap.h: Simple bitmap operations
3
 *
4
 * Copyright (C) 2012-2013 Red Hat, Inc.
5 6 7 8 9 10 11 12 13 14 15 16 17
 * Copyright (C) 2010 Novell, Inc.
 *
 * This library 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.
 *
 * This library 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 for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
18
 * License along with this library.  If not, see
O
Osier Yang 已提交
19
 * <http://www.gnu.org/licenses/>.
20 21 22 23 24 25 26
 *
 * Author: Jim Fehlig <jfehlig@novell.com>
 */

#ifndef __BITMAP_H__
# define __BITMAP_H__

E
Eric Blake 已提交
27
# include "internal.h"
28

E
Eric Blake 已提交
29
# include <sys/types.h>
30 31 32 33 34 35 36 37


typedef struct _virBitmap virBitmap;
typedef virBitmap *virBitmapPtr;

/*
 * Allocate a bitmap capable of containing @size bits.
 */
38
virBitmapPtr virBitmapNewQuiet(size_t size) ATTRIBUTE_RETURN_CHECK;
39
virBitmapPtr virBitmapNew(size_t size) ATTRIBUTE_RETURN_CHECK;
40
virBitmapPtr virBitmapNewEmpty(void) ATTRIBUTE_RETURN_CHECK;
41 42 43 44 45 46

/*
 * Free previously allocated bitmap
 */
void virBitmapFree(virBitmapPtr bitmap);

D
Daniel P. Berrange 已提交
47 48 49 50 51 52
/*
 * Copy all bits from @src to @dst. The bitmap sizes
 * must be the same
 */
int virBitmapCopy(virBitmapPtr dst, virBitmapPtr src);

53 54 55 56 57 58
/*
 * Set bit position @b in @bitmap
 */
int virBitmapSetBit(virBitmapPtr bitmap, size_t b)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

59 60 61 62
int virBitmapSetBitExpand(virBitmapPtr bitmap, size_t b)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;


63 64 65 66 67 68
/*
 * Clear bit position @b in @bitmap
 */
int virBitmapClearBit(virBitmapPtr bitmap, size_t b)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

69 70 71
int virBitmapClearBitExpand(virBitmapPtr bitmap, size_t b)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

J
Ján Tomko 已提交
72 73 74 75 76
/*
 * Get bit @b in @bitmap. Returns false if b is out of range.
 */
bool virBitmapIsBitSet(virBitmapPtr bitmap, size_t b)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;
77 78 79 80 81 82
/*
 * Get setting of bit position @b in @bitmap and store in @result
 */
int virBitmapGetBit(virBitmapPtr bitmap, size_t b, bool *result)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(3) ATTRIBUTE_RETURN_CHECK;

83 84 85 86
virBitmapPtr
virBitmapNewString(const char *string)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

87
char *virBitmapToString(virBitmapPtr bitmap, bool prefix, bool trim)
88 89
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

90
char *virBitmapFormat(virBitmapPtr bitmap);
H
Hu Tao 已提交
91 92 93 94

int virBitmapParse(const char *str,
                   virBitmapPtr *bitmap,
                   size_t bitmapSize)
95
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
J
Ján Tomko 已提交
96 97 98 99 100
int
virBitmapParseSeparator(const char *str,
                        char terminator,
                        virBitmapPtr *bitmap,
                        size_t bitmapSize);
101
virBitmapPtr
102
virBitmapParseUnlimited(const char *str);
H
Hu Tao 已提交
103 104 105

virBitmapPtr virBitmapNewCopy(virBitmapPtr src) ATTRIBUTE_NONNULL(1);

106
virBitmapPtr virBitmapNewData(const void *data, int len) ATTRIBUTE_NONNULL(1);
H
Hu Tao 已提交
107 108

int virBitmapToData(virBitmapPtr bitmap, unsigned char **data, int *dataLen)
109 110 111
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

void virBitmapToDataBuf(virBitmapPtr bitmap, unsigned char *data, size_t len)
H
Hu Tao 已提交
112 113
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

114
bool virBitmapEqual(virBitmapPtr b1, virBitmapPtr b2);
H
Hu Tao 已提交
115 116 117 118 119 120 121 122 123 124 125 126 127

size_t virBitmapSize(virBitmapPtr bitmap)
    ATTRIBUTE_NONNULL(1);

void virBitmapSetAll(virBitmapPtr bitmap)
    ATTRIBUTE_NONNULL(1);

void virBitmapClearAll(virBitmapPtr bitmap)
    ATTRIBUTE_NONNULL(1);

bool virBitmapIsAllSet(virBitmapPtr bitmap)
    ATTRIBUTE_NONNULL(1);

128 129 130
bool virBitmapIsAllClear(virBitmapPtr bitmap)
    ATTRIBUTE_NONNULL(1);

E
Eric Blake 已提交
131 132 133
ssize_t virBitmapNextSetBit(virBitmapPtr bitmap, ssize_t pos)
    ATTRIBUTE_NONNULL(1);

134 135 136
ssize_t virBitmapLastSetBit(virBitmapPtr bitmap)
    ATTRIBUTE_NONNULL(1);

137 138 139
ssize_t virBitmapNextClearBit(virBitmapPtr bitmap, ssize_t pos)
    ATTRIBUTE_NONNULL(1);

E
Eric Blake 已提交
140
size_t virBitmapCountBits(virBitmapPtr bitmap)
H
Hu Tao 已提交
141 142
    ATTRIBUTE_NONNULL(1);

143 144
char *virBitmapDataFormat(const void *data,
                          int len)
J
Ján Tomko 已提交
145
    ATTRIBUTE_NONNULL(1);
146 147 148
bool virBitmapOverlaps(virBitmapPtr b1,
                       virBitmapPtr b2)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
J
Ján Tomko 已提交
149

150
void virBitmapIntersect(virBitmapPtr a, virBitmapPtr b)
151 152
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

153 154 155
void virBitmapSubtract(virBitmapPtr a, virBitmapPtr b)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

156 157
void virBitmapShrink(virBitmapPtr map, size_t b);

158
#endif