ACPI: fix NULL bug for HID/UID string
acpi_device->pnp.hardware_id and unique_id are now allocated pointers, replacing the previous arrays. acpi_device_install_notify_handler() oopsed on the NULL hid when probing the video device, and perhaps other uses are vulnerable too. So initialize those pointers to empty strings when there is no hid or uid. Also, free hardware_id and unique_id when when acpi_device is going to be freed. http://bugzilla.kernel.org/show_bug.cgi?id=14096 Signed-off-by: Hugh Dickins <hugh.dickins@tiscali.co.uk> Signed-off-by: Lin Ming <ming.m.lin@intel.com> Signed-off-by: Len Brown <len.brown@intel.com>
This commit is contained in:
parent
49ae80c994
commit
718fb0de8f
1 changed files with 12 additions and 8 deletions
|
@ -309,6 +309,10 @@ static void acpi_device_release(struct device *dev)
|
||||||
struct acpi_device *acpi_dev = to_acpi_device(dev);
|
struct acpi_device *acpi_dev = to_acpi_device(dev);
|
||||||
|
|
||||||
kfree(acpi_dev->pnp.cid_list);
|
kfree(acpi_dev->pnp.cid_list);
|
||||||
|
if (acpi_dev->flags.hardware_id)
|
||||||
|
kfree(acpi_dev->pnp.hardware_id);
|
||||||
|
if (acpi_dev->flags.unique_id)
|
||||||
|
kfree(acpi_dev->pnp.unique_id);
|
||||||
kfree(acpi_dev);
|
kfree(acpi_dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1137,8 +1141,9 @@ static void acpi_device_set_id(struct acpi_device *device,
|
||||||
strcpy(device->pnp.hardware_id, hid);
|
strcpy(device->pnp.hardware_id, hid);
|
||||||
device->flags.hardware_id = 1;
|
device->flags.hardware_id = 1;
|
||||||
}
|
}
|
||||||
} else
|
}
|
||||||
device->pnp.hardware_id = NULL;
|
if (!device->flags.hardware_id)
|
||||||
|
device->pnp.hardware_id = "";
|
||||||
|
|
||||||
if (uid) {
|
if (uid) {
|
||||||
device->pnp.unique_id = ACPI_ALLOCATE_ZEROED(strlen (uid) + 1);
|
device->pnp.unique_id = ACPI_ALLOCATE_ZEROED(strlen (uid) + 1);
|
||||||
|
@ -1146,8 +1151,9 @@ static void acpi_device_set_id(struct acpi_device *device,
|
||||||
strcpy(device->pnp.unique_id, uid);
|
strcpy(device->pnp.unique_id, uid);
|
||||||
device->flags.unique_id = 1;
|
device->flags.unique_id = 1;
|
||||||
}
|
}
|
||||||
} else
|
}
|
||||||
device->pnp.unique_id = NULL;
|
if (!device->flags.unique_id)
|
||||||
|
device->pnp.unique_id = "";
|
||||||
|
|
||||||
if (cid_list || cid_add) {
|
if (cid_list || cid_add) {
|
||||||
struct acpica_device_id_list *list;
|
struct acpica_device_id_list *list;
|
||||||
|
@ -1362,10 +1368,8 @@ acpi_add_single_object(struct acpi_device **child,
|
||||||
end:
|
end:
|
||||||
if (!result)
|
if (!result)
|
||||||
*child = device;
|
*child = device;
|
||||||
else {
|
else
|
||||||
kfree(device->pnp.cid_list);
|
acpi_device_release(&device->dev);
|
||||||
kfree(device);
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue