Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
d61692f1
Commit
d61692f1
authored
Jun 19, 2004
by
Nathan Scott
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[XFS] Sanitise the ACL initialisation macros.
SGI Modid: xfs-linux:xfs-kern:173559a Signed-off-by: nathans@sgi.com
parent
a5c4ca27
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
13 additions
and
17 deletions
+13
-17
fs/xfs/xfs_acl.h
fs/xfs/xfs_acl.h
+11
-15
fs/xfs/xfs_vfsops.c
fs/xfs/xfs_vfsops.c
+2
-2
No files found.
fs/xfs/xfs_acl.h
View file @
d61692f1
/*
* Copyright (c) 2001-200
3
Silicon Graphics, Inc. All Rights Reserved.
* Copyright (c) 2001-200
4
Silicon Graphics, Inc. All Rights Reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
...
...
@@ -61,14 +61,17 @@ typedef struct xfs_acl {
#define SGI_ACL_DEFAULT_SIZE (sizeof(SGI_ACL_DEFAULT)-1)
#ifdef __KERNEL__
#ifdef CONFIG_XFS_POSIX_ACL
struct
vattr
;
struct
vnode
;
struct
xfs_inode
;
extern
struct
kmem_zone
*
xfs_acl_zone
;
#define xfs_acl_zone_init(zone, name) \
(zone) = kmem_zone_init(sizeof(xfs_acl_t), name)
#define xfs_acl_zone_destroy(zone) kmem_cache_destroy(zone)
extern
int
xfs_acl_inherit
(
struct
vnode
*
,
struct
vattr
*
,
xfs_acl_t
*
);
extern
int
xfs_acl_iaccess
(
struct
xfs_inode
*
,
mode_t
,
cred_t
*
);
extern
int
xfs_acl_get
(
struct
vnode
*
,
xfs_acl_t
*
,
xfs_acl_t
*
);
...
...
@@ -80,17 +83,10 @@ extern int xfs_acl_vset(struct vnode *, void *, size_t, int);
extern
int
xfs_acl_vget
(
struct
vnode
*
,
void
*
,
size_t
,
int
);
extern
int
xfs_acl_vremove
(
struct
vnode
*
vp
,
int
);
extern
struct
kmem_zone
*
xfs_acl_zone
;
#define _ACL_TYPE_ACCESS 1
#define _ACL_TYPE_DEFAULT 2
#define _ACL_PERM_INVALID(perm) ((perm) & ~(ACL_READ|ACL_WRITE|ACL_EXECUTE))
#define _ACL_DECL(a) xfs_acl_t *(a) = NULL
#define _ACL_ALLOC(a) ((a) = kmem_zone_alloc(xfs_acl_zone, KM_SLEEP))
#define _ACL_FREE(a) ((a)? kmem_zone_free(xfs_acl_zone, (a)) : 0)
#define _ACL_ZONE_INIT(z,name) ((z) = kmem_zone_init(sizeof(xfs_acl_t), name))
#define _ACL_ZONE_DESTROY(z) (kmem_cache_destroy(z))
#define _ACL_INHERIT(c,v,d) (xfs_acl_inherit(c,v,d))
#define _ACL_GET_ACCESS(pv,pa) (xfs_acl_vtoacl(pv,pa,NULL) == 0)
#define _ACL_GET_DEFAULT(pv,pd) (xfs_acl_vtoacl(pv,NULL,pd) == 0)
...
...
@@ -98,17 +94,19 @@ extern struct kmem_zone *xfs_acl_zone;
#define _ACL_DEFAULT_EXISTS xfs_acl_vhasacl_default
#define _ACL_XFS_IACCESS(i,m,c) (XFS_IFORK_Q(i) ? xfs_acl_iaccess(i,m,c) : -1)
#define _ACL_ALLOC(a) ((a) = kmem_zone_alloc(xfs_acl_zone, KM_SLEEP))
#define _ACL_FREE(a) ((a)? kmem_zone_free(xfs_acl_zone, (a)) : 0)
#else
#define xfs_acl_zone_init(zone,name)
#define xfs_acl_zone_destroy(zone)
#define xfs_acl_vset(v,p,sz,t) (-EOPNOTSUPP)
#define xfs_acl_vget(v,p,sz,t) (-EOPNOTSUPP)
#define xfs_acl_vremove(v,t) (-EOPNOTSUPP)
#define xfs_acl_vhasacl_access(v) (0)
#define xfs_acl_vhasacl_default(v) (0)
#define _ACL_DECL(a) ((void)0)
#define _ACL_ALLOC(a) (1)
/* successfully allocate nothing */
#define _ACL_FREE(a) ((void)0)
#define _ACL_ZONE_INIT(z,name) ((void)0)
#define _ACL_ZONE_DESTROY(z) ((void)0)
#define _ACL_INHERIT(c,v,d) (0)
#define _ACL_GET_ACCESS(pv,pa) (0)
#define _ACL_GET_DEFAULT(pv,pd) (0)
...
...
@@ -117,6 +115,4 @@ extern struct kmem_zone *xfs_acl_zone;
#define _ACL_XFS_IACCESS(i,m,c) (-1)
#endif
#endif
/* __KERNEL__ */
#endif
/* __XFS_ACL_H__ */
fs/xfs/xfs_vfsops.c
View file @
d61692f1
...
...
@@ -118,7 +118,7 @@ xfs_init(void)
xfs_ili_zone
=
kmem_zone_init
(
sizeof
(
xfs_inode_log_item_t
),
"xfs_ili"
);
xfs_chashlist_zone
=
kmem_zone_init
(
sizeof
(
xfs_chashlist_t
),
"xfs_chashlist"
);
_ACL_ZONE_INIT
(
xfs_acl_zone
,
"xfs_acl"
);
xfs_acl_zone_init
(
xfs_acl_zone
,
"xfs_acl"
);
/*
* Allocate global trace buffers.
...
...
@@ -170,6 +170,7 @@ xfs_cleanup(void)
xfs_cleanup_procfs
();
xfs_sysctl_unregister
();
xfs_refcache_destroy
();
xfs_acl_zone_destroy
(
xfs_acl_zone
);
#ifdef XFS_DIR2_TRACE
ktrace_free
(
xfs_dir2_trace_buf
);
...
...
@@ -202,7 +203,6 @@ xfs_cleanup(void)
kmem_cache_destroy
(
xfs_ifork_zone
);
kmem_cache_destroy
(
xfs_ili_zone
);
kmem_cache_destroy
(
xfs_chashlist_zone
);
_ACL_ZONE_DESTROY
(
xfs_acl_zone
);
}
/*
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment