mirror of
https://git.kernel.org/pub/scm/fs/ext2/e2fsprogs.git
synced 2025-01-21 16:03:24 +08:00
215 lines
4.5 KiB
C
215 lines
4.5 KiB
C
/*
|
|
|
|
/usr/src/ext2ed/inodebitmap_com.c
|
|
|
|
A part of the extended file system 2 disk editor.
|
|
|
|
-------------------------
|
|
Handles the inode bitmap.
|
|
-------------------------
|
|
|
|
Please refer to the documentation in blockbitmap_com.c - Those two files are almost equal.
|
|
|
|
First written on: July 25 1995
|
|
|
|
Copyright (C) 1995 Gadi Oxman
|
|
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
#include "ext2ed.h"
|
|
|
|
|
|
void type_ext2_inode_bitmap___entry (char *command_line)
|
|
|
|
{
|
|
unsigned long entry_num;
|
|
char *ptr,buffer [80];
|
|
|
|
ptr=parse_word (command_line,buffer);
|
|
if (*ptr==0) {
|
|
wprintw (command_win,"Error - No argument specified\n");refresh_command_win ();return;
|
|
}
|
|
ptr=parse_word (ptr,buffer);
|
|
|
|
entry_num=atol (buffer);
|
|
|
|
if (entry_num >= file_system_info.super_block.s_inodes_per_group) {
|
|
wprintw (command_win,"Error - Entry number out of bounds\n");refresh_command_win ();return;
|
|
}
|
|
|
|
inode_bitmap_info.entry_num=entry_num;
|
|
strcpy (buffer,"show");dispatch (buffer);
|
|
}
|
|
|
|
void type_ext2_inode_bitmap___next (char *command_line)
|
|
|
|
{
|
|
long entry_offset=1;
|
|
char *ptr,buffer [80];
|
|
|
|
ptr=parse_word (command_line,buffer);
|
|
if (*ptr!=0) {
|
|
ptr=parse_word (ptr,buffer);
|
|
entry_offset=atol (buffer);
|
|
}
|
|
|
|
sprintf (buffer,"entry %ld",inode_bitmap_info.entry_num+entry_offset);
|
|
dispatch (buffer);
|
|
}
|
|
|
|
void type_ext2_inode_bitmap___prev (char *command_line)
|
|
|
|
{
|
|
long entry_offset=1;
|
|
char *ptr,buffer [80];
|
|
|
|
ptr=parse_word (command_line,buffer);
|
|
if (*ptr!=0) {
|
|
ptr=parse_word (ptr,buffer);
|
|
entry_offset=atol (buffer);
|
|
}
|
|
|
|
sprintf (buffer,"entry %ld",inode_bitmap_info.entry_num-entry_offset);
|
|
dispatch (buffer);
|
|
}
|
|
|
|
void type_ext2_inode_bitmap___allocate (char *command_line)
|
|
|
|
{
|
|
long entry_num,num=1;
|
|
char *ptr,buffer [80];
|
|
|
|
ptr=parse_word (command_line,buffer);
|
|
if (*ptr!=0) {
|
|
ptr=parse_word (ptr,buffer);
|
|
num=atol (buffer);
|
|
}
|
|
|
|
entry_num=inode_bitmap_info.entry_num;
|
|
if (num > file_system_info.super_block.s_inodes_per_group-entry_num) {
|
|
wprintw (command_win,"Error - There aren't that much inodes in the group\n");
|
|
refresh_command_win ();return;
|
|
}
|
|
|
|
while (num) {
|
|
allocate_inode (entry_num);
|
|
num--;entry_num++;
|
|
}
|
|
|
|
dispatch ("show");
|
|
}
|
|
|
|
void type_ext2_inode_bitmap___deallocate (char *command_line)
|
|
|
|
{
|
|
long entry_num,num=1;
|
|
char *ptr,buffer [80];
|
|
|
|
ptr=parse_word (command_line,buffer);
|
|
if (*ptr!=0) {
|
|
ptr=parse_word (ptr,buffer);
|
|
num=atol (buffer);
|
|
}
|
|
|
|
entry_num=inode_bitmap_info.entry_num;
|
|
if (num > file_system_info.super_block.s_inodes_per_group-entry_num) {
|
|
wprintw (command_win,"Error - There aren't that much inodes in the group\n");
|
|
refresh_command_win ();return;
|
|
}
|
|
|
|
while (num) {
|
|
deallocate_inode (entry_num);
|
|
num--;entry_num++;
|
|
}
|
|
|
|
dispatch ("show");
|
|
}
|
|
|
|
|
|
void allocate_inode (long entry_num)
|
|
|
|
{
|
|
unsigned char bit_mask=1;
|
|
int byte_offset,j;
|
|
|
|
byte_offset=entry_num/8;
|
|
for (j=0;j<entry_num%8;j++)
|
|
bit_mask*=2;
|
|
type_data.u.buffer [byte_offset] |= bit_mask;
|
|
}
|
|
|
|
void deallocate_inode (long entry_num)
|
|
|
|
{
|
|
unsigned char bit_mask=1;
|
|
int byte_offset,j;
|
|
|
|
byte_offset=entry_num/8;
|
|
for (j=0;j<entry_num%8;j++)
|
|
bit_mask*=2;
|
|
bit_mask^=0xff;
|
|
|
|
type_data.u.buffer [byte_offset] &= bit_mask;
|
|
}
|
|
|
|
void type_ext2_inode_bitmap___show (char *command_line)
|
|
|
|
{
|
|
int i,j;
|
|
unsigned char *ptr;
|
|
unsigned long inode_num,entry_num;
|
|
|
|
ptr=type_data.u.buffer;
|
|
show_pad_info.line=0;show_pad_info.max_line=-1;
|
|
|
|
wmove (show_pad,0,0);
|
|
for (i=0,entry_num=0;i<file_system_info.super_block.s_inodes_per_group/8;i++,ptr++) {
|
|
for (j=1;j<=128;j*=2) {
|
|
if (entry_num==inode_bitmap_info.entry_num) {
|
|
wattrset (show_pad,A_REVERSE);
|
|
show_pad_info.line=show_pad_info.max_line-show_pad_info.display_lines/2;
|
|
}
|
|
|
|
if ((*ptr) & j)
|
|
wprintw (show_pad,"1");
|
|
else
|
|
wprintw (show_pad,"0");
|
|
|
|
if (entry_num==inode_bitmap_info.entry_num)
|
|
wattrset (show_pad,A_NORMAL);
|
|
|
|
entry_num++;
|
|
}
|
|
wprintw (show_pad," ");
|
|
if (i%8==7) {
|
|
wprintw (show_pad,"\n");
|
|
show_pad_info.max_line++;
|
|
}
|
|
}
|
|
|
|
if (i%8!=7) {
|
|
wprintw (show_pad,"\n");
|
|
show_pad_info.max_line++;
|
|
}
|
|
|
|
refresh_show_pad ();
|
|
show_info ();
|
|
wmove (show_win,1,0);wprintw (show_win,"Inode bitmap of block group %ld\n",inode_bitmap_info.group_num);
|
|
|
|
inode_num=1+inode_bitmap_info.entry_num+inode_bitmap_info.group_num*file_system_info.super_block.s_inodes_per_group;
|
|
wprintw (show_win,"Status of inode %ld - ",inode_num);
|
|
ptr=type_data.u.buffer+inode_bitmap_info.entry_num/8;
|
|
j=1;
|
|
for (i=inode_bitmap_info.entry_num % 8;i>0;i--)
|
|
j*=2;
|
|
if ((*ptr) & j)
|
|
wprintw (show_win,"Allocated\n");
|
|
else
|
|
wprintw (show_win,"Free\n");
|
|
refresh_show_win ();
|
|
}
|