Blame view

fs/adfs/adfs.h 5.65 KB
608ba50bd   Al Viro   Cleanup of adfs h...
1
2
  #include <linux/fs.h>
  #include <linux/adfs_fs.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
3
4
5
6
7
8
9
10
11
12
13
14
15
  /* Internal data structures for ADFS */
  
  #define ADFS_FREE_FRAG		 0
  #define ADFS_BAD_FRAG		 1
  #define ADFS_ROOT_FRAG		 2
  
  #define ADFS_NDA_OWNER_READ	(1 << 0)
  #define ADFS_NDA_OWNER_WRITE	(1 << 1)
  #define ADFS_NDA_LOCKED		(1 << 2)
  #define ADFS_NDA_DIRECTORY	(1 << 3)
  #define ADFS_NDA_EXECUTE	(1 << 4)
  #define ADFS_NDA_PUBLIC_READ	(1 << 5)
  #define ADFS_NDA_PUBLIC_WRITE	(1 << 6)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
16
17
18
19
20
  #include "dir_f.h"
  
  struct buffer_head;
  
  /*
608ba50bd   Al Viro   Cleanup of adfs h...
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
   * adfs file system inode data in memory
   */
  struct adfs_inode_info {
  	loff_t		mmu_private;
  	unsigned long	parent_id;	/* object id of parent		*/
  	__u32		loadaddr;	/* RISC OS load address		*/
  	__u32		execaddr;	/* RISC OS exec address		*/
  	unsigned int	filetype;	/* RISC OS file type		*/
  	unsigned int	attr;		/* RISC OS permissions		*/
  	unsigned int	stamped:1;	/* RISC OS file has date/time	*/
  	struct inode vfs_inode;
  };
  
  /*
   * Forward-declare this
   */
  struct adfs_discmap;
  struct adfs_dir_ops;
  
  /*
   * ADFS file system superblock data in memory
   */
  struct adfs_sb_info {
2d1d9b5b5   Al Viro   adfs: delayed fre...
44
  	union { struct {
90d6cd51a   Andrew Morton   fs/adfs/adfs.h: t...
45
46
  		struct adfs_discmap *s_map;	/* bh list containing map */
  		const struct adfs_dir_ops *s_dir; /* directory operations */
2d1d9b5b5   Al Viro   adfs: delayed fre...
47
  		};
90d6cd51a   Andrew Morton   fs/adfs/adfs.h: t...
48
  		struct rcu_head rcu;	/* used only at shutdown time	 */
2d1d9b5b5   Al Viro   adfs: delayed fre...
49
  	};
90d6cd51a   Andrew Morton   fs/adfs/adfs.h: t...
50
51
52
53
  	kuid_t		s_uid;		/* owner uid */
  	kgid_t		s_gid;		/* owner gid */
  	umode_t		s_owner_mask;	/* ADFS owner perm -> unix perm */
  	umode_t		s_other_mask;	/* ADFS other perm -> unix perm	*/
da23ef054   Stuart Swales   adfs: add hexadec...
54
  	int		s_ftsuffix;	/* ,xyz hex filetype suffix option */
608ba50bd   Al Viro   Cleanup of adfs h...
55

90d6cd51a   Andrew Morton   fs/adfs/adfs.h: t...
56
57
58
59
60
61
62
  	__u32		s_ids_per_zone;	/* max. no ids in one zone */
  	__u32		s_idlen;	/* length of ID in map */
  	__u32		s_map_size;	/* sector size of a map	*/
  	unsigned long	s_size;		/* total size (in blocks) of this fs */
  	signed int	s_map2blk;	/* shift left by this for map->sector*/
  	unsigned int	s_log2sharesize;/* log2 share size */
  	__le32		s_version;	/* disc format version */
608ba50bd   Al Viro   Cleanup of adfs h...
63
64
65
66
67
68
69
70
71
72
73
74
75
76
  	unsigned int	s_namelen;	/* maximum number of characters in name	 */
  };
  
  static inline struct adfs_sb_info *ADFS_SB(struct super_block *sb)
  {
  	return sb->s_fs_info;
  }
  
  static inline struct adfs_inode_info *ADFS_I(struct inode *inode)
  {
  	return container_of(inode, struct adfs_inode_info, vfs_inode);
  }
  
  /*
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
77
78
79
80
81
82
83
   * Directory handling
   */
  struct adfs_dir {
  	struct super_block	*sb;
  
  	int			nr_buffers;
  	struct buffer_head	*bh[4];
2f09719af   Stuart Swales   adfs: fix E+/F+ d...
84
85
86
  
  	/* big directories need allocated buffers */
  	struct buffer_head	**bh_fplus;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
87
88
89
90
91
92
93
94
95
96
  	unsigned int		pos;
  	unsigned int		parent_id;
  
  	struct adfs_dirheader	dirhead;
  	union  adfs_dirtail	dirtail;
  };
  
  /*
   * This is the overall maximum name length
   */
da23ef054   Stuart Swales   adfs: add hexadec...
97
  #define ADFS_MAX_NAME_LEN	(256 + 4) /* +4 for ,xyz hex filetype suffix */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
98
99
100
101
102
103
104
  struct object_info {
  	__u32		parent_id;		/* parent object id	*/
  	__u32		file_id;		/* object id		*/
  	__u32		loadaddr;		/* load address		*/
  	__u32		execaddr;		/* execution address	*/
  	__u32		size;			/* size			*/
  	__u8		attr;			/* RISC OS attributes	*/
da23ef054   Stuart Swales   adfs: add hexadec...
105
  	unsigned int	name_len;		/* name length		*/
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
106
  	char		name[ADFS_MAX_NAME_LEN];/* file name		*/
da23ef054   Stuart Swales   adfs: add hexadec...
107
108
109
  
  	/* RISC OS file type (12-bit: derived from loadaddr) */
  	__u16		filetype;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
110
  };
da23ef054   Stuart Swales   adfs: add hexadec...
111
112
113
  /* RISC OS 12-bit filetype converts to ,xyz hex filename suffix */
  static inline int append_filetype_suffix(char *buf, __u16 filetype)
  {
135a9fcf4   Andrew Morton   fs/adfs/adfs.h: f...
114
  	if (filetype == 0xffff)	/* no explicit 12-bit file type was set */
da23ef054   Stuart Swales   adfs: add hexadec...
115
116
117
118
119
120
121
122
  		return 0;
  
  	*buf++ = ',';
  	*buf++ = hex_asc_lo(filetype >> 8);
  	*buf++ = hex_asc_lo(filetype >> 4);
  	*buf++ = hex_asc_lo(filetype >> 0);
  	return 4;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
123
124
125
126
127
128
129
  struct adfs_dir_ops {
  	int	(*read)(struct super_block *sb, unsigned int id, unsigned int sz, struct adfs_dir *dir);
  	int	(*setpos)(struct adfs_dir *dir, unsigned int fpos);
  	int	(*getnext)(struct adfs_dir *dir, struct object_info *obj);
  	int	(*update)(struct adfs_dir *dir, struct object_info *obj);
  	int	(*create)(struct adfs_dir *dir, struct object_info *obj);
  	int	(*remove)(struct adfs_dir *dir, struct object_info *obj);
ffdc9064f   Al Viro   repair adfs ->wri...
130
  	int	(*sync)(struct adfs_dir *dir);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
131
132
133
134
135
136
137
138
139
140
141
142
  	void	(*free)(struct adfs_dir *dir);
  };
  
  struct adfs_discmap {
  	struct buffer_head	*dm_bh;
  	__u32			dm_startblk;
  	unsigned int		dm_startbit;
  	unsigned int		dm_endbit;
  };
  
  /* Inode stuff */
  struct inode *adfs_iget(struct super_block *sb, struct object_info *obj);
a9185b41a   Christoph Hellwig   pass writeback_co...
143
  int adfs_write_inode(struct inode *inode, struct writeback_control *wbc);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
144
145
146
147
148
149
150
  int adfs_notify_change(struct dentry *dentry, struct iattr *attr);
  
  /* map.c */
  extern int adfs_map_lookup(struct super_block *sb, unsigned int frag_id, unsigned int offset);
  extern unsigned int adfs_map_free(struct super_block *sb);
  
  /* Misc */
19bdd41a5   Joe Perches   adfs: add __print...
151
  __printf(3, 4)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
152
153
  void __adfs_error(struct super_block *sb, const char *function,
  		  const char *fmt, ...);
8e24eea72   Harvey Harrison   fs: replace remai...
154
  #define adfs_error(sb, fmt...) __adfs_error(sb, __func__, fmt)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
155
156
157
158
159
160
161
162
  
  /* super.c */
  
  /*
   * Inodes and file operations
   */
  
  /* dir_*.c */
754661f14   Arjan van de Ven   [PATCH] mark stru...
163
  extern const struct inode_operations adfs_dir_inode_operations;
4b6f5d20b   Arjan van de Ven   [PATCH] Make most...
164
  extern const struct file_operations adfs_dir_operations;
e16404ed0   Al Viro   constify dentry_o...
165
  extern const struct dentry_operations adfs_dentry_operations;
0125f504e   Julia Lawall   adfs: constify ad...
166
167
  extern const struct adfs_dir_ops adfs_f_dir_ops;
  extern const struct adfs_dir_ops adfs_fplus_dir_ops;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
168

ffdc9064f   Al Viro   repair adfs ->wri...
169
170
  extern int adfs_dir_update(struct super_block *sb, struct object_info *obj,
  			   int wait);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
171
172
  
  /* file.c */
754661f14   Arjan van de Ven   [PATCH] mark stru...
173
  extern const struct inode_operations adfs_file_inode_operations;
4b6f5d20b   Arjan van de Ven   [PATCH] Make most...
174
  extern const struct file_operations adfs_file_operations;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
175

e0c93142c   Adrian Bunk   [ARM] fs/adfs/adf...
176
  static inline __u32 signed_asl(__u32 val, signed int shift)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
177
178
179
180
181
182
183
184
185
186
187
188
189
190
  {
  	if (shift >= 0)
  		val <<= shift;
  	else
  		val >>= -shift;
  	return val;
  }
  
  /*
   * Calculate the address of a block in an object given the block offset
   * and the object identity.
   *
   * The root directory ID should always be looked up in the map [3.4]
   */
e0c93142c   Adrian Bunk   [ARM] fs/adfs/adf...
191
  static inline int
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
192
193
194
195
196
197
198
199
200
201
202
203
  __adfs_block_map(struct super_block *sb, unsigned int object_id,
  		 unsigned int block)
  {
  	if (object_id & 255) {
  		unsigned int off;
  
  		off = (object_id & 255) - 1;
  		block += off << ADFS_SB(sb)->s_log2sharesize;
  	}
  
  	return adfs_map_lookup(sb, object_id >> 8, block);
  }