1 Star 2 Fork 1

ZhouHeyu/Mix-SSD

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
flash.h 12.59 KB
一键复制 编辑 原始数据 按行查看 历史
ZhouHeyu 提交于 2018-12-17 14:25 . debuging
/*
* Contributors: Youngjae Kim (youkim@cse.psu.edu)
* Aayush Gupta (axg354@cse.psu.edu)
*
* In case if you have any doubts or questions, kindly write to: youkim@cse.psu.edu
*
* Description: This is a header file for flash.c.
*
* Acknowledgement: We thank Jeong Uk Kang by sharing the initial version
* of sector-level FTL source code.
*
*/
#ifndef SSD_LAYOUT
#define SSD_LAYOUT
#include "type.h"
#define MIN_FREE_BLK_NUM 30
#define LB_SIZE_512 1
#define LB_SIZE_1024 2
#define LB_SIZE_2048 4
/*origin code page is 2K(4sects),block is 128K(64 pages)*/
/***************NAND flash******************/
#define SECT_NUM_PER_PAGE 4
#define PAGE_NUM_PER_BLK 64
#define SECT_NUM_PER_BLK (SECT_NUM_PER_PAGE * PAGE_NUM_PER_BLK)
#define SECT_SIZE_B 512
#define SECT_BITS 2
#define PAGE_BITS 6
#define PAGE_SECT_BITS 8
#define BLK_BITS 24
#define NAND_STATE_FREE -1
#define NAND_STATE_INVALID -2
#define SECT_MASK_IN_SECT 0x0003
#define PAGE_MASK_IN_SECT 0x00FC
#define PAGE_SECT_MASK_IN_SECT 0x00FF
#define BLK_MASK_IN_SECT 0xFFFFFF00
#define PAGE_BITS_IN_PAGE 0x003F
#define BLK_MASK_IN_PAGE 0x3FFFFFC0
#define PAGE_SIZE_B (SECT_SIZE_B * SECT_NUM_PER_PAGE)
#define PAGE_SIZE_KB (PAGE_SIZE_B / 1024)
#define BLK_SIZE_B (PAGE_SIZE_B * PAGE_NUM_PER_BLK)
#define BLK_SIZE_KB (BLK_SIZE_B / 1024)
#define BLK_NO_SECT(sect) (((sect) & BLK_MASK_IN_SECT) >> (PAGE_BITS + SECT_BITS))
#define PAGE_NO_SECT(sect) (((sect) & PAGE_MASK_IN_SECT) >> SECT_BITS)
#define SECT_NO_SECT(sect) ((sect) & SECT_MASK_IN_SECT)
#define BLK_PAGE_NO_SECT(sect) ((sect) >> SECT_BITS)
#define PAGE_SECT_NO_SECT(sect) ((sect) & PAGE_SECT_MASK_IN_SECT)
#define BLK_NO_PAGE(page) (((page) & BLK_MASK_IN_PAGE) >> PAGE_BITS)
#define PAGE_NO_PAGE(page) ((page) & PAGE_MASK_IN_PAGE)
#define SECTOR(blk, page) (((blk) << PAGE_SECT_BITS) | (page))
#define BLK_MASK_SECT 0x3FFFFF00
#define PGE_MASK_SECT 0x000000FC
#define OFF_MASK_SECT 0x00000003
#define IND_MASK_SECT (PGE_MASK_SECT | OFF_MASK_SECT)
#define BLK_BITS_SECT 22
#define PGE_BITS_SECT 6
#define OFF_BITS_SECT 2
#define IND_BITS_SECT (PGE_BITS_SECT + OFF_BITS_SECT)
#define BLK_F_SECT(sect) (((sect) & BLK_MASK_SECT) >> IND_BITS_SECT)
#define PGE_F_SECT(sect) (((sect) & PGE_MASK_SECT) >> OFF_BITS_SECT)
#define OFF_F_SECT(sect) (((sect) & OFF_MASK_SECT))
#define PNI_F_SECT(sect) (((sect) & (~OFF_MASK_SECT)) >> OFF_BITS_SECT)
#define IND_F_SECT(sect) (((sect) & IND_MASK_SECT))
#define IS_SAME_BLK(s1, s2) (((s1) & BLK_MASK_SECT) == ((s2) & BLK_MASK_SECT))
#define IS_SAME_PAGE(s1, s2) (((s1) & (~OFF_MASK_SECT)) == ((s2) & (~OFF_MASK_SECT)))
/*****************************************/
/*SLC page is 2K(4sects),block is 128K(64 pages)*/
/***************SLC flash******************/
#define S_SECT_NUM_PER_PAGE 4
#define S_PAGE_NUM_PER_BLK 64
#define S_SECT_NUM_PER_BLK (S_SECT_NUM_PER_PAGE * S_PAGE_NUM_PER_BLK)
#define SECT_SIZE_B 512
#define S_SECT_BITS 2
#define S_PAGE_BITS 6
#define S_PAGE_SECT_BITS 8
#define S_BLK_BITS 24
#define NAND_STATE_FREE -1
#define NAND_STATE_INVALID -2
#define S_SECT_MASK_IN_SECT 0x0003
#define S_PAGE_MASK_IN_SECT 0x00FC
#define S_PAGE_SECT_MASK_IN_SECT 0x00FF
#define S_BLK_MASK_IN_SECT 0xFFFFFF00
#define S_PAGE_BITS_IN_PAGE 0x003F
#define S_BLK_MASK_IN_PAGE 0x3FFFFFC0
#define S_PAGE_SIZE_B (SECT_SIZE_B * S_SECT_NUM_PER_PAGE)
#define S_PAGE_SIZE_KB (S_PAGE_SIZE_B / 1024)
#define S_BLK_SIZE_B (S_PAGE_SIZE_B * S_PAGE_NUM_PER_BLK)
#define S_BLK_SIZE_KB (S_BLK_SIZE_B / 1024)
#define S_BLK_NO_SECT(sect) (((sect) & S_BLK_MASK_IN_SECT) >> (S_PAGE_BITS + S_SECT_BITS))
#define S_PAGE_NO_SECT(sect) (((sect) & S_PAGE_MASK_IN_SECT) >> S_SECT_BITS)
#define S_SECT_NO_SECT(sect) ((sect) & S_SECT_MASK_IN_SECT)
#define S_BLK_PAGE_NO_SECT(sect) ((sect) >> S_SECT_BITS)
#define S_PAGE_SECT_NO_SECT(sect) ((sect) & S_PAGE_SECT_MASK_IN_SECT)
#define S_BLK_NO_PAGE(page) (((page) & S_BLK_MASK_IN_PAGE) >> S_PAGE_BITS)
#define S_PAGE_NO_PAGE(page) ((page) & S_PAGE_MASK_IN_PAGE)
#define S_SECTOR(blk, page) (((blk) << S_PAGE_SECT_BITS) | (page))
#define S_BLK_MASK_SECT 0x3FFFFF00
#define S_PGE_MASK_SECT 0x000000FC
#define S_OFF_MASK_SECT 0x00000003
#define S_IND_MASK_SECT (S_PGE_MASK_SECT | S_OFF_MASK_SECT)
#define S_BLK_BITS_SECT 22
#define S_PGE_BITS_SECT 6
#define S_OFF_BITS_SECT 2
#define S_IND_BITS_SECT (S_PGE_BITS_SECT + S_OFF_BITS_SECT)
#define S_BLK_F_SECT(sect) (((sect) & S_BLK_MASK_SECT) >> S_IND_BITS_SECT)
#define S_PGE_F_SECT(sect) (((sect) & S_PGE_MASK_SECT) >> S_OFF_BITS_SECT)
#define S_OFF_F_SECT(sect) (((sect) & S_OFF_MASK_SECT))
#define S_PNI_F_SECT(sect) (((sect) & (~S_OFF_MASK_SECT)) >> S_OFF_BITS_SECT)
#define S_IND_F_SECT(sect) (((sect) & S_IND_MASK_SECT))
#define S_IS_SAME_BLK(s1, s2) (((s1) & S_BLK_MASK_SECT) == ((s2) & S_BLK_MASK_SECT))
#define S_IS_SAME_PAGE(s1, s2) (((s1) & (~S_OFF_MASK_SECT)) == ((s2) & (~S_OFF_MASK_SECT)))
/*****************************************/
/*MLC page is 4K(8sects),block is 512K(128 pages)*/
/***************MLC flash******************/
#define M_SECT_NUM_PER_PAGE 8
#define M_PAGE_NUM_PER_BLK 128
#define M_SECT_NUM_PER_BLK (M_SECT_NUM_PER_PAGE * M_PAGE_NUM_PER_BLK)
#define UPN_SECT_BITS 3
#define M_SECT_BITS 3
#define M_PAGE_BITS 7
#define M_PAGE_SECT_BITS 10
#define M_BLK_BITS 22
#define M_SECT_MASK_IN_SECT 0x0007
#define M_PAGE_MASK_IN_SECT 0x03F8;
#define M_PAGE_SECT_MASK_IN_SECT 0x03FF //zj:一个块中所有的扇区数
#define M_BLK_MASK_IN_SECT 0xFFFFFC00//0xFFEF7C00 0xFFEFFC00 zj:从块号为4096开始
#define M_PAGE_BITS_IN_PAGE 0x007F //zj:128个页/block
#define M_BLK_MASK_IN_PAGE 0x3FFFFF80
#define M_PAGE_SIZE_B (SECT_SIZE_B * M_SECT_NUM_PER_PAGE)
#define M_PAGE_SIZE_KB (M_PAGE_SIZE_B / 1024)
#define M_BLK_SIZE_B (M_PAGE_SIZE_B * M_PAGE_NUM_PER_BLK)
#define M_BLK_SIZE_KB (M_BLK_SIZE_B / 1024)
#define M_BLK_NO_SECT(sect) (((sect) & M_BLK_MASK_IN_SECT) >> (M_PAGE_BITS + M_SECT_BITS))
#define M_PAGE_NO_SECT(sect) (((sect) & M_PAGE_MASK_IN_SECT) >> M_SECT_BITS)
#define M_SECT_NO_SECT(sect) ((sect) & M_SECT_MASK_IN_SECT)
#define M_BLK_PAGE_NO_SECT(sect) ((sect) >> M_SECT_BITS)
#define UPN_BLK_PAGE_NO_SECT(sect) ((sect) >> UPN_SECT_BITS)
#define M_PAGE_SECT_NO_SECT(sect) ((sect) & M_PAGE_SECT_MASK_IN_SECT)
#define M_BLK_NO_PAGE(page) (((page) & M_BLK_MASK_IN_PAGE) >> M_PAGE_BITS)
#define M_PAGE_NO_PAGE(page) ((page) & M_PAGE_MASK_IN_PAGE)
#define M_SECTOR(blk, page) (((blk) << M_PAGE_SECT_BITS) | (page))
#define M_BLK_MASK_SECT 0x3FFFFC00//0x3FEF7C00
#define M_PGE_MASK_SECT 0x000003F8
#define M_OFF_MASK_SECT 0x00000007
#define M_IND_MASK_SECT (M_PGE_MASK_SECT | M_OFF_MASK_SECT)
#define M_BLK_BITS_SECT 22
#define M_PGE_BITS_SECT 7
#define M_OFF_BITS_SECT 3
#define M_IND_BITS_SECT (M_PGE_BITS_SECT + M_OFF_BITS_SECT)
#define M_BLK_F_SECT(sect) (((sect) & M_BLK_MASK_SECT) >> M_IND_BITS_SECT)
#define M_PGE_F_SECT(sect) (((sect) & M_PGE_MASK_SECT) >> M_OFF_BITS_SECT)
#define M_OFF_F_SECT(sect) (((sect) & M_OFF_MASK_SECT))
#define M_PNI_F_SECT(sect) (((sect) & (~M_OFF_MASK_SECT)) >> M_OFF_BITS_SECT)
#define M_IND_F_SECT(sect) (((sect) & M_IND_MASK_SECT))
#define M_IS_SAME_BLK(s1, s2) (((s1) & M_BLK_MASK_SECT) == ((s2) & M_BLK_MASK_SECT))
#define M_IS_SAME_PAGE(s1, s2) (((s1) & (~M_OFF_MASK_SECT)) == ((s2) & (~M_OFF_MASK_SECT)))
/*****************************************/
struct blk_state {
int free;
int ec;
int update_ec;
};
struct sect_state {
_u32 free : 1;
_u32 valid : 1;
_u32 lsn : 30;
};
struct nand_blk_info {
struct blk_state state; // Erase Conunter
struct sect_state sect[SECT_NUM_PER_BLK]; // Logical Sector Number
_s32 fpc : 10; // free page counter
_s32 ipc : 10; // invalide page counter
_s32 lwn : 12; // last written page number
int page_status[PAGE_NUM_PER_BLK];
};
/*add zhoujie 11-21*/
struct SLC_nand_blk_info {
struct blk_state state; // Erase Conunter
struct sect_state sect[S_SECT_NUM_PER_BLK]; // Logical Sector Number
_s32 fpc : 10; // free page counter
_s32 ipc : 10; // invalide page counter
_s32 lwn : 12; // last written page number
int page_status[S_PAGE_NUM_PER_BLK];
};
struct MLC_nand_blk_info {
struct blk_state state; // Erase Conunter
struct sect_state sect[M_SECT_NUM_PER_BLK]; // Logical Sector Number
_s32 fpc : 21; // free page counter
_s32 ipc : 21; // invalide page counter
_s32 lwn : 20; // last written page number
int page_status[M_PAGE_NUM_PER_BLK];
};
/*add zhoujie 11-21*/
extern _u32 nand_blk_num;
extern _u32 nand_SLC_blk_num;
extern _u32 nand_MLC_blk_num;
extern _u8 pb_size;
extern struct nand_blk_info *nand_blk;
extern struct SLC_nand_blk_info *SLC_nand_blk;
extern struct MLC_nand_blk_info *MLC_nand_blk;
extern FILE *fp_erase;
int nand_init (_u32 blk_num, _u8 min_free_blk_num);
void nand_end ();
_u8 nand_page_read (_u32 psn, _u32 *lsns, _u8 isGC);
_u8 nand_page_write (_u32 psn, _u32 *lsns, _u8 isGC, int map_flag);
void nand_erase (_u32 blk_no);
void nand_invalidate (_u32 psn, _u32 lsn);
_u32 nand_get_free_blk(int);
void nand_stat(int);
void nand_stat_reset();
void nand_stat_print(FILE *outFP);
void nand_ecn_print(FILE *outFP);
int nand_oob_read(_u32 psn);
/*************Mix SSD add Function*********************/
//read page content (the lsn)
_u8 MLC_nand_page_read(_u32 psn, _u32 *lsns, _u8 isGC);
_u8 SLC_nand_page_read(_u32 psn, _u32 *lsns, _u8 isGC);
//write attention to sect size
_u8 SLC_nand_page_write(_u32 psn, _u32 *lsns, _u8 isGC, int map_flag);
_u8 MLC_nand_page_write(_u32 psn, _u32 *lsns, _u8 isGC, int map_flag);
//erase is same
void MLC_nand_erase (_u32 blk_no);
void SLC_nand_erase (_u32 blk_no);
//invalidate page
void MLC_nand_invalidate (_u32 psn, _u32 lsn);
void SLC_nand_invalidate (_u32 psn, _u32 lsn);
//sure page state read oob
int MLC_nand_oob_read(_u32 psn);
int SLC_nand_oob_read(_u32 psn);
//get free blk (wear level alogrithm can insert)
_u32 SLC_nand_get_free_blk (int isGC);
_u32 MLC_nand_get_free_blk (int isGC);
//same base function(init;end;reset;print)
int Mix_nand_init (_u32 SLC_blk_num,_u32 MLC_blk_num, _u8 min_free_blk_num);
void Mix_nand_end ();
void Mix_nand_stat_reset();
void Mix_nand_stat_print(FILE *outFP);
_u8 SLC_nand_4K_data_page_write(_u32 psn, _u32 *lsns, _u8 isGC, int map_flag);
_u8 SLC_nand_4K_data_page_read(_u32 psn, _u32 *lsns, _u8 isGC);
/**************************
* Date :04.12.2018
* Author:zhoujie
* goal: to match IRRFTL when slc gc to check valid ppn is cold or hot
*************************/
//-1:not in cmt;0 in rcmt; 1 in cold-wcmt;2 in hot-wcmt
extern int * SLC_ppn_status;
int SLC_ppn_num;
int SLC_to_MLC_num;
int SLC_to_SLC_num;
/*************Mix SSD add Function END*********************/
_u32 free_SLC_blk_num;
_u32 free_MLC_blk_num;
_u32 free_SLC_blk_idx;
_u32 free_MLC_blk_idx;
_u32 free_blk_num;
_u32 free_blk_idx;
/**************origin code static value*********************/
_u32 stat_read_num, stat_write_num, stat_erase_num;
_u32 stat_gc_read_num, stat_gc_write_num;
_u32 stat_oob_read_num, stat_oob_write_num;
/***********************************/
/**************SLC code static value*********************/
_u32 SLC_stat_read_num, SLC_stat_write_num, SLC_stat_erase_num;
_u32 SLC_stat_gc_read_num, SLC_stat_gc_write_num;
_u32 SLC_stat_oob_read_num, SLC_stat_oob_write_num;
/***********************************/
/**************MLC code static value*********************/
_u32 MLC_stat_read_num, MLC_stat_write_num, MLC_stat_erase_num;
_u32 MLC_stat_gc_read_num, MLC_stat_gc_write_num;
_u32 MLC_stat_oob_read_num, MLC_stat_oob_write_num;
/***********************************/
//add zhoujie
/***********************************/
_u32 translate_map_write_num;
_u32 real_data_write_sect_num;
_u32 sup_data_write_sect_num;
_u32 SLC_IO_data_write_sect_num;
_u32 MLC_IO_data_write_sect_num;
/********************************/
extern _u32 min_fb_num;
//zhoujie add
//自己定义的磨损均衡阈值偏差
double my_wear_level_threshold;
extern double my_global_nand_blk_wear_ave;
extern double my_global_nand_blk_wear_std;
extern double my_global_nand_blk_wear_var;
int called_wear_num;
int last_called_wear_num;
void nand_blk_ecn_ave_static();
void nand_blk_ecn_std_var_static();
_u32 find_switch_cold_blk_method1(int victim_blkno);
_u32 find_switch_cold_blk_method2(int victim_blkno);
// add zhoujie 11-10
//添加辅助信息确定物理块的数据页的映射项是否存在于映射缓存中
int * nand_ppn_2_lpn_in_CMT_arr;
int * nand_pbn_2_lpn_in_CMT_arr;
//add zhoujie 11-16
//添加关于SW_level(2007年)算法的数据结构
int * SW_level_BET_arr;
int SW_level_BET_Size;
int SW_level_Ecnt;
int SW_level_Fcnt;
int SW_level_Findex;
int SW_level_reset_num;
int SW_level_GC_called_num;
void SW_Level_BET_Value_Reset();
extern int SW_level_K;
extern int SW_level_T;
#endif
//源码内部定义了磨损均衡度,但是没有使用?
#define WEAR_LEVEL_THRESHOLD 35
void flush(int);
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C
1
https://gitee.com/ZhouHeyu/Flashsim-origin.git
git@gitee.com:ZhouHeyu/Flashsim-origin.git
ZhouHeyu
Flashsim-origin
Mix-SSD
master

搜索帮助