2.//清除所给块的位图信息
void yaffs_clear_chunk_bits(struct yaffs_dev *dev, int blk)
{
u8 *blk_bits = yaffs_block_bits(dev, blk);
memset(blk_bits, 0, dev->chunk_bit_stride);
}
3.void yaffs_verify_chunk_bit_id(struct yaffs_dev *dev, int blk, int chunk)//验证该页是否存在
4.//清除某块的对应的具体某一位(也就是页)
void yaffs_clear_chunk_bit(struct yaffs_dev *dev, int blk, int chunk)
{u8 *blk_bits = yaffs_block_bits(dev, blk);
yaffs_verify_chunk_bit_id(dev, blk, chunk);
blk_bits[chunk / 8] &= ~(1 << (chunk & 7));
}
5.//设置该页的某一位
void yaffs_set_chunk_bit(struct yaffs_dev *dev, int blk, int chunk)
{u8 *blk_bits = yaffs_block_bits(dev, blk);
yaffs_verify_chunk_bit_id(dev, blk, chunk);
blk_bits[chunk / 8] |= (1 << (chunk & 7));
}
6.int yaffs_check_chunk_bit(struct yaffs_dev *dev, int blk, int chunk)//检查对应的chunk位
{u8 *blk_bits = yaffs_block_bits(dev, blk);
yaffs_verify_chunk_bit_id(dev, blk, chunk);
return (blk_bits[chunk / 8] & (1 << (chunk & 7))) ? 1 : 0;
}
7.int yaffs_still_some_chunks(struct yaffs_dev *dev, int blk)//检查是否有一些未使用的页,如果存在返回1,不存在返回0
8.int yaffs_count_chunk_bits(struct yaffs_dev *dev, int blk)//??????
{
u8 *blk_bits = yaffs_block_bits(dev, blk);
int i;
int n = 0;
for (i = 0; i < dev->chunk_bit_stride; i++, blk_bits++)
n += hweight8(*blk_bits);
return n;
}
//chunkbits和chunkBitmapStride是两个很有意思的东西,正是它们组成了整个nandflash的位图架构,对于一块有32页的nandflash,这里的chunkBitmapStride是4,而chunkbits是8位的,这样刚好4*8=32,也就是每一个位对应了nandflash中一个page,当然在系统挂载初始化的时候会为每一个块都分配,也就是说在首地址是chunkbits中的每一个位都对应了nandflash的一页,当然一个地址对应8页。
系统在设备描述结构yaffs_Device中维护着一张位图,该位图的每一位都代表着Flash上的一个chunk的状态。yaffs_SetChunkBit()将刚分配得到的chunk在位图中的对应位置1,表明该块已被使用。更新一些统计量后,就可以返回了。