]> Pileus Git - ~andy/linux/commitdiff
ubi/cdev: switch to fixed_size_llseek()
authorAl Viro <viro@zeniv.linux.org.uk>
Sun, 23 Jun 2013 08:30:24 +0000 (12:30 +0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Sat, 29 Jun 2013 08:57:49 +0000 (12:57 +0400)
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
drivers/mtd/ubi/cdev.c

index 4f02848bb2bc5d843900d6762b10edec23e3dd84..8ca49f2043e4b8a7fe41109129de5760995b59d4 100644 (file)
@@ -155,7 +155,6 @@ static loff_t vol_cdev_llseek(struct file *file, loff_t offset, int origin)
 {
        struct ubi_volume_desc *desc = file->private_data;
        struct ubi_volume *vol = desc->vol;
-       loff_t new_offset;
 
        if (vol->updating) {
                /* Update is in progress, seeking is prohibited */
@@ -163,30 +162,7 @@ static loff_t vol_cdev_llseek(struct file *file, loff_t offset, int origin)
                return -EBUSY;
        }
 
-       switch (origin) {
-       case 0: /* SEEK_SET */
-               new_offset = offset;
-               break;
-       case 1: /* SEEK_CUR */
-               new_offset = file->f_pos + offset;
-               break;
-       case 2: /* SEEK_END */
-               new_offset = vol->used_bytes + offset;
-               break;
-       default:
-               return -EINVAL;
-       }
-
-       if (new_offset < 0 || new_offset > vol->used_bytes) {
-               ubi_err("bad seek %lld", new_offset);
-               return -EINVAL;
-       }
-
-       dbg_gen("seek volume %d, offset %lld, origin %d, new offset %lld",
-               vol->vol_id, offset, origin, new_offset);
-
-       file->f_pos = new_offset;
-       return new_offset;
+       return fixed_size_llseek(file, offset, origin, vol->used_bytes);
 }
 
 static int vol_cdev_fsync(struct file *file, loff_t start, loff_t end,