Skip to content

Commit b5c8314

Browse files
committed
Merge tag 'led-fixes-for-5.1-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/j.anaszewski/linux-leds
Pull LED fixes from Jacek Anaszewski: - fix refcnt leak on interface rename - use memcpy in device_name_store() to avoid including garbage from a previous, longer value in the device_name - fix a potential NULL pointer dereference in case of_match_device() cannot find a match * tag 'led-fixes-for-5.1-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/j.anaszewski/linux-leds: leds: trigger: netdev: use memcpy in device_name_store leds: pca9532: fix a potential NULL pointer dereference leds: trigger: netdev: fix refcnt leak on interface rename
2 parents 3af9a52 + 9093464 commit b5c8314

File tree

2 files changed

+13
-11
lines changed

2 files changed

+13
-11
lines changed

drivers/leds/leds-pca9532.c

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -513,6 +513,7 @@ static int pca9532_probe(struct i2c_client *client,
513513
const struct i2c_device_id *id)
514514
{
515515
int devid;
516+
const struct of_device_id *of_id;
516517
struct pca9532_data *data = i2c_get_clientdata(client);
517518
struct pca9532_platform_data *pca9532_pdata =
518519
dev_get_platdata(&client->dev);
@@ -528,8 +529,11 @@ static int pca9532_probe(struct i2c_client *client,
528529
dev_err(&client->dev, "no platform data\n");
529530
return -EINVAL;
530531
}
531-
devid = (int)(uintptr_t)of_match_device(
532-
of_pca9532_leds_match, &client->dev)->data;
532+
of_id = of_match_device(of_pca9532_leds_match,
533+
&client->dev);
534+
if (unlikely(!of_id))
535+
return -EINVAL;
536+
devid = (int)(uintptr_t) of_id->data;
533537
} else {
534538
devid = id->driver_data;
535539
}

drivers/leds/trigger/ledtrig-netdev.c

Lines changed: 7 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -122,7 +122,8 @@ static ssize_t device_name_store(struct device *dev,
122122
trigger_data->net_dev = NULL;
123123
}
124124

125-
strncpy(trigger_data->device_name, buf, size);
125+
memcpy(trigger_data->device_name, buf, size);
126+
trigger_data->device_name[size] = 0;
126127
if (size > 0 && trigger_data->device_name[size - 1] == '\n')
127128
trigger_data->device_name[size - 1] = 0;
128129

@@ -301,11 +302,11 @@ static int netdev_trig_notify(struct notifier_block *nb,
301302
container_of(nb, struct led_netdev_data, notifier);
302303

303304
if (evt != NETDEV_UP && evt != NETDEV_DOWN && evt != NETDEV_CHANGE
304-
&& evt != NETDEV_REGISTER && evt != NETDEV_UNREGISTER
305-
&& evt != NETDEV_CHANGENAME)
305+
&& evt != NETDEV_REGISTER && evt != NETDEV_UNREGISTER)
306306
return NOTIFY_DONE;
307307

308-
if (strcmp(dev->name, trigger_data->device_name))
308+
if (!(dev == trigger_data->net_dev ||
309+
(evt == NETDEV_REGISTER && !strcmp(dev->name, trigger_data->device_name))))
309310
return NOTIFY_DONE;
310311

311312
cancel_delayed_work_sync(&trigger_data->work);
@@ -320,12 +321,9 @@ static int netdev_trig_notify(struct notifier_block *nb,
320321
dev_hold(dev);
321322
trigger_data->net_dev = dev;
322323
break;
323-
case NETDEV_CHANGENAME:
324324
case NETDEV_UNREGISTER:
325-
if (trigger_data->net_dev) {
326-
dev_put(trigger_data->net_dev);
327-
trigger_data->net_dev = NULL;
328-
}
325+
dev_put(trigger_data->net_dev);
326+
trigger_data->net_dev = NULL;
329327
break;
330328
case NETDEV_UP:
331329
case NETDEV_CHANGE:

0 commit comments

Comments
 (0)