xref: /openbmc/linux/fs/ufs/balloc.c (revision ca55b2fef3a9373fcfc30f82fd26bc7fccbda732)
1 /*
2  *  linux/fs/ufs/balloc.c
3  *
4  * Copyright (C) 1998
5  * Daniel Pirkl <daniel.pirkl@email.cz>
6  * Charles University, Faculty of Mathematics and Physics
7  *
8  * UFS2 write support Evgeniy Dushistov <dushistov@mail.ru>, 2007
9  */
10 
11 #include <linux/fs.h>
12 #include <linux/stat.h>
13 #include <linux/time.h>
14 #include <linux/string.h>
15 #include <linux/buffer_head.h>
16 #include <linux/capability.h>
17 #include <linux/bitops.h>
18 #include <asm/byteorder.h>
19 
20 #include "ufs_fs.h"
21 #include "ufs.h"
22 #include "swab.h"
23 #include "util.h"
24 
25 #define INVBLOCK ((u64)-1L)
26 
27 static u64 ufs_add_fragments(struct inode *, u64, unsigned, unsigned);
28 static u64 ufs_alloc_fragments(struct inode *, unsigned, u64, unsigned, int *);
29 static u64 ufs_alloccg_block(struct inode *, struct ufs_cg_private_info *, u64, int *);
30 static u64 ufs_bitmap_search (struct super_block *, struct ufs_cg_private_info *, u64, unsigned);
31 static unsigned char ufs_fragtable_8fpb[], ufs_fragtable_other[];
32 static void ufs_clusteracct(struct super_block *, struct ufs_cg_private_info *, unsigned, int);
33 
34 /*
35  * Free 'count' fragments from fragment number 'fragment'
36  */
37 void ufs_free_fragments(struct inode *inode, u64 fragment, unsigned count)
38 {
39 	struct super_block * sb;
40 	struct ufs_sb_private_info * uspi;
41 	struct ufs_cg_private_info * ucpi;
42 	struct ufs_cylinder_group * ucg;
43 	unsigned cgno, bit, end_bit, bbase, blkmap, i;
44 	u64 blkno;
45 
46 	sb = inode->i_sb;
47 	uspi = UFS_SB(sb)->s_uspi;
48 
49 	UFSD("ENTER, fragment %llu, count %u\n",
50 	     (unsigned long long)fragment, count);
51 
52 	if (ufs_fragnum(fragment) + count > uspi->s_fpg)
53 		ufs_error (sb, "ufs_free_fragments", "internal error");
54 
55 	mutex_lock(&UFS_SB(sb)->s_lock);
56 
57 	cgno = ufs_dtog(uspi, fragment);
58 	bit = ufs_dtogd(uspi, fragment);
59 	if (cgno >= uspi->s_ncg) {
60 		ufs_panic (sb, "ufs_free_fragments", "freeing blocks are outside device");
61 		goto failed;
62 	}
63 
64 	ucpi = ufs_load_cylinder (sb, cgno);
65 	if (!ucpi)
66 		goto failed;
67 	ucg = ubh_get_ucg (UCPI_UBH(ucpi));
68 	if (!ufs_cg_chkmagic(sb, ucg)) {
69 		ufs_panic (sb, "ufs_free_fragments", "internal error, bad magic number on cg %u", cgno);
70 		goto failed;
71 	}
72 
73 	end_bit = bit + count;
74 	bbase = ufs_blknum (bit);
75 	blkmap = ubh_blkmap (UCPI_UBH(ucpi), ucpi->c_freeoff, bbase);
76 	ufs_fragacct (sb, blkmap, ucg->cg_frsum, -1);
77 	for (i = bit; i < end_bit; i++) {
78 		if (ubh_isclr (UCPI_UBH(ucpi), ucpi->c_freeoff, i))
79 			ubh_setbit (UCPI_UBH(ucpi), ucpi->c_freeoff, i);
80 		else
81 			ufs_error (sb, "ufs_free_fragments",
82 				   "bit already cleared for fragment %u", i);
83 	}
84 
85 	fs32_add(sb, &ucg->cg_cs.cs_nffree, count);
86 	uspi->cs_total.cs_nffree += count;
87 	fs32_add(sb, &UFS_SB(sb)->fs_cs(cgno).cs_nffree, count);
88 	blkmap = ubh_blkmap (UCPI_UBH(ucpi), ucpi->c_freeoff, bbase);
89 	ufs_fragacct(sb, blkmap, ucg->cg_frsum, 1);
90 
91 	/*
92 	 * Trying to reassemble free fragments into block
93 	 */
94 	blkno = ufs_fragstoblks (bbase);
95 	if (ubh_isblockset(UCPI_UBH(ucpi), ucpi->c_freeoff, blkno)) {
96 		fs32_sub(sb, &ucg->cg_cs.cs_nffree, uspi->s_fpb);
97 		uspi->cs_total.cs_nffree -= uspi->s_fpb;
98 		fs32_sub(sb, &UFS_SB(sb)->fs_cs(cgno).cs_nffree, uspi->s_fpb);
99 		if ((UFS_SB(sb)->s_flags & UFS_CG_MASK) == UFS_CG_44BSD)
100 			ufs_clusteracct (sb, ucpi, blkno, 1);
101 		fs32_add(sb, &ucg->cg_cs.cs_nbfree, 1);
102 		uspi->cs_total.cs_nbfree++;
103 		fs32_add(sb, &UFS_SB(sb)->fs_cs(cgno).cs_nbfree, 1);
104 		if (uspi->fs_magic != UFS2_MAGIC) {
105 			unsigned cylno = ufs_cbtocylno (bbase);
106 
107 			fs16_add(sb, &ubh_cg_blks(ucpi, cylno,
108 						  ufs_cbtorpos(bbase)), 1);
109 			fs32_add(sb, &ubh_cg_blktot(ucpi, cylno), 1);
110 		}
111 	}
112 
113 	ubh_mark_buffer_dirty (USPI_UBH(uspi));
114 	ubh_mark_buffer_dirty (UCPI_UBH(ucpi));
115 	if (sb->s_flags & MS_SYNCHRONOUS)
116 		ubh_sync_block(UCPI_UBH(ucpi));
117 	ufs_mark_sb_dirty(sb);
118 
119 	mutex_unlock(&UFS_SB(sb)->s_lock);
120 	UFSD("EXIT\n");
121 	return;
122 
123 failed:
124 	mutex_unlock(&UFS_SB(sb)->s_lock);
125 	UFSD("EXIT (FAILED)\n");
126 	return;
127 }
128 
129 /*
130  * Free 'count' fragments from fragment number 'fragment' (free whole blocks)
131  */
132 void ufs_free_blocks(struct inode *inode, u64 fragment, unsigned count)
133 {
134 	struct super_block * sb;
135 	struct ufs_sb_private_info * uspi;
136 	struct ufs_cg_private_info * ucpi;
137 	struct ufs_cylinder_group * ucg;
138 	unsigned overflow, cgno, bit, end_bit, i;
139 	u64 blkno;
140 
141 	sb = inode->i_sb;
142 	uspi = UFS_SB(sb)->s_uspi;
143 
144 	UFSD("ENTER, fragment %llu, count %u\n",
145 	     (unsigned long long)fragment, count);
146 
147 	if ((fragment & uspi->s_fpbmask) || (count & uspi->s_fpbmask)) {
148 		ufs_error (sb, "ufs_free_blocks", "internal error, "
149 			   "fragment %llu, count %u\n",
150 			   (unsigned long long)fragment, count);
151 		goto failed;
152 	}
153 
154 	mutex_lock(&UFS_SB(sb)->s_lock);
155 
156 do_more:
157 	overflow = 0;
158 	cgno = ufs_dtog(uspi, fragment);
159 	bit = ufs_dtogd(uspi, fragment);
160 	if (cgno >= uspi->s_ncg) {
161 		ufs_panic (sb, "ufs_free_blocks", "freeing blocks are outside device");
162 		goto failed_unlock;
163 	}
164 	end_bit = bit + count;
165 	if (end_bit > uspi->s_fpg) {
166 		overflow = bit + count - uspi->s_fpg;
167 		count -= overflow;
168 		end_bit -= overflow;
169 	}
170 
171 	ucpi = ufs_load_cylinder (sb, cgno);
172 	if (!ucpi)
173 		goto failed_unlock;
174 	ucg = ubh_get_ucg (UCPI_UBH(ucpi));
175 	if (!ufs_cg_chkmagic(sb, ucg)) {
176 		ufs_panic (sb, "ufs_free_blocks", "internal error, bad magic number on cg %u", cgno);
177 		goto failed_unlock;
178 	}
179 
180 	for (i = bit; i < end_bit; i += uspi->s_fpb) {
181 		blkno = ufs_fragstoblks(i);
182 		if (ubh_isblockset(UCPI_UBH(ucpi), ucpi->c_freeoff, blkno)) {
183 			ufs_error(sb, "ufs_free_blocks", "freeing free fragment");
184 		}
185 		ubh_setblock(UCPI_UBH(ucpi), ucpi->c_freeoff, blkno);
186 		if ((UFS_SB(sb)->s_flags & UFS_CG_MASK) == UFS_CG_44BSD)
187 			ufs_clusteracct (sb, ucpi, blkno, 1);
188 
189 		fs32_add(sb, &ucg->cg_cs.cs_nbfree, 1);
190 		uspi->cs_total.cs_nbfree++;
191 		fs32_add(sb, &UFS_SB(sb)->fs_cs(cgno).cs_nbfree, 1);
192 
193 		if (uspi->fs_magic != UFS2_MAGIC) {
194 			unsigned cylno = ufs_cbtocylno(i);
195 
196 			fs16_add(sb, &ubh_cg_blks(ucpi, cylno,
197 						  ufs_cbtorpos(i)), 1);
198 			fs32_add(sb, &ubh_cg_blktot(ucpi, cylno), 1);
199 		}
200 	}
201 
202 	ubh_mark_buffer_dirty (USPI_UBH(uspi));
203 	ubh_mark_buffer_dirty (UCPI_UBH(ucpi));
204 	if (sb->s_flags & MS_SYNCHRONOUS)
205 		ubh_sync_block(UCPI_UBH(ucpi));
206 
207 	if (overflow) {
208 		fragment += count;
209 		count = overflow;
210 		goto do_more;
211 	}
212 
213 	ufs_mark_sb_dirty(sb);
214 	mutex_unlock(&UFS_SB(sb)->s_lock);
215 	UFSD("EXIT\n");
216 	return;
217 
218 failed_unlock:
219 	mutex_unlock(&UFS_SB(sb)->s_lock);
220 failed:
221 	UFSD("EXIT (FAILED)\n");
222 	return;
223 }
224 
225 /*
226  * Modify inode page cache in such way:
227  * have - blocks with b_blocknr equal to oldb...oldb+count-1
228  * get - blocks with b_blocknr equal to newb...newb+count-1
229  * also we suppose that oldb...oldb+count-1 blocks
230  * situated at the end of file.
231  *
232  * We can come here from ufs_writepage or ufs_prepare_write,
233  * locked_page is argument of these functions, so we already lock it.
234  */
235 static void ufs_change_blocknr(struct inode *inode, sector_t beg,
236 			       unsigned int count, sector_t oldb,
237 			       sector_t newb, struct page *locked_page)
238 {
239 	const unsigned blks_per_page =
240 		1 << (PAGE_CACHE_SHIFT - inode->i_blkbits);
241 	const unsigned mask = blks_per_page - 1;
242 	struct address_space * const mapping = inode->i_mapping;
243 	pgoff_t index, cur_index, last_index;
244 	unsigned pos, j, lblock;
245 	sector_t end, i;
246 	struct page *page;
247 	struct buffer_head *head, *bh;
248 
249 	UFSD("ENTER, ino %lu, count %u, oldb %llu, newb %llu\n",
250 	      inode->i_ino, count,
251 	     (unsigned long long)oldb, (unsigned long long)newb);
252 
253 	BUG_ON(!locked_page);
254 	BUG_ON(!PageLocked(locked_page));
255 
256 	cur_index = locked_page->index;
257 	end = count + beg;
258 	last_index = end >> (PAGE_CACHE_SHIFT - inode->i_blkbits);
259 	for (i = beg; i < end; i = (i | mask) + 1) {
260 		index = i >> (PAGE_CACHE_SHIFT - inode->i_blkbits);
261 
262 		if (likely(cur_index != index)) {
263 			page = ufs_get_locked_page(mapping, index);
264 			if (!page)/* it was truncated */
265 				continue;
266 			if (IS_ERR(page)) {/* or EIO */
267 				ufs_error(inode->i_sb, __func__,
268 					  "read of page %llu failed\n",
269 					  (unsigned long long)index);
270 				continue;
271 			}
272 		} else
273 			page = locked_page;
274 
275 		head = page_buffers(page);
276 		bh = head;
277 		pos = i & mask;
278 		for (j = 0; j < pos; ++j)
279 			bh = bh->b_this_page;
280 
281 
282 		if (unlikely(index == last_index))
283 			lblock = end & mask;
284 		else
285 			lblock = blks_per_page;
286 
287 		do {
288 			if (j >= lblock)
289 				break;
290 			pos = (i - beg) + j;
291 
292 			if (!buffer_mapped(bh))
293 					map_bh(bh, inode->i_sb, oldb + pos);
294 			if (!buffer_uptodate(bh)) {
295 				ll_rw_block(READ, 1, &bh);
296 				wait_on_buffer(bh);
297 				if (!buffer_uptodate(bh)) {
298 					ufs_error(inode->i_sb, __func__,
299 						  "read of block failed\n");
300 					break;
301 				}
302 			}
303 
304 			UFSD(" change from %llu to %llu, pos %u\n",
305 			     (unsigned long long)(pos + oldb),
306 			     (unsigned long long)(pos + newb), pos);
307 
308 			bh->b_blocknr = newb + pos;
309 			unmap_underlying_metadata(bh->b_bdev,
310 						  bh->b_blocknr);
311 			mark_buffer_dirty(bh);
312 			++j;
313 			bh = bh->b_this_page;
314 		} while (bh != head);
315 
316 		if (likely(cur_index != index))
317 			ufs_put_locked_page(page);
318  	}
319 	UFSD("EXIT\n");
320 }
321 
322 static void ufs_clear_frags(struct inode *inode, sector_t beg, unsigned int n,
323 			    int sync)
324 {
325 	struct buffer_head *bh;
326 	sector_t end = beg + n;
327 
328 	for (; beg < end; ++beg) {
329 		bh = sb_getblk(inode->i_sb, beg);
330 		lock_buffer(bh);
331 		memset(bh->b_data, 0, inode->i_sb->s_blocksize);
332 		set_buffer_uptodate(bh);
333 		mark_buffer_dirty(bh);
334 		unlock_buffer(bh);
335 		if (IS_SYNC(inode) || sync)
336 			sync_dirty_buffer(bh);
337 		brelse(bh);
338 	}
339 }
340 
341 u64 ufs_new_fragments(struct inode *inode, void *p, u64 fragment,
342 			   u64 goal, unsigned count, int *err,
343 			   struct page *locked_page)
344 {
345 	struct super_block * sb;
346 	struct ufs_sb_private_info * uspi;
347 	struct ufs_super_block_first * usb1;
348 	unsigned cgno, oldcount, newcount;
349 	u64 tmp, request, result;
350 
351 	UFSD("ENTER, ino %lu, fragment %llu, goal %llu, count %u\n",
352 	     inode->i_ino, (unsigned long long)fragment,
353 	     (unsigned long long)goal, count);
354 
355 	sb = inode->i_sb;
356 	uspi = UFS_SB(sb)->s_uspi;
357 	usb1 = ubh_get_usb_first(uspi);
358 	*err = -ENOSPC;
359 
360 	mutex_lock(&UFS_SB(sb)->s_lock);
361 	tmp = ufs_data_ptr_to_cpu(sb, p);
362 
363 	if (count + ufs_fragnum(fragment) > uspi->s_fpb) {
364 		ufs_warning(sb, "ufs_new_fragments", "internal warning"
365 			    " fragment %llu, count %u",
366 			    (unsigned long long)fragment, count);
367 		count = uspi->s_fpb - ufs_fragnum(fragment);
368 	}
369 	oldcount = ufs_fragnum (fragment);
370 	newcount = oldcount + count;
371 
372 	/*
373 	 * Somebody else has just allocated our fragments
374 	 */
375 	if (oldcount) {
376 		if (!tmp) {
377 			ufs_error(sb, "ufs_new_fragments", "internal error, "
378 				  "fragment %llu, tmp %llu\n",
379 				  (unsigned long long)fragment,
380 				  (unsigned long long)tmp);
381 			mutex_unlock(&UFS_SB(sb)->s_lock);
382 			return INVBLOCK;
383 		}
384 		if (fragment < UFS_I(inode)->i_lastfrag) {
385 			UFSD("EXIT (ALREADY ALLOCATED)\n");
386 			mutex_unlock(&UFS_SB(sb)->s_lock);
387 			return 0;
388 		}
389 	}
390 	else {
391 		if (tmp) {
392 			UFSD("EXIT (ALREADY ALLOCATED)\n");
393 			mutex_unlock(&UFS_SB(sb)->s_lock);
394 			return 0;
395 		}
396 	}
397 
398 	/*
399 	 * There is not enough space for user on the device
400 	 */
401 	if (!capable(CAP_SYS_RESOURCE) && ufs_freespace(uspi, UFS_MINFREE) <= 0) {
402 		mutex_unlock(&UFS_SB(sb)->s_lock);
403 		UFSD("EXIT (FAILED)\n");
404 		return 0;
405 	}
406 
407 	if (goal >= uspi->s_size)
408 		goal = 0;
409 	if (goal == 0)
410 		cgno = ufs_inotocg (inode->i_ino);
411 	else
412 		cgno = ufs_dtog(uspi, goal);
413 
414 	/*
415 	 * allocate new fragment
416 	 */
417 	if (oldcount == 0) {
418 		result = ufs_alloc_fragments (inode, cgno, goal, count, err);
419 		if (result) {
420 			ufs_clear_frags(inode, result + oldcount,
421 					newcount - oldcount, locked_page != NULL);
422 			write_seqlock(&UFS_I(inode)->meta_lock);
423 			ufs_cpu_to_data_ptr(sb, p, result);
424 			write_sequnlock(&UFS_I(inode)->meta_lock);
425 			*err = 0;
426 			UFS_I(inode)->i_lastfrag =
427 				max(UFS_I(inode)->i_lastfrag, fragment + count);
428 		}
429 		mutex_unlock(&UFS_SB(sb)->s_lock);
430 		UFSD("EXIT, result %llu\n", (unsigned long long)result);
431 		return result;
432 	}
433 
434 	/*
435 	 * resize block
436 	 */
437 	result = ufs_add_fragments(inode, tmp, oldcount, newcount);
438 	if (result) {
439 		*err = 0;
440 		UFS_I(inode)->i_lastfrag = max(UFS_I(inode)->i_lastfrag,
441 						fragment + count);
442 		ufs_clear_frags(inode, result + oldcount, newcount - oldcount,
443 				locked_page != NULL);
444 		mutex_unlock(&UFS_SB(sb)->s_lock);
445 		UFSD("EXIT, result %llu\n", (unsigned long long)result);
446 		return result;
447 	}
448 
449 	/*
450 	 * allocate new block and move data
451 	 */
452 	switch (fs32_to_cpu(sb, usb1->fs_optim)) {
453 	    case UFS_OPTSPACE:
454 		request = newcount;
455 		if (uspi->s_minfree < 5 || uspi->cs_total.cs_nffree
456 		    > uspi->s_dsize * uspi->s_minfree / (2 * 100))
457 			break;
458 		usb1->fs_optim = cpu_to_fs32(sb, UFS_OPTTIME);
459 		break;
460 	    default:
461 		usb1->fs_optim = cpu_to_fs32(sb, UFS_OPTTIME);
462 
463 	    case UFS_OPTTIME:
464 		request = uspi->s_fpb;
465 		if (uspi->cs_total.cs_nffree < uspi->s_dsize *
466 		    (uspi->s_minfree - 2) / 100)
467 			break;
468 		usb1->fs_optim = cpu_to_fs32(sb, UFS_OPTTIME);
469 		break;
470 	}
471 	result = ufs_alloc_fragments (inode, cgno, goal, request, err);
472 	if (result) {
473 		ufs_clear_frags(inode, result + oldcount, newcount - oldcount,
474 				locked_page != NULL);
475 		ufs_change_blocknr(inode, fragment - oldcount, oldcount,
476 				   uspi->s_sbbase + tmp,
477 				   uspi->s_sbbase + result, locked_page);
478 		write_seqlock(&UFS_I(inode)->meta_lock);
479 		ufs_cpu_to_data_ptr(sb, p, result);
480 		write_sequnlock(&UFS_I(inode)->meta_lock);
481 		*err = 0;
482 		UFS_I(inode)->i_lastfrag = max(UFS_I(inode)->i_lastfrag,
483 						fragment + count);
484 		mutex_unlock(&UFS_SB(sb)->s_lock);
485 		if (newcount < request)
486 			ufs_free_fragments (inode, result + newcount, request - newcount);
487 		ufs_free_fragments (inode, tmp, oldcount);
488 		UFSD("EXIT, result %llu\n", (unsigned long long)result);
489 		return result;
490 	}
491 
492 	mutex_unlock(&UFS_SB(sb)->s_lock);
493 	UFSD("EXIT (FAILED)\n");
494 	return 0;
495 }
496 
497 static u64 ufs_add_fragments(struct inode *inode, u64 fragment,
498 			     unsigned oldcount, unsigned newcount)
499 {
500 	struct super_block * sb;
501 	struct ufs_sb_private_info * uspi;
502 	struct ufs_cg_private_info * ucpi;
503 	struct ufs_cylinder_group * ucg;
504 	unsigned cgno, fragno, fragoff, count, fragsize, i;
505 
506 	UFSD("ENTER, fragment %llu, oldcount %u, newcount %u\n",
507 	     (unsigned long long)fragment, oldcount, newcount);
508 
509 	sb = inode->i_sb;
510 	uspi = UFS_SB(sb)->s_uspi;
511 	count = newcount - oldcount;
512 
513 	cgno = ufs_dtog(uspi, fragment);
514 	if (fs32_to_cpu(sb, UFS_SB(sb)->fs_cs(cgno).cs_nffree) < count)
515 		return 0;
516 	if ((ufs_fragnum (fragment) + newcount) > uspi->s_fpb)
517 		return 0;
518 	ucpi = ufs_load_cylinder (sb, cgno);
519 	if (!ucpi)
520 		return 0;
521 	ucg = ubh_get_ucg (UCPI_UBH(ucpi));
522 	if (!ufs_cg_chkmagic(sb, ucg)) {
523 		ufs_panic (sb, "ufs_add_fragments",
524 			"internal error, bad magic number on cg %u", cgno);
525 		return 0;
526 	}
527 
528 	fragno = ufs_dtogd(uspi, fragment);
529 	fragoff = ufs_fragnum (fragno);
530 	for (i = oldcount; i < newcount; i++)
531 		if (ubh_isclr (UCPI_UBH(ucpi), ucpi->c_freeoff, fragno + i))
532 			return 0;
533 	/*
534 	 * Block can be extended
535 	 */
536 	ucg->cg_time = cpu_to_fs32(sb, get_seconds());
537 	for (i = newcount; i < (uspi->s_fpb - fragoff); i++)
538 		if (ubh_isclr (UCPI_UBH(ucpi), ucpi->c_freeoff, fragno + i))
539 			break;
540 	fragsize = i - oldcount;
541 	if (!fs32_to_cpu(sb, ucg->cg_frsum[fragsize]))
542 		ufs_panic (sb, "ufs_add_fragments",
543 			"internal error or corrupted bitmap on cg %u", cgno);
544 	fs32_sub(sb, &ucg->cg_frsum[fragsize], 1);
545 	if (fragsize != count)
546 		fs32_add(sb, &ucg->cg_frsum[fragsize - count], 1);
547 	for (i = oldcount; i < newcount; i++)
548 		ubh_clrbit (UCPI_UBH(ucpi), ucpi->c_freeoff, fragno + i);
549 
550 	fs32_sub(sb, &ucg->cg_cs.cs_nffree, count);
551 	fs32_sub(sb, &UFS_SB(sb)->fs_cs(cgno).cs_nffree, count);
552 	uspi->cs_total.cs_nffree -= count;
553 
554 	ubh_mark_buffer_dirty (USPI_UBH(uspi));
555 	ubh_mark_buffer_dirty (UCPI_UBH(ucpi));
556 	if (sb->s_flags & MS_SYNCHRONOUS)
557 		ubh_sync_block(UCPI_UBH(ucpi));
558 	ufs_mark_sb_dirty(sb);
559 
560 	UFSD("EXIT, fragment %llu\n", (unsigned long long)fragment);
561 
562 	return fragment;
563 }
564 
565 #define UFS_TEST_FREE_SPACE_CG \
566 	ucg = (struct ufs_cylinder_group *) UFS_SB(sb)->s_ucg[cgno]->b_data; \
567 	if (fs32_to_cpu(sb, ucg->cg_cs.cs_nbfree)) \
568 		goto cg_found; \
569 	for (k = count; k < uspi->s_fpb; k++) \
570 		if (fs32_to_cpu(sb, ucg->cg_frsum[k])) \
571 			goto cg_found;
572 
573 static u64 ufs_alloc_fragments(struct inode *inode, unsigned cgno,
574 			       u64 goal, unsigned count, int *err)
575 {
576 	struct super_block * sb;
577 	struct ufs_sb_private_info * uspi;
578 	struct ufs_cg_private_info * ucpi;
579 	struct ufs_cylinder_group * ucg;
580 	unsigned oldcg, i, j, k, allocsize;
581 	u64 result;
582 
583 	UFSD("ENTER, ino %lu, cgno %u, goal %llu, count %u\n",
584 	     inode->i_ino, cgno, (unsigned long long)goal, count);
585 
586 	sb = inode->i_sb;
587 	uspi = UFS_SB(sb)->s_uspi;
588 	oldcg = cgno;
589 
590 	/*
591 	 * 1. searching on preferred cylinder group
592 	 */
593 	UFS_TEST_FREE_SPACE_CG
594 
595 	/*
596 	 * 2. quadratic rehash
597 	 */
598 	for (j = 1; j < uspi->s_ncg; j *= 2) {
599 		cgno += j;
600 		if (cgno >= uspi->s_ncg)
601 			cgno -= uspi->s_ncg;
602 		UFS_TEST_FREE_SPACE_CG
603 	}
604 
605 	/*
606 	 * 3. brute force search
607 	 * We start at i = 2 ( 0 is checked at 1.step, 1 at 2.step )
608 	 */
609 	cgno = (oldcg + 1) % uspi->s_ncg;
610 	for (j = 2; j < uspi->s_ncg; j++) {
611 		cgno++;
612 		if (cgno >= uspi->s_ncg)
613 			cgno = 0;
614 		UFS_TEST_FREE_SPACE_CG
615 	}
616 
617 	UFSD("EXIT (FAILED)\n");
618 	return 0;
619 
620 cg_found:
621 	ucpi = ufs_load_cylinder (sb, cgno);
622 	if (!ucpi)
623 		return 0;
624 	ucg = ubh_get_ucg (UCPI_UBH(ucpi));
625 	if (!ufs_cg_chkmagic(sb, ucg))
626 		ufs_panic (sb, "ufs_alloc_fragments",
627 			"internal error, bad magic number on cg %u", cgno);
628 	ucg->cg_time = cpu_to_fs32(sb, get_seconds());
629 
630 	if (count == uspi->s_fpb) {
631 		result = ufs_alloccg_block (inode, ucpi, goal, err);
632 		if (result == INVBLOCK)
633 			return 0;
634 		goto succed;
635 	}
636 
637 	for (allocsize = count; allocsize < uspi->s_fpb; allocsize++)
638 		if (fs32_to_cpu(sb, ucg->cg_frsum[allocsize]) != 0)
639 			break;
640 
641 	if (allocsize == uspi->s_fpb) {
642 		result = ufs_alloccg_block (inode, ucpi, goal, err);
643 		if (result == INVBLOCK)
644 			return 0;
645 		goal = ufs_dtogd(uspi, result);
646 		for (i = count; i < uspi->s_fpb; i++)
647 			ubh_setbit (UCPI_UBH(ucpi), ucpi->c_freeoff, goal + i);
648 		i = uspi->s_fpb - count;
649 
650 		fs32_add(sb, &ucg->cg_cs.cs_nffree, i);
651 		uspi->cs_total.cs_nffree += i;
652 		fs32_add(sb, &UFS_SB(sb)->fs_cs(cgno).cs_nffree, i);
653 		fs32_add(sb, &ucg->cg_frsum[i], 1);
654 		goto succed;
655 	}
656 
657 	result = ufs_bitmap_search (sb, ucpi, goal, allocsize);
658 	if (result == INVBLOCK)
659 		return 0;
660 	for (i = 0; i < count; i++)
661 		ubh_clrbit (UCPI_UBH(ucpi), ucpi->c_freeoff, result + i);
662 
663 	fs32_sub(sb, &ucg->cg_cs.cs_nffree, count);
664 	uspi->cs_total.cs_nffree -= count;
665 	fs32_sub(sb, &UFS_SB(sb)->fs_cs(cgno).cs_nffree, count);
666 	fs32_sub(sb, &ucg->cg_frsum[allocsize], 1);
667 
668 	if (count != allocsize)
669 		fs32_add(sb, &ucg->cg_frsum[allocsize - count], 1);
670 
671 succed:
672 	ubh_mark_buffer_dirty (USPI_UBH(uspi));
673 	ubh_mark_buffer_dirty (UCPI_UBH(ucpi));
674 	if (sb->s_flags & MS_SYNCHRONOUS)
675 		ubh_sync_block(UCPI_UBH(ucpi));
676 	ufs_mark_sb_dirty(sb);
677 
678 	result += cgno * uspi->s_fpg;
679 	UFSD("EXIT3, result %llu\n", (unsigned long long)result);
680 	return result;
681 }
682 
683 static u64 ufs_alloccg_block(struct inode *inode,
684 			     struct ufs_cg_private_info *ucpi,
685 			     u64 goal, int *err)
686 {
687 	struct super_block * sb;
688 	struct ufs_sb_private_info * uspi;
689 	struct ufs_cylinder_group * ucg;
690 	u64 result, blkno;
691 
692 	UFSD("ENTER, goal %llu\n", (unsigned long long)goal);
693 
694 	sb = inode->i_sb;
695 	uspi = UFS_SB(sb)->s_uspi;
696 	ucg = ubh_get_ucg(UCPI_UBH(ucpi));
697 
698 	if (goal == 0) {
699 		goal = ucpi->c_rotor;
700 		goto norot;
701 	}
702 	goal = ufs_blknum (goal);
703 	goal = ufs_dtogd(uspi, goal);
704 
705 	/*
706 	 * If the requested block is available, use it.
707 	 */
708 	if (ubh_isblockset(UCPI_UBH(ucpi), ucpi->c_freeoff, ufs_fragstoblks(goal))) {
709 		result = goal;
710 		goto gotit;
711 	}
712 
713 norot:
714 	result = ufs_bitmap_search (sb, ucpi, goal, uspi->s_fpb);
715 	if (result == INVBLOCK)
716 		return INVBLOCK;
717 	ucpi->c_rotor = result;
718 gotit:
719 	blkno = ufs_fragstoblks(result);
720 	ubh_clrblock (UCPI_UBH(ucpi), ucpi->c_freeoff, blkno);
721 	if ((UFS_SB(sb)->s_flags & UFS_CG_MASK) == UFS_CG_44BSD)
722 		ufs_clusteracct (sb, ucpi, blkno, -1);
723 
724 	fs32_sub(sb, &ucg->cg_cs.cs_nbfree, 1);
725 	uspi->cs_total.cs_nbfree--;
726 	fs32_sub(sb, &UFS_SB(sb)->fs_cs(ucpi->c_cgx).cs_nbfree, 1);
727 
728 	if (uspi->fs_magic != UFS2_MAGIC) {
729 		unsigned cylno = ufs_cbtocylno((unsigned)result);
730 
731 		fs16_sub(sb, &ubh_cg_blks(ucpi, cylno,
732 					  ufs_cbtorpos((unsigned)result)), 1);
733 		fs32_sub(sb, &ubh_cg_blktot(ucpi, cylno), 1);
734 	}
735 
736 	UFSD("EXIT, result %llu\n", (unsigned long long)result);
737 
738 	return result;
739 }
740 
741 static unsigned ubh_scanc(struct ufs_sb_private_info *uspi,
742 			  struct ufs_buffer_head *ubh,
743 			  unsigned begin, unsigned size,
744 			  unsigned char *table, unsigned char mask)
745 {
746 	unsigned rest, offset;
747 	unsigned char *cp;
748 
749 
750 	offset = begin & ~uspi->s_fmask;
751 	begin >>= uspi->s_fshift;
752 	for (;;) {
753 		if ((offset + size) < uspi->s_fsize)
754 			rest = size;
755 		else
756 			rest = uspi->s_fsize - offset;
757 		size -= rest;
758 		cp = ubh->bh[begin]->b_data + offset;
759 		while ((table[*cp++] & mask) == 0 && --rest)
760 			;
761 		if (rest || !size)
762 			break;
763 		begin++;
764 		offset = 0;
765 	}
766 	return (size + rest);
767 }
768 
769 /*
770  * Find a block of the specified size in the specified cylinder group.
771  * @sp: pointer to super block
772  * @ucpi: pointer to cylinder group info
773  * @goal: near which block we want find new one
774  * @count: specified size
775  */
776 static u64 ufs_bitmap_search(struct super_block *sb,
777 			     struct ufs_cg_private_info *ucpi,
778 			     u64 goal, unsigned count)
779 {
780 	/*
781 	 * Bit patterns for identifying fragments in the block map
782 	 * used as ((map & mask_arr) == want_arr)
783 	 */
784 	static const int mask_arr[9] = {
785 		0x3, 0x7, 0xf, 0x1f, 0x3f, 0x7f, 0xff, 0x1ff, 0x3ff
786 	};
787 	static const int want_arr[9] = {
788 		0x0, 0x2, 0x6, 0xe, 0x1e, 0x3e, 0x7e, 0xfe, 0x1fe
789 	};
790 	struct ufs_sb_private_info *uspi = UFS_SB(sb)->s_uspi;
791 	unsigned start, length, loc;
792 	unsigned pos, want, blockmap, mask, end;
793 	u64 result;
794 
795 	UFSD("ENTER, cg %u, goal %llu, count %u\n", ucpi->c_cgx,
796 	     (unsigned long long)goal, count);
797 
798 	if (goal)
799 		start = ufs_dtogd(uspi, goal) >> 3;
800 	else
801 		start = ucpi->c_frotor >> 3;
802 
803 	length = ((uspi->s_fpg + 7) >> 3) - start;
804 	loc = ubh_scanc(uspi, UCPI_UBH(ucpi), ucpi->c_freeoff + start, length,
805 		(uspi->s_fpb == 8) ? ufs_fragtable_8fpb : ufs_fragtable_other,
806 		1 << (count - 1 + (uspi->s_fpb & 7)));
807 	if (loc == 0) {
808 		length = start + 1;
809 		loc = ubh_scanc(uspi, UCPI_UBH(ucpi), ucpi->c_freeoff, length,
810 				(uspi->s_fpb == 8) ? ufs_fragtable_8fpb :
811 				ufs_fragtable_other,
812 				1 << (count - 1 + (uspi->s_fpb & 7)));
813 		if (loc == 0) {
814 			ufs_error(sb, "ufs_bitmap_search",
815 				  "bitmap corrupted on cg %u, start %u,"
816 				  " length %u, count %u, freeoff %u\n",
817 				  ucpi->c_cgx, start, length, count,
818 				  ucpi->c_freeoff);
819 			return INVBLOCK;
820 		}
821 		start = 0;
822 	}
823 	result = (start + length - loc) << 3;
824 	ucpi->c_frotor = result;
825 
826 	/*
827 	 * found the byte in the map
828 	 */
829 
830 	for (end = result + 8; result < end; result += uspi->s_fpb) {
831 		blockmap = ubh_blkmap(UCPI_UBH(ucpi), ucpi->c_freeoff, result);
832 		blockmap <<= 1;
833 		mask = mask_arr[count];
834 		want = want_arr[count];
835 		for (pos = 0; pos <= uspi->s_fpb - count; pos++) {
836 			if ((blockmap & mask) == want) {
837 				UFSD("EXIT, result %llu\n",
838 				     (unsigned long long)result);
839 				return result + pos;
840  			}
841 			mask <<= 1;
842 			want <<= 1;
843  		}
844  	}
845 
846 	ufs_error(sb, "ufs_bitmap_search", "block not in map on cg %u\n",
847 		  ucpi->c_cgx);
848 	UFSD("EXIT (FAILED)\n");
849 	return INVBLOCK;
850 }
851 
852 static void ufs_clusteracct(struct super_block * sb,
853 	struct ufs_cg_private_info * ucpi, unsigned blkno, int cnt)
854 {
855 	struct ufs_sb_private_info * uspi;
856 	int i, start, end, forw, back;
857 
858 	uspi = UFS_SB(sb)->s_uspi;
859 	if (uspi->s_contigsumsize <= 0)
860 		return;
861 
862 	if (cnt > 0)
863 		ubh_setbit(UCPI_UBH(ucpi), ucpi->c_clusteroff, blkno);
864 	else
865 		ubh_clrbit(UCPI_UBH(ucpi), ucpi->c_clusteroff, blkno);
866 
867 	/*
868 	 * Find the size of the cluster going forward.
869 	 */
870 	start = blkno + 1;
871 	end = start + uspi->s_contigsumsize;
872 	if ( end >= ucpi->c_nclusterblks)
873 		end = ucpi->c_nclusterblks;
874 	i = ubh_find_next_zero_bit (UCPI_UBH(ucpi), ucpi->c_clusteroff, end, start);
875 	if (i > end)
876 		i = end;
877 	forw = i - start;
878 
879 	/*
880 	 * Find the size of the cluster going backward.
881 	 */
882 	start = blkno - 1;
883 	end = start - uspi->s_contigsumsize;
884 	if (end < 0 )
885 		end = -1;
886 	i = ubh_find_last_zero_bit (UCPI_UBH(ucpi), ucpi->c_clusteroff, start, end);
887 	if ( i < end)
888 		i = end;
889 	back = start - i;
890 
891 	/*
892 	 * Account for old cluster and the possibly new forward and
893 	 * back clusters.
894 	 */
895 	i = back + forw + 1;
896 	if (i > uspi->s_contigsumsize)
897 		i = uspi->s_contigsumsize;
898 	fs32_add(sb, (__fs32*)ubh_get_addr(UCPI_UBH(ucpi), ucpi->c_clustersumoff + (i << 2)), cnt);
899 	if (back > 0)
900 		fs32_sub(sb, (__fs32*)ubh_get_addr(UCPI_UBH(ucpi), ucpi->c_clustersumoff + (back << 2)), cnt);
901 	if (forw > 0)
902 		fs32_sub(sb, (__fs32*)ubh_get_addr(UCPI_UBH(ucpi), ucpi->c_clustersumoff + (forw << 2)), cnt);
903 }
904 
905 
906 static unsigned char ufs_fragtable_8fpb[] = {
907 	0x00, 0x01, 0x01, 0x02, 0x01, 0x01, 0x02, 0x04, 0x01, 0x01, 0x01, 0x03, 0x02, 0x03, 0x04, 0x08,
908 	0x01, 0x01, 0x01, 0x03, 0x01, 0x01, 0x03, 0x05, 0x02, 0x03, 0x03, 0x02, 0x04, 0x05, 0x08, 0x10,
909 	0x01, 0x01, 0x01, 0x03, 0x01, 0x01, 0x03, 0x05, 0x01, 0x01, 0x01, 0x03, 0x03, 0x03, 0x05, 0x09,
910 	0x02, 0x03, 0x03, 0x02, 0x03, 0x03, 0x02, 0x06, 0x04, 0x05, 0x05, 0x06, 0x08, 0x09, 0x10, 0x20,
911 	0x01, 0x01, 0x01, 0x03, 0x01, 0x01, 0x03, 0x05, 0x01, 0x01, 0x01, 0x03, 0x03, 0x03, 0x05, 0x09,
912 	0x01, 0x01, 0x01, 0x03, 0x01, 0x01, 0x03, 0x05, 0x03, 0x03, 0x03, 0x03, 0x05, 0x05, 0x09, 0x11,
913 	0x02, 0x03, 0x03, 0x02, 0x03, 0x03, 0x02, 0x06, 0x03, 0x03, 0x03, 0x03, 0x02, 0x03, 0x06, 0x0A,
914 	0x04, 0x05, 0x05, 0x06, 0x05, 0x05, 0x06, 0x04, 0x08, 0x09, 0x09, 0x0A, 0x10, 0x11, 0x20, 0x40,
915 	0x01, 0x01, 0x01, 0x03, 0x01, 0x01, 0x03, 0x05, 0x01, 0x01, 0x01, 0x03, 0x03, 0x03, 0x05, 0x09,
916 	0x01, 0x01, 0x01, 0x03, 0x01, 0x01, 0x03, 0x05, 0x03, 0x03, 0x03, 0x03, 0x05, 0x05, 0x09, 0x11,
917 	0x01, 0x01, 0x01, 0x03, 0x01, 0x01, 0x03, 0x05, 0x01, 0x01, 0x01, 0x03, 0x03, 0x03, 0x05, 0x09,
918 	0x03, 0x03, 0x03, 0x03, 0x03, 0x03, 0x03, 0x07, 0x05, 0x05, 0x05, 0x07, 0x09, 0x09, 0x11, 0x21,
919 	0x02, 0x03, 0x03, 0x02, 0x03, 0x03, 0x02, 0x06, 0x03, 0x03, 0x03, 0x03, 0x02, 0x03, 0x06, 0x0A,
920 	0x03, 0x03, 0x03, 0x03, 0x03, 0x03, 0x03, 0x07, 0x02, 0x03, 0x03, 0x02, 0x06, 0x07, 0x0A, 0x12,
921 	0x04, 0x05, 0x05, 0x06, 0x05, 0x05, 0x06, 0x04, 0x05, 0x05, 0x05, 0x07, 0x06, 0x07, 0x04, 0x0C,
922 	0x08, 0x09, 0x09, 0x0A, 0x09, 0x09, 0x0A, 0x0C, 0x10, 0x11, 0x11, 0x12, 0x20, 0x21, 0x40, 0x80,
923 };
924 
925 static unsigned char ufs_fragtable_other[] = {
926 	0x00, 0x16, 0x16, 0x2A, 0x16, 0x16, 0x26, 0x4E, 0x16, 0x16, 0x16, 0x3E, 0x2A, 0x3E, 0x4E, 0x8A,
927 	0x16, 0x16, 0x16, 0x3E, 0x16, 0x16, 0x36, 0x5E, 0x16, 0x16, 0x16, 0x3E, 0x3E, 0x3E, 0x5E, 0x9E,
928 	0x16, 0x16, 0x16, 0x3E, 0x16, 0x16, 0x36, 0x5E, 0x16, 0x16, 0x16, 0x3E, 0x3E, 0x3E, 0x5E, 0x9E,
929 	0x2A, 0x3E, 0x3E, 0x2A, 0x3E, 0x3E, 0x2E, 0x6E, 0x3E, 0x3E, 0x3E, 0x3E, 0x2A, 0x3E, 0x6E, 0xAA,
930 	0x16, 0x16, 0x16, 0x3E, 0x16, 0x16, 0x36, 0x5E, 0x16, 0x16, 0x16, 0x3E, 0x3E, 0x3E, 0x5E, 0x9E,
931 	0x16, 0x16, 0x16, 0x3E, 0x16, 0x16, 0x36, 0x5E, 0x16, 0x16, 0x16, 0x3E, 0x3E, 0x3E, 0x5E, 0x9E,
932 	0x26, 0x36, 0x36, 0x2E, 0x36, 0x36, 0x26, 0x6E, 0x36, 0x36, 0x36, 0x3E, 0x2E, 0x3E, 0x6E, 0xAE,
933 	0x4E, 0x5E, 0x5E, 0x6E, 0x5E, 0x5E, 0x6E, 0x4E, 0x5E, 0x5E, 0x5E, 0x7E, 0x6E, 0x7E, 0x4E, 0xCE,
934 	0x16, 0x16, 0x16, 0x3E, 0x16, 0x16, 0x36, 0x5E, 0x16, 0x16, 0x16, 0x3E, 0x3E, 0x3E, 0x5E, 0x9E,
935 	0x16, 0x16, 0x16, 0x3E, 0x16, 0x16, 0x36, 0x5E, 0x16, 0x16, 0x16, 0x3E, 0x3E, 0x3E, 0x5E, 0x9E,
936 	0x16, 0x16, 0x16, 0x3E, 0x16, 0x16, 0x36, 0x5E, 0x16, 0x16, 0x16, 0x3E, 0x3E, 0x3E, 0x5E, 0x9E,
937 	0x3E, 0x3E, 0x3E, 0x3E, 0x3E, 0x3E, 0x3E, 0x7E, 0x3E, 0x3E, 0x3E, 0x3E, 0x3E, 0x3E, 0x7E, 0xBE,
938 	0x2A, 0x3E, 0x3E, 0x2A, 0x3E, 0x3E, 0x2E, 0x6E, 0x3E, 0x3E, 0x3E, 0x3E, 0x2A, 0x3E, 0x6E, 0xAA,
939 	0x3E, 0x3E, 0x3E, 0x3E, 0x3E, 0x3E, 0x3E, 0x7E,	0x3E, 0x3E, 0x3E, 0x3E, 0x3E, 0x3E, 0x7E, 0xBE,
940 	0x4E, 0x5E, 0x5E, 0x6E, 0x5E, 0x5E, 0x6E, 0x4E, 0x5E, 0x5E, 0x5E, 0x7E, 0x6E, 0x7E, 0x4E, 0xCE,
941 	0x8A, 0x9E, 0x9E, 0xAA, 0x9E, 0x9E, 0xAE, 0xCE, 0x9E, 0x9E, 0x9E, 0xBE, 0xAA, 0xBE, 0xCE, 0x8A,
942 };
943