134 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef jffs2_private_h
 | |
| #define jffs2_private_h
 | |
| 
 | |
| #include <jffs2/jffs2.h>
 | |
| 
 | |
| struct b_node {
 | |
| 	struct b_node *next;
 | |
| };
 | |
| 
 | |
| struct b_inode {
 | |
| 	struct b_inode *next;
 | |
| 	u32 offset;	/* physical offset to beginning of real inode */
 | |
| 	u32 version;
 | |
| 	u32 ino;
 | |
| 	u32 isize;
 | |
| 	u32 csize;
 | |
| };
 | |
| 
 | |
| struct b_dirent {
 | |
| 	struct b_dirent *next;
 | |
| 	u32 offset;	/* physical offset to beginning of real dirent */
 | |
| 	u32 version;
 | |
| 	u32 pino;
 | |
| 	u32 ino;
 | |
| 	unsigned int nhash;
 | |
| 	unsigned char nsize;
 | |
| 	unsigned char type;
 | |
| };
 | |
| 
 | |
| struct b_list {
 | |
| 	struct b_node *listTail;
 | |
| 	struct b_node *listHead;
 | |
| 	unsigned int listCount;
 | |
| 	struct mem_block *listMemBase;
 | |
| };
 | |
| 
 | |
| struct b_lists {
 | |
| 	char *partOffset;
 | |
| 	struct b_list dir;
 | |
| 	struct b_list frag;
 | |
| };
 | |
| 
 | |
| struct b_compr_info {
 | |
| 	u32 num_frags;
 | |
| 	u32 compr_sum;
 | |
| 	u32 decompr_sum;
 | |
| };
 | |
| 
 | |
| struct b_jffs2_info {
 | |
| 	struct b_compr_info compr_info[JFFS2_NUM_COMPR];
 | |
| };
 | |
| 
 | |
| static inline int
 | |
| hdr_crc(struct jffs2_unknown_node *node)
 | |
| {
 | |
| #if 1
 | |
| 	u32 crc = crc32_no_comp(0, (unsigned char *)node, sizeof(struct jffs2_unknown_node) - 4);
 | |
| #else
 | |
| 	/* what's the semantics of this? why is this here? */
 | |
| 	u32 crc = crc32_no_comp(~0, (unsigned char *)node, sizeof(struct jffs2_unknown_node) - 4);
 | |
| 
 | |
| 	crc ^= ~0;
 | |
| #endif
 | |
| 	if (node->hdr_crc != crc) {
 | |
| 		return 0;
 | |
| 	} else {
 | |
| 		return 1;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static inline int
 | |
| dirent_crc(struct jffs2_raw_dirent *node)
 | |
| {
 | |
| 	if (node->node_crc != crc32_no_comp(0, (unsigned char *)node, sizeof(struct jffs2_raw_dirent) - 8)) {
 | |
| 		return 0;
 | |
| 	} else {
 | |
| 		return 1;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static inline int
 | |
| dirent_name_crc(struct jffs2_raw_dirent *node)
 | |
| {
 | |
| 	if (node->name_crc != crc32_no_comp(0, (unsigned char *)&(node->name), node->nsize)) {
 | |
| 		return 0;
 | |
| 	} else {
 | |
| 		return 1;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static inline int
 | |
| inode_crc(struct jffs2_raw_inode *node)
 | |
| {
 | |
| 	if (node->node_crc != crc32_no_comp(0, (unsigned char *)node, sizeof(struct jffs2_raw_inode) - 8)) {
 | |
| 		return 0;
 | |
| 	} else {
 | |
| 		return 1;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| /* Borrowed from include/linux/dcache.h */
 | |
| 
 | |
| /* Name hashing routines. Initial hash value */
 | |
| /* Hash courtesy of the R5 hash in reiserfs modulo sign bits */
 | |
| #define init_name_hash()		0
 | |
| 
 | |
| /* partial hash update function. Assume roughly 4 bits per character */
 | |
| static inline unsigned long
 | |
| partial_name_hash(unsigned long c, unsigned long prevhash)
 | |
| {
 | |
| 	return (prevhash + (c << 4) + (c >> 4)) * 11;
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Finally: cut down the number of bits to a int value (and try to avoid
 | |
|  * losing bits)
 | |
|  */
 | |
| static inline unsigned long end_name_hash(unsigned long hash)
 | |
| {
 | |
| 	return (unsigned int) hash;
 | |
| }
 | |
| 
 | |
| /* Compute the hash for a name string. */
 | |
| static inline unsigned int
 | |
| full_name_hash(const unsigned char *name, unsigned int len)
 | |
| {
 | |
| 	unsigned long hash = init_name_hash();
 | |
| 	while (len--)
 | |
| 		hash = partial_name_hash(*name++, hash);
 | |
| 	return end_name_hash(hash);
 | |
| }
 | |
| 
 | |
| #endif /* jffs2_private.h */
 | 
