diff options
author | Tomas Winkler <tomas.winkler@intel.com> | 2015-02-10 03:39:44 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2015-03-01 22:37:00 -0500 |
commit | 03b8d3419fdfc02d1984a0db51c8b74426e12605 (patch) | |
tree | 740b43b278842ad3d88c47e1b707616e4c2c4a1a /drivers/misc/mei/main.c | |
parent | bca67d681c4864b74fa5fae9ee47e562d1e272b1 (diff) |
mei: add mei_cl_alloc_linked function
Add convenient wrapper mei_cl_alloc_linked
to simplify error handling
Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/misc/mei/main.c')
-rw-r--r-- | drivers/misc/mei/main.c | 17 |
1 files changed, 5 insertions, 12 deletions
diff --git a/drivers/misc/mei/main.c b/drivers/misc/mei/main.c index 369de0a070f1..10fc3a6a1574 100644 --- a/drivers/misc/mei/main.c +++ b/drivers/misc/mei/main.c | |||
@@ -59,24 +59,18 @@ static int mei_open(struct inode *inode, struct file *file) | |||
59 | 59 | ||
60 | mutex_lock(&dev->device_lock); | 60 | mutex_lock(&dev->device_lock); |
61 | 61 | ||
62 | cl = NULL; | ||
63 | |||
64 | err = -ENODEV; | ||
65 | if (dev->dev_state != MEI_DEV_ENABLED) { | 62 | if (dev->dev_state != MEI_DEV_ENABLED) { |
66 | dev_dbg(dev->dev, "dev_state != MEI_ENABLED dev_state = %s\n", | 63 | dev_dbg(dev->dev, "dev_state != MEI_ENABLED dev_state = %s\n", |
67 | mei_dev_state_str(dev->dev_state)); | 64 | mei_dev_state_str(dev->dev_state)); |
65 | err = -ENODEV; | ||
68 | goto err_unlock; | 66 | goto err_unlock; |
69 | } | 67 | } |
70 | 68 | ||
71 | err = -ENOMEM; | 69 | cl = mei_cl_alloc_linked(dev, MEI_HOST_CLIENT_ID_ANY); |
72 | cl = mei_cl_allocate(dev); | 70 | if (IS_ERR(cl)) { |
73 | if (!cl) | 71 | err = PTR_ERR(cl); |
74 | goto err_unlock; | ||
75 | |||
76 | /* open_handle_count check is handled in the mei_cl_link */ | ||
77 | err = mei_cl_link(cl, MEI_HOST_CLIENT_ID_ANY); | ||
78 | if (err) | ||
79 | goto err_unlock; | 72 | goto err_unlock; |
73 | } | ||
80 | 74 | ||
81 | file->private_data = cl; | 75 | file->private_data = cl; |
82 | 76 | ||
@@ -86,7 +80,6 @@ static int mei_open(struct inode *inode, struct file *file) | |||
86 | 80 | ||
87 | err_unlock: | 81 | err_unlock: |
88 | mutex_unlock(&dev->device_lock); | 82 | mutex_unlock(&dev->device_lock); |
89 | kfree(cl); | ||
90 | return err; | 83 | return err; |
91 | } | 84 | } |
92 | 85 | ||