extcon: Add exception handling to prevent the NULL pointer access

This patch check whether argument is NULL to prevent NULL pointer access.

Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
This commit is contained in:
Chanwoo Choi 2015-06-21 23:48:36 +09:00
parent 0ffe8cbd51
commit 7eae43aeab

View File

@ -264,6 +264,9 @@ int extcon_update_state(struct extcon_dev *edev, u32 mask, u32 state)
unsigned long flags; unsigned long flags;
bool attached; bool attached;
if (!edev)
return -EINVAL;
spin_lock_irqsave(&edev->lock, flags); spin_lock_irqsave(&edev->lock, flags);
if (edev->state != ((edev->state & ~mask) | (state & mask))) { if (edev->state != ((edev->state & ~mask) | (state & mask))) {
@ -337,6 +340,9 @@ EXPORT_SYMBOL_GPL(extcon_update_state);
*/ */
int extcon_set_state(struct extcon_dev *edev, u32 state) int extcon_set_state(struct extcon_dev *edev, u32 state)
{ {
if (!edev)
return -EINVAL;
return extcon_update_state(edev, 0xffffffff, state); return extcon_update_state(edev, 0xffffffff, state);
} }
EXPORT_SYMBOL_GPL(extcon_set_state); EXPORT_SYMBOL_GPL(extcon_set_state);
@ -350,6 +356,9 @@ int extcon_get_cable_state_(struct extcon_dev *edev, const unsigned int id)
{ {
int index; int index;
if (!edev)
return -EINVAL;
index = find_cable_index_by_id(edev, id); index = find_cable_index_by_id(edev, id);
if (index < 0) if (index < 0)
return index; return index;
@ -394,6 +403,9 @@ int extcon_set_cable_state_(struct extcon_dev *edev, unsigned int id,
u32 state; u32 state;
int index; int index;
if (!edev)
return -EINVAL;
index = find_cable_index_by_id(edev, id); index = find_cable_index_by_id(edev, id);
if (index < 0) if (index < 0)
return index; return index;
@ -436,6 +448,9 @@ struct extcon_dev *extcon_get_extcon_dev(const char *extcon_name)
{ {
struct extcon_dev *sd; struct extcon_dev *sd;
if (!extcon_name)
return ERR_PTR(-EINVAL);
mutex_lock(&extcon_dev_list_lock); mutex_lock(&extcon_dev_list_lock);
list_for_each_entry(sd, &extcon_dev_list, entry) { list_for_each_entry(sd, &extcon_dev_list, entry) {
if (!strcmp(sd->name, extcon_name)) if (!strcmp(sd->name, extcon_name))
@ -564,6 +579,9 @@ int extcon_register_notifier(struct extcon_dev *edev, unsigned int id,
unsigned long flags; unsigned long flags;
int ret, idx; int ret, idx;
if (!edev || !nb)
return -EINVAL;
idx = find_cable_index_by_id(edev, id); idx = find_cable_index_by_id(edev, id);
spin_lock_irqsave(&edev->lock, flags); spin_lock_irqsave(&edev->lock, flags);
@ -586,6 +604,9 @@ int extcon_unregister_notifier(struct extcon_dev *edev, unsigned int id,
unsigned long flags; unsigned long flags;
int ret, idx; int ret, idx;
if (!edev || !nb)
return -EINVAL;
idx = find_cable_index_by_id(edev, id); idx = find_cable_index_by_id(edev, id);
spin_lock_irqsave(&edev->lock, flags); spin_lock_irqsave(&edev->lock, flags);
@ -646,6 +667,9 @@ struct extcon_dev *extcon_dev_allocate(const unsigned int *supported_cable)
{ {
struct extcon_dev *edev; struct extcon_dev *edev;
if (!supported_cable)
return ERR_PTR(-EINVAL);
edev = kzalloc(sizeof(*edev), GFP_KERNEL); edev = kzalloc(sizeof(*edev), GFP_KERNEL);
if (!edev) if (!edev)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
@ -746,7 +770,7 @@ int extcon_dev_register(struct extcon_dev *edev)
return ret; return ret;
} }
if (!edev->supported_cable) if (!edev || !edev->supported_cable)
return -EINVAL; return -EINVAL;
for (; edev->supported_cable[index] != EXTCON_NONE; index++); for (; edev->supported_cable[index] != EXTCON_NONE; index++);
@ -952,6 +976,9 @@ void extcon_dev_unregister(struct extcon_dev *edev)
{ {
int index; int index;
if (!edev)
return;
mutex_lock(&extcon_dev_list_lock); mutex_lock(&extcon_dev_list_lock);
list_del(&edev->entry); list_del(&edev->entry);
mutex_unlock(&extcon_dev_list_lock); mutex_unlock(&extcon_dev_list_lock);
@ -1058,6 +1085,9 @@ struct extcon_dev *extcon_get_edev_by_phandle(struct device *dev, int index)
struct device_node *node; struct device_node *node;
struct extcon_dev *edev; struct extcon_dev *edev;
if (!dev)
return ERR_PTR(-EINVAL);
if (!dev->of_node) { if (!dev->of_node) {
dev_err(dev, "device does not have a device node entry\n"); dev_err(dev, "device does not have a device node entry\n");
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);