⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fs.h

📁 基于组件方式开发操作系统的OSKIT源代码
💻 H
📖 第 1 页 / 共 2 页
字号:
/* * Filesystem clean flags */#define	FS_ISCLEAN	0x01#define	FS_WASCLEAN	0x02/* * Preference for optimization. */#define FS_OPTTIME	0	/* minimize allocation time */#define FS_OPTSPACE	1	/* minimize disk fragmentation *//* * Rotational layout table format types */#define FS_42POSTBLFMT		-1	/* 4.2BSD rotational table format */#define FS_DYNAMICPOSTBLFMT	1	/* dynamic rotational table format *//* * Macros for access to superblock array structures */#define fs_postbl(fs, cylno) \    (((fs)->fs_postblformat == FS_42POSTBLFMT) \    ? ((fs)->fs_opostbl[cylno]) \    : ((int16_t *)((u_int8_t *)(fs) + \	(fs)->fs_postbloff) + (cylno) * (fs)->fs_nrpos))#define fs_rotbl(fs) \    (((fs)->fs_postblformat == FS_42POSTBLFMT) \    ? ((fs)->fs_space) \    : ((u_int8_t *)((u_int8_t *)(fs) + (fs)->fs_rotbloff)))/* * The size of a cylinder group is calculated by CGSIZE. The maximum size * is limited by the fact that cylinder groups are at most one block. * Its size is derived from the size of the maps maintained in the * cylinder group and the (struct cg) size. */#define CGSIZE(fs) \    /* base cg */	(sizeof(struct cg) + sizeof(int32_t) + \    /* blktot size */	(fs)->fs_cpg * sizeof(int32_t) + \    /* blks size */	(fs)->fs_cpg * (fs)->fs_nrpos * sizeof(int16_t) + \    /* inode map */	howmany((fs)->fs_ipg, NBBY) + \    /* block map */	howmany((fs)->fs_cpg * (fs)->fs_spc / NSPF(fs), NBBY) +\    /* if present */	((fs)->fs_contigsumsize <= 0 ? 0 : \    /* cluster sum */	(fs)->fs_contigsumsize * sizeof(int32_t) + \    /* cluster map */	howmany((fs)->fs_cpg * (fs)->fs_spc / NSPB(fs), NBBY)))/* * Convert cylinder group to base address of its global summary info. * * N.B. This macro assumes that sizeof(struct csum) is a power of two. */#define fs_cs(fs, indx) \	fs_csp[(indx) >> (fs)->fs_csshift][(indx) & ~(fs)->fs_csmask]/* * Cylinder group block for a file system. */#define	CG_MAGIC	0x090255struct cg {	int32_t	 cg_firstfield;		/* historic cyl groups linked list */	int32_t	 cg_magic;		/* magic number */	time_t	 cg_time;		/* time last written */	int32_t	 cg_cgx;		/* we are the cgx'th cylinder group */	int16_t	 cg_ncyl;		/* number of cyl's this cg */	int16_t	 cg_niblk;		/* number of inode blocks this cg */	int32_t	 cg_ndblk;		/* number of data blocks this cg */	struct	csum cg_cs;		/* cylinder summary information */	int32_t	 cg_rotor;		/* position of last used block */	int32_t	 cg_frotor;		/* position of last used frag */	int32_t	 cg_irotor;		/* position of last used inode */	int32_t	 cg_frsum[MAXFRAG];	/* counts of available frags */	int32_t	 cg_btotoff;		/* (int32) block totals per cylinder */	int32_t	 cg_boff;		/* (u_int16) free block positions */	int32_t	 cg_iusedoff;		/* (u_int8) used inode map */	int32_t	 cg_freeoff;		/* (u_int8) free block map */	int32_t	 cg_nextfreeoff;	/* (u_int8) next available space */	int32_t	 cg_clustersumoff;	/* (u_int32) counts of avail clusters */	int32_t	 cg_clusteroff;		/* (u_int8) free cluster map */	int32_t	 cg_nclusterblks;	/* number of clusters this cg */	int32_t	 cg_sparecon[13];	/* reserved for future use */	u_int8_t cg_space[1];		/* space for cylinder group maps *//* actually longer */};/* * Macros for access to cylinder group array structures */#define cg_blktot(cgp) \    (((cgp)->cg_magic != CG_MAGIC) \    ? (((struct ocg *)(cgp))->cg_btot) \    : ((int32_t *)((u_int8_t *)(cgp) + (cgp)->cg_btotoff)))#define cg_blks(fs, cgp, cylno) \    (((cgp)->cg_magic != CG_MAGIC) \    ? (((struct ocg *)(cgp))->cg_b[cylno]) \    : ((int16_t *)((u_int8_t *)(cgp) + \	(cgp)->cg_boff) + (cylno) * (fs)->fs_nrpos))#define cg_inosused(cgp) \    (((cgp)->cg_magic != CG_MAGIC) \    ? (((struct ocg *)(cgp))->cg_iused) \    : ((u_int8_t *)((u_int8_t *)(cgp) + (cgp)->cg_iusedoff)))#define cg_blksfree(cgp) \    (((cgp)->cg_magic != CG_MAGIC) \    ? (((struct ocg *)(cgp))->cg_free) \    : ((u_int8_t *)((u_int8_t *)(cgp) + (cgp)->cg_freeoff)))#define cg_chkmagic(cgp) \    ((cgp)->cg_magic == CG_MAGIC || ((struct ocg *)(cgp))->cg_magic == CG_MAGIC)#define cg_clustersfree(cgp) \    ((u_int8_t *)((u_int8_t *)(cgp) + (cgp)->cg_clusteroff))#define cg_clustersum(cgp) \    ((int32_t *)((u_int8_t *)(cgp) + (cgp)->cg_clustersumoff))/* * The following structure is defined * for compatibility with old file systems. */struct ocg {	int32_t	 cg_firstfield;		/* historic linked list of cyl groups */	int32_t	 cg_unused_1;		/*     used for incore cyl groups */	time_t	 cg_time;		/* time last written */	int32_t	 cg_cgx;		/* we are the cgx'th cylinder group */	int16_t	 cg_ncyl;		/* number of cyl's this cg */	int16_t	 cg_niblk;		/* number of inode blocks this cg */	int32_t	 cg_ndblk;		/* number of data blocks this cg */	struct	csum cg_cs;		/* cylinder summary information */	int32_t	 cg_rotor;		/* position of last used block */	int32_t	 cg_frotor;		/* position of last used frag */	int32_t	 cg_irotor;		/* position of last used inode */	int32_t	 cg_frsum[8];		/* counts of available frags */	int32_t	 cg_btot[32];		/* block totals per cylinder */	int16_t	 cg_b[32][8];		/* positions of free blocks */	u_int8_t cg_iused[256];		/* used inode map */	int32_t	 cg_magic;		/* magic number */	u_int8_t cg_free[1];		/* free block map *//* actually longer */};/* * Turn file system block numbers into disk block addresses. * This maps file system blocks to device size blocks. */#define fsbtodb(fs, b)	((b) << (fs)->fs_fsbtodb)#define	dbtofsb(fs, b)	((b) >> (fs)->fs_fsbtodb)/* * Cylinder group macros to locate things in cylinder groups. * They calc file system addresses of cylinder group data structures. */#define	cgbase(fs, c)	((daddr_t)((fs)->fs_fpg * (c)))#define	cgdmin(fs, c)	(cgstart(fs, c) + (fs)->fs_dblkno)	/* 1st data */#define	cgimin(fs, c)	(cgstart(fs, c) + (fs)->fs_iblkno)	/* inode blk */#define	cgsblock(fs, c)	(cgstart(fs, c) + (fs)->fs_sblkno)	/* super blk */#define	cgtod(fs, c)	(cgstart(fs, c) + (fs)->fs_cblkno)	/* cg block */#define cgstart(fs, c)							\	(cgbase(fs, c) + (fs)->fs_cgoffset * ((c) & ~((fs)->fs_cgmask)))/* * Macros for handling inode numbers: *     inode number to file system block offset. *     inode number to cylinder group number. *     inode number to file system block address. */#define	ino_to_cg(fs, x)	((x) / (fs)->fs_ipg)#define	ino_to_fsba(fs, x)						\	((daddr_t)(cgimin(fs, ino_to_cg(fs, x)) +			\	    (blkstofrags((fs), (((x) % (fs)->fs_ipg) / INOPB(fs))))))#define	ino_to_fsbo(fs, x)	((x) % INOPB(fs))/* * Give cylinder group number for a file system block. * Give cylinder group block number for a file system block. */#define	dtog(fs, d)	((d) / (fs)->fs_fpg)#define	dtogd(fs, d)	((d) % (fs)->fs_fpg)/* * Extract the bits for a block from a map. * Compute the cylinder and rotational position of a cyl block addr. */#define blkmap(fs, map, loc) \    (((map)[(loc) / NBBY] >> ((loc) % NBBY)) & (0xff >> (NBBY - (fs)->fs_frag)))#define cbtocylno(fs, bno) \    ((bno) * NSPF(fs) / (fs)->fs_spc)#define cbtorpos(fs, bno) \    (((bno) * NSPF(fs) % (fs)->fs_spc / (fs)->fs_nsect * (fs)->fs_trackskew + \     (bno) * NSPF(fs) % (fs)->fs_spc % (fs)->fs_nsect * (fs)->fs_interleave) % \     (fs)->fs_nsect * (fs)->fs_nrpos / (fs)->fs_npsect)/* * The following macros optimize certain frequently calculated * quantities by using shifts and masks in place of divisions * modulos and multiplications. */#define blkoff(fs, loc)		/* calculates (loc % fs->fs_bsize) */ \	((loc) & (fs)->fs_qbmask)#define fragoff(fs, loc)	/* calculates (loc % fs->fs_fsize) */ \	((loc) & (fs)->fs_qfmask)#define lblktosize(fs, blk)	/* calculates (blk * fs->fs_bsize) */ \	((blk) << (fs)->fs_bshift)#define lblkno(fs, loc)		/* calculates (loc / fs->fs_bsize) */ \	((loc) >> (fs)->fs_bshift)#define numfrags(fs, loc)	/* calculates (loc / fs->fs_fsize) */ \	((loc) >> (fs)->fs_fshift)#define blkroundup(fs, size)	/* calculates roundup(size, fs->fs_bsize) */ \	(((size) + (fs)->fs_qbmask) & (fs)->fs_bmask)#define fragroundup(fs, size)	/* calculates roundup(size, fs->fs_fsize) */ \	(((size) + (fs)->fs_qfmask) & (fs)->fs_fmask)#define fragstoblks(fs, frags)	/* calculates (frags / fs->fs_frag) */ \	((frags) >> (fs)->fs_fragshift)#define blkstofrags(fs, blks)	/* calculates (blks * fs->fs_frag) */ \	((blks) << (fs)->fs_fragshift)#define fragnum(fs, fsb)	/* calculates (fsb % fs->fs_frag) */ \	((fsb) & ((fs)->fs_frag - 1))#define blknum(fs, fsb)		/* calculates rounddown(fsb, fs->fs_frag) */ \	((fsb) &~ ((fs)->fs_frag - 1))/* * Determine the number of available frags given a * percentage to hold in reserve. */#define freespace(fs, percentreserved) \	(blkstofrags((fs), (fs)->fs_cstotal.cs_nbfree) + \	(fs)->fs_cstotal.cs_nffree - ((fs)->fs_dsize * (percentreserved) / 100))/* * Determining the size of a file block in the file system. */#define blksize(fs, ip, lbn) \	(((lbn) >= NDADDR || (ip)->i_size >= ((lbn) + 1) << (fs)->fs_bshift) \	    ? (fs)->fs_bsize \	    : (fragroundup(fs, blkoff(fs, (ip)->i_size))))#define dblksize(fs, dip, lbn) \	(((lbn) >= NDADDR || (dip)->di_size >= ((lbn) + 1) << (fs)->fs_bshift) \	    ? (fs)->fs_bsize \	    : (fragroundup(fs, blkoff(fs, (dip)->di_size))))/* * Number of disk sectors per block/fragment; assumes DEV_BSIZE byte * sector size. */#define	NSPB(fs)	((fs)->fs_nspf << (fs)->fs_fragshift)#define	NSPF(fs)	((fs)->fs_nspf)/* * Number of inodes in a secondary storage block/fragment. */#define	INOPB(fs)	((fs)->fs_inopb)#define	INOPF(fs)	((fs)->fs_inopb >> (fs)->fs_fragshift)/* * Number of indirects in a file system block. */#define	NINDIR(fs)	((fs)->fs_nindir)extern int inside[], around[];extern u_char *fragtbl[];

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -