summaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2010-06-29 15:56:36 +0200
committerSascha Hauer <s.hauer@pengutronix.de>2010-07-05 15:07:13 +0200
commit9ae9ef472ef45dbed603b61a5094790f711529d1 (patch)
treea07f59ea5f8310f490b4b26a2e6acf630198256c /fs
parent8196b9e2ccb8f75ef23123fd1cf3c02776b6ed19 (diff)
downloadbarebox-9ae9ef472ef45dbed603b61a5094790f711529d1.tar.gz
barebox-9ae9ef472ef45dbed603b61a5094790f711529d1.tar.xz
devfs: only check for ioctl function when needed
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'fs')
-rw-r--r--fs/devfs.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/fs/devfs.c b/fs/devfs.c
index 9ce9117672..7019c8d920 100644
--- a/fs/devfs.c
+++ b/fs/devfs.c
@@ -193,6 +193,8 @@ static int partition_ioctl(struct cdev *cdev, int request, void *buf)
user->eccsize = 0;
return 0;
}
+ if (!cdev->ops->ioctl)
+ return -EINVAL;
return cdev->ops->ioctl(cdev, request, buf);
default:
return -EINVAL;
@@ -202,17 +204,14 @@ static int partition_ioctl(struct cdev *cdev, int request, void *buf)
static int devfs_ioctl(struct device_d *_dev, FILE *f, int request, void *buf)
{
struct cdev *cdev = f->inode;
- int ret = -EINVAL;
+
+ if (cdev->flags & DEVFS_IS_PARTITION)
+ return partition_ioctl(cdev, request, buf);
if (!cdev->ops->ioctl)
- goto out;
+ return -EINVAL;
- if (cdev->flags & DEVFS_IS_PARTITION)
- ret = partition_ioctl(cdev, request, buf);
- else
- ret = cdev->ops->ioctl(cdev, request, buf);
-out:
- return ret;
+ return cdev->ops->ioctl(cdev, request, buf);
}
static int devfs_truncate(struct device_d *dev, FILE *f, ulong size)