Преглед изворни кода

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>
Jiang Liu пре 11 година
родитељ
комит
4988d0aeb6
1 измењених фајлова са 4 додато и 1 уклоњено
  1. 4 1
      drivers/gpu/drm/nouveau/nouveau_acpi.c

+ 4 - 1
drivers/gpu/drm/nouveau/nouveau_acpi.c

@@ -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) {