use GuangZhe's version of fs.h

This commit is contained in:
WangZiao 2023-11-12 13:55:12 -08:00
parent 3d959eeeb1
commit da703c02f0

View File

@ -9,10 +9,8 @@ one inode equipped with one 512 bytes block
*****************************************************/ *****************************************************/
#define SECTOR_SIZE 512 #define SECTOR_SIZE 512
#define IO_BLOCK_SIZE 4096 #define IO_BLOCK_SIZE 4096
#define MAX_INODE 2048 #define MAX_INODE 524288
// 524288 #define MAX_BLOCKNUM MAX_INODE*2 //62914560
#define MAX_BLOCKNUM 51200
// 1GB Disk: 2097152 = 196512 IO_BLOCK's. MAX_INODE*2 //62914560
class SuperBlock{ class SuperBlock{
@ -172,8 +170,8 @@ public:
} }
} }
if (!notFull){ if (!notFull){
printf("HEADER REMOVAL DETECTED %llu %llu\n", freeListHead, freeBlockNum);
u_int64_t next_header = read_byte_at(0, buffer); u_int64_t next_header = read_byte_at(0, buffer);
printf("HEADER MOVE (Cause: Alloc) %llu -> %llu (%llu)\n", freeListHead, next_header, freeBlockNum);
SuperBlock::writeFreeListHead(disk, next_header); SuperBlock::writeFreeListHead(disk, next_header);
} }
return freeBlockNum; return freeBlockNum;
@ -278,26 +276,22 @@ public:
// find the related 2048block head // find the related 2048block head
u_int64_t freeBlockHead = ((freeBlockNum/SECTOR_SIZE-MAX_INODE)/(8*2048)*(8*2048)+MAX_INODE)*SECTOR_SIZE; u_int64_t freeBlockHead = ((freeBlockNum/SECTOR_SIZE-MAX_INODE)/(8*2048)*(8*2048)+MAX_INODE)*SECTOR_SIZE;
// mark it alive in its bitmap
char buffer[IO_BLOCK_SIZE] = {0}; char buffer[IO_BLOCK_SIZE] = {0};
bool nowInList = false; bool nowInList = false;
disk.rawdisk_read(freeBlockHead, buffer, sizeof(buffer)); disk.rawdisk_read(freeBlockHead, buffer, sizeof(buffer));
// mark it alive in its bitmap
u_int64_t inBlockPos = (freeBlockNum-freeBlockHead)/IO_BLOCK_SIZE-1;
buffer[8+inBlockPos/8] &= (-1)^(1<<(inBlockPos%8));
bool notEmpty = false;
for (int i = 8; i < 264; i++){ for (int i = 8; i < 264; i++){
if((i < 263 && buffer[i] != -1) || (i == 263 && buffer[i] != 127)){ if((i < 263 && buffer[i] != -1) || (i == 263 && buffer[i] != 127)){
nowInList = true; nowInList = true;
} }
} }
u_int64_t inBlockPos = (freeBlockNum-freeBlockHead)/IO_BLOCK_SIZE-1;
buffer[8+inBlockPos/8] &= (-1)^(1<<(inBlockPos%8));
// if its bitmap was 0, add it back to the list head // if its bitmap was 0, add it back to the list head
if(!nowInList){ if(!nowInList){
u_int64_t freeListHead = SuperBlock::getFreeListHead(disk); u_int64_t freeListHead = SuperBlock::getFreeListHead(disk);
write_byte_at(freeListHead, 0, buffer); write_byte_at(freeListHead, 0, buffer);
printf("HEADER MOVE (Cause: Dealloc) %llu -> %llu\n", freeListHead, freeBlockHead);
SuperBlock::writeFreeListHead(disk, freeBlockHead); SuperBlock::writeFreeListHead(disk, freeBlockHead);
} }
disk.rawdisk_write(freeBlockHead, buffer, sizeof(buffer)); disk.rawdisk_write(freeBlockHead, buffer, sizeof(buffer));
@ -318,7 +312,6 @@ public:
addr = 0; addr = 0;
write_byte_at(addr, i, buffer); write_byte_at(addr, i, buffer);
delpoint = i; delpoint = i;
//printf("delpoint: %d\n", delpoint);
break; break;
} }
} }
@ -392,10 +385,8 @@ public:
freeBlockNum = deallo_triple_indirect(disk, triple_indirect); freeBlockNum = deallo_triple_indirect(disk, triple_indirect);
if(!freeBlockNum){ if(!freeBlockNum){
freeBlockNum = deallo_double_indirect(disk, double_indirect); freeBlockNum = deallo_double_indirect(disk, double_indirect);
//printf("In fs.h, Inode::datablock_deallocate: finished dealloc double indirect, got %lld\n", freeBlockNum);
if(!freeBlockNum){ if(!freeBlockNum){
freeBlockNum = deallo_single_indirect(disk, single_indirect); freeBlockNum = deallo_single_indirect(disk, single_indirect);
//printf("In fs.h, Inode::datablock_deallocate: finished dealloc single indirect, got %lld\n", freeBlockNum);
if(!freeBlockNum){ if(!freeBlockNum){
for(int i = 47; i>=0; i--) for(int i = 47; i>=0; i--)
if(blocks[i] != 0){ if(blocks[i] != 0){