ioctl.c (617ba13b31fbf505cc21799826639ef24ed94af0) | ioctl.c (dab291af8d6307a3075c3d67d0cc8f98e646cb94) |
---|---|
1/* 2 * linux/fs/ext4/ioctl.c 3 * 4 * Copyright (C) 1993, 1994, 1995 5 * Remy Card (card@masi.ibp.fr) 6 * Laboratoire MASI - Institut Blaise Pascal 7 * Universite Pierre et Marie Curie (Paris VI) 8 */ 9 10#include <linux/fs.h> | 1/* 2 * linux/fs/ext4/ioctl.c 3 * 4 * Copyright (C) 1993, 1994, 1995 5 * Remy Card (card@masi.ibp.fr) 6 * Laboratoire MASI - Institut Blaise Pascal 7 * Universite Pierre et Marie Curie (Paris VI) 8 */ 9 10#include <linux/fs.h> |
11#include <linux/jbd.h> | 11#include <linux/jbd2.h> |
12#include <linux/capability.h> 13#include <linux/ext4_fs.h> | 12#include <linux/capability.h> 13#include <linux/ext4_fs.h> |
14#include <linux/ext4_jbd.h> | 14#include <linux/ext4_jbd2.h> |
15#include <linux/time.h> 16#include <linux/compat.h> 17#include <linux/smp_lock.h> 18#include <asm/uaccess.h> 19 20int ext4_ioctl (struct inode * inode, struct file * filp, unsigned int cmd, 21 unsigned long arg) 22{ --- 191 unchanged lines hidden (view full) --- 214 215 if (IS_RDONLY(inode)) 216 return -EROFS; 217 218 if (get_user(n_blocks_count, (__u32 __user *)arg)) 219 return -EFAULT; 220 221 err = ext4_group_extend(sb, EXT4_SB(sb)->s_es, n_blocks_count); | 15#include <linux/time.h> 16#include <linux/compat.h> 17#include <linux/smp_lock.h> 18#include <asm/uaccess.h> 19 20int ext4_ioctl (struct inode * inode, struct file * filp, unsigned int cmd, 21 unsigned long arg) 22{ --- 191 unchanged lines hidden (view full) --- 214 215 if (IS_RDONLY(inode)) 216 return -EROFS; 217 218 if (get_user(n_blocks_count, (__u32 __user *)arg)) 219 return -EFAULT; 220 221 err = ext4_group_extend(sb, EXT4_SB(sb)->s_es, n_blocks_count); |
222 journal_lock_updates(EXT4_SB(sb)->s_journal); 223 journal_flush(EXT4_SB(sb)->s_journal); 224 journal_unlock_updates(EXT4_SB(sb)->s_journal); | 222 jbd2_journal_lock_updates(EXT4_SB(sb)->s_journal); 223 jbd2_journal_flush(EXT4_SB(sb)->s_journal); 224 jbd2_journal_unlock_updates(EXT4_SB(sb)->s_journal); |
225 226 return err; 227 } 228 case EXT4_IOC_GROUP_ADD: { 229 struct ext4_new_group_data input; 230 struct super_block *sb = inode->i_sb; 231 int err; 232 233 if (!capable(CAP_SYS_RESOURCE)) 234 return -EPERM; 235 236 if (IS_RDONLY(inode)) 237 return -EROFS; 238 239 if (copy_from_user(&input, (struct ext4_new_group_input __user *)arg, 240 sizeof(input))) 241 return -EFAULT; 242 243 err = ext4_group_add(sb, &input); | 225 226 return err; 227 } 228 case EXT4_IOC_GROUP_ADD: { 229 struct ext4_new_group_data input; 230 struct super_block *sb = inode->i_sb; 231 int err; 232 233 if (!capable(CAP_SYS_RESOURCE)) 234 return -EPERM; 235 236 if (IS_RDONLY(inode)) 237 return -EROFS; 238 239 if (copy_from_user(&input, (struct ext4_new_group_input __user *)arg, 240 sizeof(input))) 241 return -EFAULT; 242 243 err = ext4_group_add(sb, &input); |
244 journal_lock_updates(EXT4_SB(sb)->s_journal); 245 journal_flush(EXT4_SB(sb)->s_journal); 246 journal_unlock_updates(EXT4_SB(sb)->s_journal); | 244 jbd2_journal_lock_updates(EXT4_SB(sb)->s_journal); 245 jbd2_journal_flush(EXT4_SB(sb)->s_journal); 246 jbd2_journal_unlock_updates(EXT4_SB(sb)->s_journal); |
247 248 return err; 249 } 250 251 252 default: 253 return -ENOTTY; 254 } --- 53 unchanged lines hidden --- | 247 248 return err; 249 } 250 251 252 default: 253 return -ENOTTY; 254 } --- 53 unchanged lines hidden --- |