nouveau / ACPI: fix memory leak in ACPI _DSM related code
Fix memory leak in function nouveau_optimus_dsm() and nouveau_dsm(). Signed-off-by: Jiang Liu <jiang.liu@linux.intel.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
parent
d5c3d79e5e
commit
4988d0aeb6
1 changed files with 4 additions and 1 deletions
|
@ -111,6 +111,7 @@ static int nouveau_optimus_dsm(acpi_handle handle, int func, int arg, uint32_t *
|
||||||
|
|
||||||
if (obj->type == ACPI_TYPE_INTEGER)
|
if (obj->type == ACPI_TYPE_INTEGER)
|
||||||
if (obj->integer.value == 0x80000002) {
|
if (obj->integer.value == 0x80000002) {
|
||||||
|
kfree(output.pointer);
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -157,8 +158,10 @@ static int nouveau_dsm(acpi_handle handle, int func, int arg, uint32_t *result)
|
||||||
obj = (union acpi_object *)output.pointer;
|
obj = (union acpi_object *)output.pointer;
|
||||||
|
|
||||||
if (obj->type == ACPI_TYPE_INTEGER)
|
if (obj->type == ACPI_TYPE_INTEGER)
|
||||||
if (obj->integer.value == 0x80000002)
|
if (obj->integer.value == 0x80000002) {
|
||||||
|
kfree(output.pointer);
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
}
|
||||||
|
|
||||||
if (obj->type == ACPI_TYPE_BUFFER) {
|
if (obj->type == ACPI_TYPE_BUFFER) {
|
||||||
if (obj->buffer.length == 4 && result) {
|
if (obj->buffer.length == 4 && result) {
|
||||||
|
|
Loading…
Reference in a new issue