2006-10-11 08:20:50 +00:00
|
|
|
/*
|
2006-10-11 08:20:53 +00:00
|
|
|
* linux/fs/ext4/bitmap.c
|
2006-10-11 08:20:50 +00:00
|
|
|
*
|
|
|
|
* Copyright (C) 1992, 1993, 1994, 1995
|
|
|
|
* Remy Card (card@masi.ibp.fr)
|
|
|
|
* Laboratoire MASI - Institut Blaise Pascal
|
|
|
|
* Universite Pierre et Marie Curie (Paris VI)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/buffer_head.h>
|
2006-10-11 08:21:01 +00:00
|
|
|
#include <linux/jbd2.h>
|
2008-04-29 22:13:32 +00:00
|
|
|
#include "ext4.h"
|
2006-10-11 08:20:50 +00:00
|
|
|
|
2007-10-17 06:26:15 +00:00
|
|
|
static const int nibblemap[] = {4, 3, 3, 2, 3, 2, 2, 1, 3, 2, 2, 1, 2, 1, 1, 0};
|
2006-10-11 08:20:50 +00:00
|
|
|
|
2012-06-30 23:14:57 +00:00
|
|
|
unsigned int ext4_count_free(char *bitmap, unsigned int numchars)
|
2006-10-11 08:20:50 +00:00
|
|
|
{
|
2008-11-05 05:14:04 +00:00
|
|
|
unsigned int i, sum = 0;
|
2006-10-11 08:20:50 +00:00
|
|
|
|
|
|
|
for (i = 0; i < numchars; i++)
|
2012-06-30 23:14:57 +00:00
|
|
|
sum += nibblemap[bitmap[i] & 0xf] +
|
|
|
|
nibblemap[(bitmap[i] >> 4) & 0xf];
|
2008-09-09 02:25:24 +00:00
|
|
|
return sum;
|
2006-10-11 08:20:50 +00:00
|
|
|
}
|
|
|
|
|