lsattr,chattr: support -p
function old new delta fgetsetprojid - 107 +107 list_attributes 169 222 +53 change_attributes 277 326 +49 chattr_main 272 307 +35 close_silently - 22 +22 .rodata 103378 103393 +15 packed_usage 33658 33666 +8 fgetsetversion 88 74 -14 fgetsetflags 162 148 -14 ------------------------------------------------------------------------------ (add/remove: 2/0 grow/shrink: 5/2 up/down: 289/-28) Total: 261 bytes Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
		@@ -51,14 +51,14 @@ int fgetsetversion(const char *name, unsigned long *get_version, unsigned long s
 | 
			
		||||
{
 | 
			
		||||
#if HAVE_EXT2_IOCTLS
 | 
			
		||||
	int fd, r;
 | 
			
		||||
	IF_LONG_IS_WIDER(int ver;)
 | 
			
		||||
	IF_LONG_IS_WIDER(unsigned ver;)
 | 
			
		||||
 | 
			
		||||
	fd = open(name, O_RDONLY | O_NONBLOCK);
 | 
			
		||||
	if (fd == -1)
 | 
			
		||||
		return -1;
 | 
			
		||||
	if (!get_version) {
 | 
			
		||||
		IF_LONG_IS_WIDER(
 | 
			
		||||
			ver = (int) set_version;
 | 
			
		||||
			ver = (unsigned) set_version;
 | 
			
		||||
			r = ioctl(fd, EXT2_IOC_SETVERSION, &ver);
 | 
			
		||||
		)
 | 
			
		||||
		IF_LONG_IS_SAME(
 | 
			
		||||
@@ -81,6 +81,32 @@ int fgetsetversion(const char *name, unsigned long *get_version, unsigned long s
 | 
			
		||||
#endif /* ! HAVE_EXT2_IOCTLS */
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
int fgetsetprojid(const char *name, uint32_t *get, uint32_t set)
 | 
			
		||||
{
 | 
			
		||||
#if HAVE_EXT2_IOCTLS
 | 
			
		||||
	struct ext2_fsxattr fsxattr;
 | 
			
		||||
	int fd, r;
 | 
			
		||||
 | 
			
		||||
	fd = open(name, O_RDONLY | O_NONBLOCK);
 | 
			
		||||
	if (fd == -1)
 | 
			
		||||
		return -1;
 | 
			
		||||
	r = ioctl(fd, EXT2_IOC_FSGETXATTR, &fsxattr);
 | 
			
		||||
	/* note: ^^^ may fail in 32-bit userspace on 64-bit kernel (seen on 4.12.0) */
 | 
			
		||||
	if (r == 0) {
 | 
			
		||||
		if (get) {
 | 
			
		||||
			*get = fsxattr.fsx_projid;
 | 
			
		||||
		} else {
 | 
			
		||||
			fsxattr.fsx_projid = set;
 | 
			
		||||
			r = ioctl(fd, EXT2_IOC_FSSETXATTR, &fsxattr);
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	close_silently(fd);
 | 
			
		||||
	return r;
 | 
			
		||||
#else /* ! HAVE_EXT2_IOCTLS */
 | 
			
		||||
	errno = EOPNOTSUPP;
 | 
			
		||||
	return -1;
 | 
			
		||||
#endif /* ! HAVE_EXT2_IOCTLS */
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Get/set a file flags on an ext2 file system */
 | 
			
		||||
int fgetsetflags(const char *name, unsigned long *get_flags, unsigned long set_flags)
 | 
			
		||||
@@ -88,7 +114,7 @@ int fgetsetflags(const char *name, unsigned long *get_flags, unsigned long set_f
 | 
			
		||||
#if HAVE_EXT2_IOCTLS
 | 
			
		||||
	struct stat buf;
 | 
			
		||||
	int fd, r;
 | 
			
		||||
	IF_LONG_IS_WIDER(int f;)
 | 
			
		||||
	IF_LONG_IS_WIDER(unsigned f;)
 | 
			
		||||
 | 
			
		||||
	if (stat(name, &buf) == 0 /* stat is ok */
 | 
			
		||||
	 && !S_ISREG(buf.st_mode) && !S_ISDIR(buf.st_mode)
 | 
			
		||||
@@ -101,7 +127,7 @@ int fgetsetflags(const char *name, unsigned long *get_flags, unsigned long set_f
 | 
			
		||||
 | 
			
		||||
	if (!get_flags) {
 | 
			
		||||
		IF_LONG_IS_WIDER(
 | 
			
		||||
			f = (int) set_flags;
 | 
			
		||||
			f = (unsigned) set_flags;
 | 
			
		||||
			r = ioctl(fd, EXT2_IOC_SETFLAGS, &f);
 | 
			
		||||
		)
 | 
			
		||||
		IF_LONG_IS_SAME(
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user