Commit 8668fdd6 authored by Eric Lapuyade's avatar Eric Lapuyade Committed by John W. Linville

NFC: Core must test the device polling state inside the device lock

There can ever be only one call to nfc_targets_found() after polling
has been engaged. This could be from a target discovered event from
the driver, or from an error handler to notify poll will never complete.
Signed-off-by: default avatarEric Lapuyade <eric.lapuyade@intel.com>
Signed-off-by: default avatarSamuel Ortiz <sameo@linux.intel.com>
parent a070c859
...@@ -571,13 +571,18 @@ int nfc_targets_found(struct nfc_dev *dev, ...@@ -571,13 +571,18 @@ int nfc_targets_found(struct nfc_dev *dev,
pr_debug("dev_name=%s n_targets=%d\n", dev_name(&dev->dev), n_targets); pr_debug("dev_name=%s n_targets=%d\n", dev_name(&dev->dev), n_targets);
dev->polling = false;
for (i = 0; i < n_targets; i++) for (i = 0; i < n_targets; i++)
targets[i].idx = dev->target_next_idx++; targets[i].idx = dev->target_next_idx++;
device_lock(&dev->dev); device_lock(&dev->dev);
if (dev->polling == false) {
device_unlock(&dev->dev);
return 0;
}
dev->polling = false;
dev->targets_generation++; dev->targets_generation++;
kfree(dev->targets); kfree(dev->targets);
......
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