Lines Matching +full:lock +full:- +full:offset
1 // SPDX-License-Identifier: GPL-2.0
19 * bit_map_string_get - find and set a bit string in bit map.
24 * Returns offset in the map or -1 if out of space.
30 int offset, count; /* siamese twins */ in bit_map_string_get() local
35 if (t->num_colors) { in bit_map_string_get()
38 align = t->num_colors; in bit_map_string_get()
44 align1 = align - 1; in bit_map_string_get()
47 if (align < 0 || align >= t->size) in bit_map_string_get()
49 if (len <= 0 || len > t->size) in bit_map_string_get()
53 spin_lock(&t->lock); in bit_map_string_get()
54 if (len < t->last_size) in bit_map_string_get()
55 offset = t->first_free; in bit_map_string_get()
57 offset = t->last_off & ~align1; in bit_map_string_get()
60 off_new = find_next_zero_bit(t->map, t->size, offset); in bit_map_string_get()
62 count += off_new - offset; in bit_map_string_get()
63 offset = off_new; in bit_map_string_get()
64 if (offset >= t->size) in bit_map_string_get()
65 offset = 0; in bit_map_string_get()
66 if (count + len > t->size) { in bit_map_string_get()
67 spin_unlock(&t->lock); in bit_map_string_get()
70 t->size, t->used, offset, len, align, count); in bit_map_string_get()
71 return -1; in bit_map_string_get()
74 if (offset + len > t->size) { in bit_map_string_get()
75 count += t->size - offset; in bit_map_string_get()
76 offset = 0; in bit_map_string_get()
81 while (test_bit(offset + i, t->map) == 0) { in bit_map_string_get()
84 bitmap_set(t->map, offset, len); in bit_map_string_get()
85 if (offset == t->first_free) in bit_map_string_get()
86 t->first_free = find_next_zero_bit in bit_map_string_get()
87 (t->map, t->size, in bit_map_string_get()
88 t->first_free + len); in bit_map_string_get()
89 if ((t->last_off = offset + len) >= t->size) in bit_map_string_get()
90 t->last_off = 0; in bit_map_string_get()
91 t->used += len; in bit_map_string_get()
92 t->last_size = len; in bit_map_string_get()
93 spin_unlock(&t->lock); in bit_map_string_get()
94 return offset; in bit_map_string_get()
98 if ((offset += i + 1) >= t->size) in bit_map_string_get()
99 offset = 0; in bit_map_string_get()
103 void bit_map_clear(struct bit_map *t, int offset, int len) in bit_map_clear() argument
107 if (t->used < len) in bit_map_clear()
109 spin_lock(&t->lock); in bit_map_clear()
111 if (test_bit(offset + i, t->map) == 0) in bit_map_clear()
113 __clear_bit(offset + i, t->map); in bit_map_clear()
115 if (offset < t->first_free) in bit_map_clear()
116 t->first_free = offset; in bit_map_clear()
117 t->used -= len; in bit_map_clear()
118 spin_unlock(&t->lock); in bit_map_clear()
125 spin_lock_init(&t->lock); in bit_map_init()
126 t->map = map; in bit_map_init()
127 t->size = size; in bit_map_init()