xref: /utopia/UTPA2-700.0.x/projects/tools/lint/mips-linux-gnu_include/linux/jffs2.h (revision 53ee8cc121a030b8d368113ac3e966b4705770ef)
1*53ee8cc1Swenshuai.xi /*
2*53ee8cc1Swenshuai.xi  * JFFS2 -- Journalling Flash File System, Version 2.
3*53ee8cc1Swenshuai.xi  *
4*53ee8cc1Swenshuai.xi  * Copyright (C) 2001-2003 Red Hat, Inc.
5*53ee8cc1Swenshuai.xi  *
6*53ee8cc1Swenshuai.xi  * Created by David Woodhouse <dwmw2@infradead.org>
7*53ee8cc1Swenshuai.xi  *
8*53ee8cc1Swenshuai.xi  * For licensing information, see the file 'LICENCE' in the
9*53ee8cc1Swenshuai.xi  * jffs2 directory.
10*53ee8cc1Swenshuai.xi  *
11*53ee8cc1Swenshuai.xi  * $Id: jffs2.h,v 1.38 2005/09/26 11:37:23 havasi Exp $
12*53ee8cc1Swenshuai.xi  *
13*53ee8cc1Swenshuai.xi  */
14*53ee8cc1Swenshuai.xi 
15*53ee8cc1Swenshuai.xi #ifndef __LINUX_JFFS2_H__
16*53ee8cc1Swenshuai.xi #define __LINUX_JFFS2_H__
17*53ee8cc1Swenshuai.xi 
18*53ee8cc1Swenshuai.xi #include <linux/magic.h>
19*53ee8cc1Swenshuai.xi 
20*53ee8cc1Swenshuai.xi /* You must include something which defines the C99 uintXX_t types.
21*53ee8cc1Swenshuai.xi    We don't do it from here because this file is used in too many
22*53ee8cc1Swenshuai.xi    different environments. */
23*53ee8cc1Swenshuai.xi 
24*53ee8cc1Swenshuai.xi /* Values we may expect to find in the 'magic' field */
25*53ee8cc1Swenshuai.xi #define JFFS2_OLD_MAGIC_BITMASK 0x1984
26*53ee8cc1Swenshuai.xi #define JFFS2_MAGIC_BITMASK 0x1985
27*53ee8cc1Swenshuai.xi #define KSAMTIB_CIGAM_2SFFJ 0x8519 /* For detecting wrong-endian fs */
28*53ee8cc1Swenshuai.xi #define JFFS2_EMPTY_BITMASK 0xffff
29*53ee8cc1Swenshuai.xi #define JFFS2_DIRTY_BITMASK 0x0000
30*53ee8cc1Swenshuai.xi 
31*53ee8cc1Swenshuai.xi /* Summary node MAGIC marker */
32*53ee8cc1Swenshuai.xi #define JFFS2_SUM_MAGIC	0x02851885
33*53ee8cc1Swenshuai.xi 
34*53ee8cc1Swenshuai.xi /* We only allow a single char for length, and 0xFF is empty flash so
35*53ee8cc1Swenshuai.xi    we don't want it confused with a real length. Hence max 254.
36*53ee8cc1Swenshuai.xi */
37*53ee8cc1Swenshuai.xi #define JFFS2_MAX_NAME_LEN 254
38*53ee8cc1Swenshuai.xi 
39*53ee8cc1Swenshuai.xi /* How small can we sensibly write nodes? */
40*53ee8cc1Swenshuai.xi #define JFFS2_MIN_DATA_LEN 128
41*53ee8cc1Swenshuai.xi 
42*53ee8cc1Swenshuai.xi #define JFFS2_COMPR_NONE	0x00
43*53ee8cc1Swenshuai.xi #define JFFS2_COMPR_ZERO	0x01
44*53ee8cc1Swenshuai.xi #define JFFS2_COMPR_RTIME	0x02
45*53ee8cc1Swenshuai.xi #define JFFS2_COMPR_RUBINMIPS	0x03
46*53ee8cc1Swenshuai.xi #define JFFS2_COMPR_COPY	0x04
47*53ee8cc1Swenshuai.xi #define JFFS2_COMPR_DYNRUBIN	0x05
48*53ee8cc1Swenshuai.xi #define JFFS2_COMPR_ZLIB	0x06
49*53ee8cc1Swenshuai.xi #define JFFS2_COMPR_LZO		0x07
50*53ee8cc1Swenshuai.xi /* Compatibility flags. */
51*53ee8cc1Swenshuai.xi #define JFFS2_COMPAT_MASK 0xc000      /* What do to if an unknown nodetype is found */
52*53ee8cc1Swenshuai.xi #define JFFS2_NODE_ACCURATE 0x2000
53*53ee8cc1Swenshuai.xi /* INCOMPAT: Fail to mount the filesystem */
54*53ee8cc1Swenshuai.xi #define JFFS2_FEATURE_INCOMPAT 0xc000
55*53ee8cc1Swenshuai.xi /* ROCOMPAT: Mount read-only */
56*53ee8cc1Swenshuai.xi #define JFFS2_FEATURE_ROCOMPAT 0x8000
57*53ee8cc1Swenshuai.xi /* RWCOMPAT_COPY: Mount read/write, and copy the node when it's GC'd */
58*53ee8cc1Swenshuai.xi #define JFFS2_FEATURE_RWCOMPAT_COPY 0x4000
59*53ee8cc1Swenshuai.xi /* RWCOMPAT_DELETE: Mount read/write, and delete the node when it's GC'd */
60*53ee8cc1Swenshuai.xi #define JFFS2_FEATURE_RWCOMPAT_DELETE 0x0000
61*53ee8cc1Swenshuai.xi 
62*53ee8cc1Swenshuai.xi #define JFFS2_NODETYPE_DIRENT (JFFS2_FEATURE_INCOMPAT | JFFS2_NODE_ACCURATE | 1)
63*53ee8cc1Swenshuai.xi #define JFFS2_NODETYPE_INODE (JFFS2_FEATURE_INCOMPAT | JFFS2_NODE_ACCURATE | 2)
64*53ee8cc1Swenshuai.xi #define JFFS2_NODETYPE_CLEANMARKER (JFFS2_FEATURE_RWCOMPAT_DELETE | JFFS2_NODE_ACCURATE | 3)
65*53ee8cc1Swenshuai.xi #define JFFS2_NODETYPE_PADDING (JFFS2_FEATURE_RWCOMPAT_DELETE | JFFS2_NODE_ACCURATE | 4)
66*53ee8cc1Swenshuai.xi 
67*53ee8cc1Swenshuai.xi #define JFFS2_NODETYPE_SUMMARY (JFFS2_FEATURE_RWCOMPAT_DELETE | JFFS2_NODE_ACCURATE | 6)
68*53ee8cc1Swenshuai.xi 
69*53ee8cc1Swenshuai.xi #define JFFS2_NODETYPE_XATTR (JFFS2_FEATURE_INCOMPAT | JFFS2_NODE_ACCURATE | 8)
70*53ee8cc1Swenshuai.xi #define JFFS2_NODETYPE_XREF (JFFS2_FEATURE_INCOMPAT | JFFS2_NODE_ACCURATE | 9)
71*53ee8cc1Swenshuai.xi 
72*53ee8cc1Swenshuai.xi /* XATTR Related */
73*53ee8cc1Swenshuai.xi #define JFFS2_XPREFIX_USER		1	/* for "user." */
74*53ee8cc1Swenshuai.xi #define JFFS2_XPREFIX_SECURITY		2	/* for "security." */
75*53ee8cc1Swenshuai.xi #define JFFS2_XPREFIX_ACL_ACCESS	3	/* for "system.posix_acl_access" */
76*53ee8cc1Swenshuai.xi #define JFFS2_XPREFIX_ACL_DEFAULT	4	/* for "system.posix_acl_default" */
77*53ee8cc1Swenshuai.xi #define JFFS2_XPREFIX_TRUSTED		5	/* for "trusted.*" */
78*53ee8cc1Swenshuai.xi 
79*53ee8cc1Swenshuai.xi #define JFFS2_ACL_VERSION		0x0001
80*53ee8cc1Swenshuai.xi 
81*53ee8cc1Swenshuai.xi // Maybe later...
82*53ee8cc1Swenshuai.xi //#define JFFS2_NODETYPE_CHECKPOINT (JFFS2_FEATURE_RWCOMPAT_DELETE | JFFS2_NODE_ACCURATE | 3)
83*53ee8cc1Swenshuai.xi //#define JFFS2_NODETYPE_OPTIONS (JFFS2_FEATURE_RWCOMPAT_COPY | JFFS2_NODE_ACCURATE | 4)
84*53ee8cc1Swenshuai.xi 
85*53ee8cc1Swenshuai.xi 
86*53ee8cc1Swenshuai.xi #define JFFS2_INO_FLAG_PREREAD	  1	/* Do read_inode() for this one at
87*53ee8cc1Swenshuai.xi 					   mount time, don't wait for it to
88*53ee8cc1Swenshuai.xi 					   happen later */
89*53ee8cc1Swenshuai.xi #define JFFS2_INO_FLAG_USERCOMPR  2	/* User has requested a specific
90*53ee8cc1Swenshuai.xi 					   compression type */
91*53ee8cc1Swenshuai.xi 
92*53ee8cc1Swenshuai.xi 
93*53ee8cc1Swenshuai.xi /* These can go once we've made sure we've caught all uses without
94*53ee8cc1Swenshuai.xi    byteswapping */
95*53ee8cc1Swenshuai.xi 
96*53ee8cc1Swenshuai.xi typedef struct {
97*53ee8cc1Swenshuai.xi 	uint32_t v32;
98*53ee8cc1Swenshuai.xi } __attribute__((packed)) jint32_t;
99*53ee8cc1Swenshuai.xi 
100*53ee8cc1Swenshuai.xi typedef struct {
101*53ee8cc1Swenshuai.xi 	uint32_t m;
102*53ee8cc1Swenshuai.xi } __attribute__((packed)) jmode_t;
103*53ee8cc1Swenshuai.xi 
104*53ee8cc1Swenshuai.xi typedef struct {
105*53ee8cc1Swenshuai.xi 	uint16_t v16;
106*53ee8cc1Swenshuai.xi } __attribute__((packed)) jint16_t;
107*53ee8cc1Swenshuai.xi 
108*53ee8cc1Swenshuai.xi struct jffs2_unknown_node
109*53ee8cc1Swenshuai.xi {
110*53ee8cc1Swenshuai.xi 	/* All start like this */
111*53ee8cc1Swenshuai.xi 	jint16_t magic;
112*53ee8cc1Swenshuai.xi 	jint16_t nodetype;
113*53ee8cc1Swenshuai.xi 	jint32_t totlen; /* So we can skip over nodes we don't grok */
114*53ee8cc1Swenshuai.xi 	jint32_t hdr_crc;
115*53ee8cc1Swenshuai.xi };
116*53ee8cc1Swenshuai.xi 
117*53ee8cc1Swenshuai.xi struct jffs2_raw_dirent
118*53ee8cc1Swenshuai.xi {
119*53ee8cc1Swenshuai.xi 	jint16_t magic;
120*53ee8cc1Swenshuai.xi 	jint16_t nodetype;	/* == JFFS2_NODETYPE_DIRENT */
121*53ee8cc1Swenshuai.xi 	jint32_t totlen;
122*53ee8cc1Swenshuai.xi 	jint32_t hdr_crc;
123*53ee8cc1Swenshuai.xi 	jint32_t pino;
124*53ee8cc1Swenshuai.xi 	jint32_t version;
125*53ee8cc1Swenshuai.xi 	jint32_t ino; /* == zero for unlink */
126*53ee8cc1Swenshuai.xi 	jint32_t mctime;
127*53ee8cc1Swenshuai.xi 	uint8_t nsize;
128*53ee8cc1Swenshuai.xi 	uint8_t type;
129*53ee8cc1Swenshuai.xi 	uint8_t unused[2];
130*53ee8cc1Swenshuai.xi 	jint32_t node_crc;
131*53ee8cc1Swenshuai.xi 	jint32_t name_crc;
132*53ee8cc1Swenshuai.xi 	uint8_t name[0];
133*53ee8cc1Swenshuai.xi };
134*53ee8cc1Swenshuai.xi 
135*53ee8cc1Swenshuai.xi /* The JFFS2 raw inode structure: Used for storage on physical media.  */
136*53ee8cc1Swenshuai.xi /* The uid, gid, atime, mtime and ctime members could be longer, but
137*53ee8cc1Swenshuai.xi    are left like this for space efficiency. If and when people decide
138*53ee8cc1Swenshuai.xi    they really need them extended, it's simple enough to add support for
139*53ee8cc1Swenshuai.xi    a new type of raw node.
140*53ee8cc1Swenshuai.xi */
141*53ee8cc1Swenshuai.xi struct jffs2_raw_inode
142*53ee8cc1Swenshuai.xi {
143*53ee8cc1Swenshuai.xi 	jint16_t magic;      /* A constant magic number.  */
144*53ee8cc1Swenshuai.xi 	jint16_t nodetype;   /* == JFFS2_NODETYPE_INODE */
145*53ee8cc1Swenshuai.xi 	jint32_t totlen;     /* Total length of this node (inc data, etc.) */
146*53ee8cc1Swenshuai.xi 	jint32_t hdr_crc;
147*53ee8cc1Swenshuai.xi 	jint32_t ino;        /* Inode number.  */
148*53ee8cc1Swenshuai.xi 	jint32_t version;    /* Version number.  */
149*53ee8cc1Swenshuai.xi 	jmode_t mode;       /* The file's type or mode.  */
150*53ee8cc1Swenshuai.xi 	jint16_t uid;        /* The file's owner.  */
151*53ee8cc1Swenshuai.xi 	jint16_t gid;        /* The file's group.  */
152*53ee8cc1Swenshuai.xi 	jint32_t isize;      /* Total resultant size of this inode (used for truncations)  */
153*53ee8cc1Swenshuai.xi 	jint32_t atime;      /* Last access time.  */
154*53ee8cc1Swenshuai.xi 	jint32_t mtime;      /* Last modification time.  */
155*53ee8cc1Swenshuai.xi 	jint32_t ctime;      /* Change time.  */
156*53ee8cc1Swenshuai.xi 	jint32_t offset;     /* Where to begin to write.  */
157*53ee8cc1Swenshuai.xi 	jint32_t csize;      /* (Compressed) data size */
158*53ee8cc1Swenshuai.xi 	jint32_t dsize;	     /* Size of the node's data. (after decompression) */
159*53ee8cc1Swenshuai.xi 	uint8_t compr;       /* Compression algorithm used */
160*53ee8cc1Swenshuai.xi 	uint8_t usercompr;   /* Compression algorithm requested by the user */
161*53ee8cc1Swenshuai.xi 	jint16_t flags;	     /* See JFFS2_INO_FLAG_* */
162*53ee8cc1Swenshuai.xi 	jint32_t data_crc;   /* CRC for the (compressed) data.  */
163*53ee8cc1Swenshuai.xi 	jint32_t node_crc;   /* CRC for the raw inode (excluding data)  */
164*53ee8cc1Swenshuai.xi 	uint8_t data[0];
165*53ee8cc1Swenshuai.xi };
166*53ee8cc1Swenshuai.xi 
167*53ee8cc1Swenshuai.xi struct jffs2_raw_xattr {
168*53ee8cc1Swenshuai.xi 	jint16_t magic;
169*53ee8cc1Swenshuai.xi 	jint16_t nodetype;	/* = JFFS2_NODETYPE_XATTR */
170*53ee8cc1Swenshuai.xi 	jint32_t totlen;
171*53ee8cc1Swenshuai.xi 	jint32_t hdr_crc;
172*53ee8cc1Swenshuai.xi 	jint32_t xid;		/* XATTR identifier number */
173*53ee8cc1Swenshuai.xi 	jint32_t version;
174*53ee8cc1Swenshuai.xi 	uint8_t xprefix;
175*53ee8cc1Swenshuai.xi 	uint8_t name_len;
176*53ee8cc1Swenshuai.xi 	jint16_t value_len;
177*53ee8cc1Swenshuai.xi 	jint32_t data_crc;
178*53ee8cc1Swenshuai.xi 	jint32_t node_crc;
179*53ee8cc1Swenshuai.xi 	uint8_t data[0];
180*53ee8cc1Swenshuai.xi } __attribute__((packed));
181*53ee8cc1Swenshuai.xi 
182*53ee8cc1Swenshuai.xi struct jffs2_raw_xref
183*53ee8cc1Swenshuai.xi {
184*53ee8cc1Swenshuai.xi 	jint16_t magic;
185*53ee8cc1Swenshuai.xi 	jint16_t nodetype;	/* = JFFS2_NODETYPE_XREF */
186*53ee8cc1Swenshuai.xi 	jint32_t totlen;
187*53ee8cc1Swenshuai.xi 	jint32_t hdr_crc;
188*53ee8cc1Swenshuai.xi 	jint32_t ino;		/* inode number */
189*53ee8cc1Swenshuai.xi 	jint32_t xid;		/* XATTR identifier number */
190*53ee8cc1Swenshuai.xi 	jint32_t xseqno;	/* xref sequencial number */
191*53ee8cc1Swenshuai.xi 	jint32_t node_crc;
192*53ee8cc1Swenshuai.xi } __attribute__((packed));
193*53ee8cc1Swenshuai.xi 
194*53ee8cc1Swenshuai.xi struct jffs2_raw_summary
195*53ee8cc1Swenshuai.xi {
196*53ee8cc1Swenshuai.xi 	jint16_t magic;
197*53ee8cc1Swenshuai.xi 	jint16_t nodetype; 	/* = JFFS2_NODETYPE_SUMMARY */
198*53ee8cc1Swenshuai.xi 	jint32_t totlen;
199*53ee8cc1Swenshuai.xi 	jint32_t hdr_crc;
200*53ee8cc1Swenshuai.xi 	jint32_t sum_num;	/* number of sum entries*/
201*53ee8cc1Swenshuai.xi 	jint32_t cln_mkr;	/* clean marker size, 0 = no cleanmarker */
202*53ee8cc1Swenshuai.xi 	jint32_t padded;	/* sum of the size of padding nodes */
203*53ee8cc1Swenshuai.xi 	jint32_t sum_crc;	/* summary information crc */
204*53ee8cc1Swenshuai.xi 	jint32_t node_crc; 	/* node crc */
205*53ee8cc1Swenshuai.xi 	jint32_t sum[0]; 	/* inode summary info */
206*53ee8cc1Swenshuai.xi };
207*53ee8cc1Swenshuai.xi 
208*53ee8cc1Swenshuai.xi union jffs2_node_union
209*53ee8cc1Swenshuai.xi {
210*53ee8cc1Swenshuai.xi 	struct jffs2_raw_inode i;
211*53ee8cc1Swenshuai.xi 	struct jffs2_raw_dirent d;
212*53ee8cc1Swenshuai.xi 	struct jffs2_raw_xattr x;
213*53ee8cc1Swenshuai.xi 	struct jffs2_raw_xref r;
214*53ee8cc1Swenshuai.xi 	struct jffs2_raw_summary s;
215*53ee8cc1Swenshuai.xi 	struct jffs2_unknown_node u;
216*53ee8cc1Swenshuai.xi };
217*53ee8cc1Swenshuai.xi 
218*53ee8cc1Swenshuai.xi /* Data payload for device nodes. */
219*53ee8cc1Swenshuai.xi union jffs2_device_node {
220*53ee8cc1Swenshuai.xi 	jint16_t old;
221*53ee8cc1Swenshuai.xi 	jint32_t new;
222*53ee8cc1Swenshuai.xi };
223*53ee8cc1Swenshuai.xi 
224*53ee8cc1Swenshuai.xi #endif /* __LINUX_JFFS2_H__ */
225