Blame view
fs/adfs/adfs.h
5.65 KB
608ba50bd Cleanup of adfs h... |
1 2 |
#include <linux/fs.h> #include <linux/adfs_fs.h> |
1da177e4c 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 Linux-2.6.12-rc2 |
16 17 18 19 20 |
#include "dir_f.h" struct buffer_head; /* |
608ba50bd 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 adfs: delayed fre... |
44 45 46 47 48 49 |
union { struct { struct adfs_discmap *s_map; /* bh list containing map */ struct adfs_dir_ops *s_dir; /* directory operations */ }; struct rcu_head rcu; /* used only at shutdown time */ }; |
c010d1ff4 userns: Convert a... |
50 51 |
kuid_t s_uid; /* owner uid */ kgid_t s_gid; /* owner gid */ |
608ba50bd Cleanup of adfs h... |
52 53 |
umode_t s_owner_mask; /* ADFS owner perm -> unix perm */ umode_t s_other_mask; /* ADFS other perm -> unix perm */ |
da23ef054 adfs: add hexadec... |
54 |
int s_ftsuffix; /* ,xyz hex filetype suffix option */ |
608ba50bd Cleanup of adfs h... |
55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 |
__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 */ 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 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 adfs: fix E+/F+ d... |
84 85 86 |
/* big directories need allocated buffers */ struct buffer_head **bh_fplus; |
1da177e4c 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 adfs: add hexadec... |
97 |
#define ADFS_MAX_NAME_LEN (256 + 4) /* +4 for ,xyz hex filetype suffix */ |
1da177e4c 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 adfs: add hexadec... |
105 |
unsigned int name_len; /* name length */ |
1da177e4c Linux-2.6.12-rc2 |
106 |
char name[ADFS_MAX_NAME_LEN];/* file name */ |
da23ef054 adfs: add hexadec... |
107 108 109 |
/* RISC OS file type (12-bit: derived from loadaddr) */ __u16 filetype; |
1da177e4c Linux-2.6.12-rc2 |
110 |
}; |
da23ef054 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 fs/adfs/adfs.h: f... |
114 |
if (filetype == 0xffff) /* no explicit 12-bit file type was set */ |
da23ef054 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 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 repair adfs ->wri... |
130 |
int (*sync)(struct adfs_dir *dir); |
1da177e4c 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 pass writeback_co... |
143 |
int adfs_write_inode(struct inode *inode, struct writeback_control *wbc); |
1da177e4c Linux-2.6.12-rc2 |
144 145 146 147 148 149 150 151 152 |
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 */ void __adfs_error(struct super_block *sb, const char *function, const char *fmt, ...); |
8e24eea72 fs: replace remai... |
153 |
#define adfs_error(sb, fmt...) __adfs_error(sb, __func__, fmt) |
1da177e4c Linux-2.6.12-rc2 |
154 155 156 157 158 159 160 161 |
/* super.c */ /* * Inodes and file operations */ /* dir_*.c */ |
754661f14 [PATCH] mark stru... |
162 |
extern const struct inode_operations adfs_dir_inode_operations; |
4b6f5d20b [PATCH] Make most... |
163 |
extern const struct file_operations adfs_dir_operations; |
e16404ed0 constify dentry_o... |
164 |
extern const struct dentry_operations adfs_dentry_operations; |
1da177e4c Linux-2.6.12-rc2 |
165 166 |
extern struct adfs_dir_ops adfs_f_dir_ops; extern struct adfs_dir_ops adfs_fplus_dir_ops; |
ffdc9064f repair adfs ->wri... |
167 168 |
extern int adfs_dir_update(struct super_block *sb, struct object_info *obj, int wait); |
1da177e4c Linux-2.6.12-rc2 |
169 170 |
/* file.c */ |
754661f14 [PATCH] mark stru... |
171 |
extern const struct inode_operations adfs_file_inode_operations; |
4b6f5d20b [PATCH] Make most... |
172 |
extern const struct file_operations adfs_file_operations; |
1da177e4c Linux-2.6.12-rc2 |
173 |
|
e0c93142c [ARM] fs/adfs/adf... |
174 |
static inline __u32 signed_asl(__u32 val, signed int shift) |
1da177e4c Linux-2.6.12-rc2 |
175 176 177 178 179 180 181 182 183 184 185 186 187 188 |
{ 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 [ARM] fs/adfs/adf... |
189 |
static inline int |
1da177e4c Linux-2.6.12-rc2 |
190 191 192 193 194 195 196 197 198 199 200 201 |
__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); } |