blob: bbde5d582978972e02bbb97841837f9788b9da20 [file] [log] [blame]
Dave Kleikampac27a0e2006-10-11 01:20:50 -07001/*
Mingming Cao617ba132006-10-11 01:20:53 -07002 * linux/fs/ext4/bitmap.c
Dave Kleikampac27a0e2006-10-11 01:20:50 -07003 *
4 * Copyright (C) 1992, 1993, 1994, 1995
5 * Remy Card (card@masi.ibp.fr)
6 * Laboratoire MASI - Institut Blaise Pascal
7 * Universite Pierre et Marie Curie (Paris VI)
8 */
9
10#include <linux/buffer_head.h>
Mingming Caodab291a2006-10-11 01:21:01 -070011#include <linux/jbd2.h>
Christoph Hellwig3dcf5452008-04-29 18:13:32 -040012#include "ext4.h"
Dave Kleikampac27a0e2006-10-11 01:20:50 -070013
Philippe De Muyterfebfcf92007-10-16 23:26:15 -070014static const int nibblemap[] = {4, 3, 3, 2, 3, 2, 2, 1, 3, 2, 2, 1, 2, 1, 1, 0};
Dave Kleikampac27a0e2006-10-11 01:20:50 -070015
Theodore Ts'o9fe60452012-06-30 19:14:57 -040016unsigned int ext4_count_free(char *bitmap, unsigned int numchars)
Dave Kleikampac27a0e2006-10-11 01:20:50 -070017{
Theodore Ts'o498e5f22008-11-05 00:14:04 -050018 unsigned int i, sum = 0;
Dave Kleikampac27a0e2006-10-11 01:20:50 -070019
Dave Kleikampac27a0e2006-10-11 01:20:50 -070020 for (i = 0; i < numchars; i++)
Theodore Ts'o9fe60452012-06-30 19:14:57 -040021 sum += nibblemap[bitmap[i] & 0xf] +
22 nibblemap[(bitmap[i] >> 4) & 0xf];
Theodore Ts'oaf5bc922008-09-08 22:25:24 -040023 return sum;
Dave Kleikampac27a0e2006-10-11 01:20:50 -070024}
25