aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs/xfs_attr.h
diff options
context:
space:
mode:
Diffstat (limited to 'fs/xfs/xfs_attr.h')
-rw-r--r--fs/xfs/xfs_attr.h55
1 files changed, 30 insertions, 25 deletions
diff --git a/fs/xfs/xfs_attr.h b/fs/xfs/xfs_attr.h
index c1f7d43e5ecf..41469434f413 100644
--- a/fs/xfs/xfs_attr.h
+++ b/fs/xfs/xfs_attr.h
@@ -18,9 +18,11 @@
18#ifndef __XFS_ATTR_H__ 18#ifndef __XFS_ATTR_H__
19#define __XFS_ATTR_H__ 19#define __XFS_ATTR_H__
20 20
21struct xfs_inode;
22struct xfs_da_args;
23struct xfs_attr_list_context;
24
21/* 25/*
22 * xfs_attr.h
23 *
24 * Large attribute lists are structured around Btrees where all the data 26 * Large attribute lists are structured around Btrees where all the data
25 * elements are in the leaf nodes. Attribute names are hashed into an int, 27 * elements are in the leaf nodes. Attribute names are hashed into an int,
26 * then that int is used as the index into the Btree. Since the hashval 28 * then that int is used as the index into the Btree. Since the hashval
@@ -35,17 +37,6 @@
35 * External interfaces 37 * External interfaces
36 *========================================================================*/ 38 *========================================================================*/
37 39
38struct cred;
39struct xfs_attr_list_context;
40
41typedef struct attrnames {
42 char * attr_name;
43 unsigned int attr_namelen;
44} attrnames_t;
45
46extern struct attrnames attr_user;
47extern struct attrnames attr_secure;
48extern struct attrnames attr_trusted;
49 40
50#define ATTR_DONTFOLLOW 0x0001 /* -- unused, from IRIX -- */ 41#define ATTR_DONTFOLLOW 0x0001 /* -- unused, from IRIX -- */
51#define ATTR_ROOT 0x0002 /* use attrs in root (trusted) namespace */ 42#define ATTR_ROOT 0x0002 /* use attrs in root (trusted) namespace */
@@ -54,14 +45,8 @@ extern struct attrnames attr_trusted;
54#define ATTR_CREATE 0x0010 /* pure create: fail if attr already exists */ 45#define ATTR_CREATE 0x0010 /* pure create: fail if attr already exists */
55#define ATTR_REPLACE 0x0020 /* pure set: fail if attr does not exist */ 46#define ATTR_REPLACE 0x0020 /* pure set: fail if attr does not exist */
56 47
57#define ATTR_KERNACCESS 0x0400 /* [kernel] iaccess, inode held io-locked */
58#define ATTR_KERNOTIME 0x1000 /* [kernel] don't update inode timestamps */ 48#define ATTR_KERNOTIME 0x1000 /* [kernel] don't update inode timestamps */
59#define ATTR_KERNOVAL 0x2000 /* [kernel] get attr size only, not value */ 49#define ATTR_KERNOVAL 0x2000 /* [kernel] get attr size only, not value */
60#define ATTR_KERNAMELS 0x4000 /* [kernel] list attr names (simple list) */
61
62#define ATTR_KERNORMALS 0x0800 /* [kernel] normal attr list: user+secure */
63#define ATTR_KERNROOTLS 0x8000 /* [kernel] include root in the attr list */
64#define ATTR_KERNFULLS (ATTR_KERNORMALS|ATTR_KERNROOTLS)
65 50
66/* 51/*
67 * The maximum size (into the kernel or returned from the kernel) of an 52 * The maximum size (into the kernel or returned from the kernel) of an
@@ -129,20 +114,40 @@ typedef struct attrlist_cursor_kern {
129 114
130 115
131/*======================================================================== 116/*========================================================================
132 * Function prototypes for the kernel. 117 * Structure used to pass context around among the routines.
133 *========================================================================*/ 118 *========================================================================*/
134 119
135struct xfs_inode; 120
136struct attrlist_cursor_kern; 121typedef int (*put_listent_func_t)(struct xfs_attr_list_context *, int,
137struct xfs_da_args; 122 char *, int, int, char *);
123
124typedef struct xfs_attr_list_context {
125 struct xfs_inode *dp; /* inode */
126 struct attrlist_cursor_kern *cursor; /* position in list */
127 char *alist; /* output buffer */
128 int seen_enough; /* T/F: seen enough of list? */
129 int count; /* num used entries */
130 int dupcnt; /* count dup hashvals seen */
131 int bufsize; /* total buffer size */
132 int firstu; /* first used byte in buffer */
133 int flags; /* from VOP call */
134 int resynch; /* T/F: resynch with cursor */
135 int put_value; /* T/F: need value for listent */
136 put_listent_func_t put_listent; /* list output fmt function */
137 int index; /* index into output buffer */
138} xfs_attr_list_context_t;
139
140
141/*========================================================================
142 * Function prototypes for the kernel.
143 *========================================================================*/
138 144
139/* 145/*
140 * Overall external interface routines. 146 * Overall external interface routines.
141 */ 147 */
142int xfs_attr_inactive(struct xfs_inode *dp); 148int xfs_attr_inactive(struct xfs_inode *dp);
143
144int xfs_attr_shortform_getvalue(struct xfs_da_args *);
145int xfs_attr_fetch(struct xfs_inode *, struct xfs_name *, char *, int *, int); 149int xfs_attr_fetch(struct xfs_inode *, struct xfs_name *, char *, int *, int);
146int xfs_attr_rmtval_get(struct xfs_da_args *args); 150int xfs_attr_rmtval_get(struct xfs_da_args *args);
151int xfs_attr_list_int(struct xfs_attr_list_context *);
147 152
148#endif /* __XFS_ATTR_H__ */ 153#endif /* __XFS_ATTR_H__ */