Commit e036cc57 authored by Tomas Winkler's avatar Tomas Winkler Committed by Greg Kroah-Hartman

mei: simplify mei_open error handling

1. Perform simple checks first and only then attempt to allocate cl structure.
2. Remove open_handler_count test, this is already checked in mei_cl_link function
3. return -EMFILE instead of -ENOENT as expected by user space
Signed-off-by: default avatarTomas Winkler <tomas.winkler@intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent d7173493
...@@ -288,7 +288,13 @@ int mei_cl_link(struct mei_cl *cl, int id) ...@@ -288,7 +288,13 @@ int mei_cl_link(struct mei_cl *cl, int id)
if (id >= MEI_CLIENTS_MAX) { if (id >= MEI_CLIENTS_MAX) {
dev_err(&dev->pdev->dev, "id exceded %d", MEI_CLIENTS_MAX) ; dev_err(&dev->pdev->dev, "id exceded %d", MEI_CLIENTS_MAX) ;
return -ENOENT; return -EMFILE;
}
if (dev->open_handle_count >= MEI_MAX_OPEN_HANDLE_COUNT) {
dev_err(&dev->pdev->dev, "open_handle_count exceded %d",
MEI_MAX_OPEN_HANDLE_COUNT);
return -EMFILE;
} }
if (dev->open_handle_count >= MEI_MAX_OPEN_HANDLE_COUNT) { if (dev->open_handle_count >= MEI_MAX_OPEN_HANDLE_COUNT) {
......
...@@ -60,48 +60,45 @@ static int mei_open(struct inode *inode, struct file *file) ...@@ -60,48 +60,45 @@ static int mei_open(struct inode *inode, struct file *file)
int err; int err;
err = -ENODEV;
if (!misc->parent) if (!misc->parent)
goto out; return -ENODEV;
pdev = container_of(misc->parent, struct pci_dev, dev); pdev = container_of(misc->parent, struct pci_dev, dev);
dev = pci_get_drvdata(pdev); dev = pci_get_drvdata(pdev);
if (!dev) if (!dev)
goto out; return -ENODEV;
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
err = -ENOMEM;
cl = mei_cl_allocate(dev); cl = NULL;
if (!cl)
goto out_unlock;
err = -ENODEV; err = -ENODEV;
if (dev->dev_state != MEI_DEV_ENABLED) { if (dev->dev_state != MEI_DEV_ENABLED) {
dev_dbg(&dev->pdev->dev, "dev_state != MEI_ENABLED dev_state = %s\n", dev_dbg(&dev->pdev->dev, "dev_state != MEI_ENABLED dev_state = %s\n",
mei_dev_state_str(dev->dev_state)); mei_dev_state_str(dev->dev_state));
goto out_unlock; goto err_unlock;
}
err = -EMFILE;
if (dev->open_handle_count >= MEI_MAX_OPEN_HANDLE_COUNT) {
dev_err(&dev->pdev->dev, "open_handle_count exceded %d",
MEI_MAX_OPEN_HANDLE_COUNT);
goto out_unlock;
} }
err = -ENOMEM;
cl = mei_cl_allocate(dev);
if (!cl)
goto err_unlock;
/* open_handle_count check is handled in the mei_cl_link */
err = mei_cl_link(cl, MEI_HOST_CLIENT_ID_ANY); err = mei_cl_link(cl, MEI_HOST_CLIENT_ID_ANY);
if (err) if (err)
goto out_unlock; goto err_unlock;
file->private_data = cl; file->private_data = cl;
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
return nonseekable_open(inode, file); return nonseekable_open(inode, file);
out_unlock: err_unlock:
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
kfree(cl); kfree(cl);
out:
return err; return err;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment