1*53ee8cc1Swenshuai.xi #ifndef __CRAMFS_H 2*53ee8cc1Swenshuai.xi #define __CRAMFS_H 3*53ee8cc1Swenshuai.xi 4*53ee8cc1Swenshuai.xi #include <linux/types.h> 5*53ee8cc1Swenshuai.xi 6*53ee8cc1Swenshuai.xi #define CRAMFS_MAGIC 0x28cd3d45 /* some random number */ 7*53ee8cc1Swenshuai.xi #define CRAMFS_MAGIC_WEND 0x453dcd28 /* magic number with the wrong endianess */ 8*53ee8cc1Swenshuai.xi #define CRAMFS_SIGNATURE "Compressed ROMFS" 9*53ee8cc1Swenshuai.xi 10*53ee8cc1Swenshuai.xi /* 11*53ee8cc1Swenshuai.xi * Width of various bitfields in struct cramfs_inode. 12*53ee8cc1Swenshuai.xi * Primarily used to generate warnings in mkcramfs. 13*53ee8cc1Swenshuai.xi */ 14*53ee8cc1Swenshuai.xi #define CRAMFS_MODE_WIDTH 16 15*53ee8cc1Swenshuai.xi #define CRAMFS_UID_WIDTH 16 16*53ee8cc1Swenshuai.xi #define CRAMFS_SIZE_WIDTH 24 17*53ee8cc1Swenshuai.xi #define CRAMFS_GID_WIDTH 8 18*53ee8cc1Swenshuai.xi #define CRAMFS_NAMELEN_WIDTH 6 19*53ee8cc1Swenshuai.xi #define CRAMFS_OFFSET_WIDTH 26 20*53ee8cc1Swenshuai.xi 21*53ee8cc1Swenshuai.xi /* 22*53ee8cc1Swenshuai.xi * Since inode.namelen is a unsigned 6-bit number, the maximum cramfs 23*53ee8cc1Swenshuai.xi * path length is 63 << 2 = 252. 24*53ee8cc1Swenshuai.xi */ 25*53ee8cc1Swenshuai.xi #define CRAMFS_MAXPATHLEN (((1 << CRAMFS_NAMELEN_WIDTH) - 1) << 2) 26*53ee8cc1Swenshuai.xi 27*53ee8cc1Swenshuai.xi /* 28*53ee8cc1Swenshuai.xi * Reasonably terse representation of the inode data. 29*53ee8cc1Swenshuai.xi */ 30*53ee8cc1Swenshuai.xi struct cramfs_inode { 31*53ee8cc1Swenshuai.xi __u32 mode:CRAMFS_MODE_WIDTH, uid:CRAMFS_UID_WIDTH; 32*53ee8cc1Swenshuai.xi /* SIZE for device files is i_rdev */ 33*53ee8cc1Swenshuai.xi __u32 size:CRAMFS_SIZE_WIDTH, gid:CRAMFS_GID_WIDTH; 34*53ee8cc1Swenshuai.xi /* NAMELEN is the length of the file name, divided by 4 and 35*53ee8cc1Swenshuai.xi rounded up. (cramfs doesn't support hard links.) */ 36*53ee8cc1Swenshuai.xi /* OFFSET: For symlinks and non-empty regular files, this 37*53ee8cc1Swenshuai.xi contains the offset (divided by 4) of the file data in 38*53ee8cc1Swenshuai.xi compressed form (starting with an array of block pointers; 39*53ee8cc1Swenshuai.xi see README). For non-empty directories it is the offset 40*53ee8cc1Swenshuai.xi (divided by 4) of the inode of the first file in that 41*53ee8cc1Swenshuai.xi directory. For anything else, offset is zero. */ 42*53ee8cc1Swenshuai.xi __u32 namelen:CRAMFS_NAMELEN_WIDTH, offset:CRAMFS_OFFSET_WIDTH; 43*53ee8cc1Swenshuai.xi }; 44*53ee8cc1Swenshuai.xi 45*53ee8cc1Swenshuai.xi struct cramfs_info { 46*53ee8cc1Swenshuai.xi __u32 crc; 47*53ee8cc1Swenshuai.xi __u32 edition; 48*53ee8cc1Swenshuai.xi __u32 blocks; 49*53ee8cc1Swenshuai.xi __u32 files; 50*53ee8cc1Swenshuai.xi }; 51*53ee8cc1Swenshuai.xi 52*53ee8cc1Swenshuai.xi /* 53*53ee8cc1Swenshuai.xi * Superblock information at the beginning of the FS. 54*53ee8cc1Swenshuai.xi */ 55*53ee8cc1Swenshuai.xi struct cramfs_super { 56*53ee8cc1Swenshuai.xi __u32 magic; /* 0x28cd3d45 - random number */ 57*53ee8cc1Swenshuai.xi __u32 size; /* length in bytes */ 58*53ee8cc1Swenshuai.xi __u32 flags; /* feature flags */ 59*53ee8cc1Swenshuai.xi __u32 future; /* reserved for future use */ 60*53ee8cc1Swenshuai.xi __u8 signature[16]; /* "Compressed ROMFS" */ 61*53ee8cc1Swenshuai.xi struct cramfs_info fsid; /* unique filesystem info */ 62*53ee8cc1Swenshuai.xi __u8 name[16]; /* user-defined name */ 63*53ee8cc1Swenshuai.xi struct cramfs_inode root; /* root inode data */ 64*53ee8cc1Swenshuai.xi }; 65*53ee8cc1Swenshuai.xi 66*53ee8cc1Swenshuai.xi /* 67*53ee8cc1Swenshuai.xi * Feature flags 68*53ee8cc1Swenshuai.xi * 69*53ee8cc1Swenshuai.xi * 0x00000000 - 0x000000ff: features that work for all past kernels 70*53ee8cc1Swenshuai.xi * 0x00000100 - 0xffffffff: features that don't work for past kernels 71*53ee8cc1Swenshuai.xi */ 72*53ee8cc1Swenshuai.xi #define CRAMFS_FLAG_FSID_VERSION_2 0x00000001 /* fsid version #2 */ 73*53ee8cc1Swenshuai.xi #define CRAMFS_FLAG_SORTED_DIRS 0x00000002 /* sorted dirs */ 74*53ee8cc1Swenshuai.xi #define CRAMFS_FLAG_HOLES 0x00000100 /* support for holes */ 75*53ee8cc1Swenshuai.xi #define CRAMFS_FLAG_WRONG_SIGNATURE 0x00000200 /* reserved */ 76*53ee8cc1Swenshuai.xi #define CRAMFS_FLAG_SHIFTED_ROOT_OFFSET 0x00000400 /* shifted root fs */ 77*53ee8cc1Swenshuai.xi 78*53ee8cc1Swenshuai.xi /* 79*53ee8cc1Swenshuai.xi * Valid values in super.flags. Currently we refuse to mount 80*53ee8cc1Swenshuai.xi * if (flags & ~CRAMFS_SUPPORTED_FLAGS). Maybe that should be 81*53ee8cc1Swenshuai.xi * changed to test super.future instead. 82*53ee8cc1Swenshuai.xi */ 83*53ee8cc1Swenshuai.xi #define CRAMFS_SUPPORTED_FLAGS ( 0x000000ff \ 84*53ee8cc1Swenshuai.xi | CRAMFS_FLAG_HOLES \ 85*53ee8cc1Swenshuai.xi | CRAMFS_FLAG_WRONG_SIGNATURE \ 86*53ee8cc1Swenshuai.xi | CRAMFS_FLAG_SHIFTED_ROOT_OFFSET ) 87*53ee8cc1Swenshuai.xi 88*53ee8cc1Swenshuai.xi /* Uncompression interfaces to the underlying zlib */ 89*53ee8cc1Swenshuai.xi int cramfs_uncompress_block(void *dst, int dstlen, void *src, int srclen); 90*53ee8cc1Swenshuai.xi int cramfs_uncompress_init(void); 91*53ee8cc1Swenshuai.xi void cramfs_uncompress_exit(void); 92*53ee8cc1Swenshuai.xi 93*53ee8cc1Swenshuai.xi #endif 94