Commit 9cc8cd08 authored by Mario Limonciello's avatar Mario Limonciello Committed by Rafael J. Wysocki
Browse files

ACPI: x86: s2idle: Fix a logic error parsing AMD constraints table



The constraints table should be resetting the `list` object
after running through all of `info_obj` iterations.

This adjusts whitespace as well as less code will now be included
with each loop. This fixes a functional problem is fixed where a
badly formed package in the inner loop may have incorrect data.

Fixes: 146f1ed8 ("ACPI: PM: s2idle: Add AMD support to handle _DSM")
Signed-off-by: default avatarMario Limonciello <mario.limonciello@amd.com>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 883cf0d4
Loading
Loading
Loading
Loading
+12 −19
Original line number Diff line number Diff line
@@ -135,12 +135,11 @@ static void lpi_device_get_constraints_amd(void)
				struct lpi_constraints *list;
				acpi_status status;

				list = &lpi_constraints_table[lpi_constraints_table_size];

				for (k = 0; k < info_obj->package.count; k++) {
					union acpi_object *obj = &info_obj->package.elements[k];

					list = &lpi_constraints_table[lpi_constraints_table_size];
					list->min_dstate = -1;

					switch (k) {
					case 0:
						dev_info.enabled = obj->integer.value;
@@ -155,13 +154,13 @@ static void lpi_device_get_constraints_amd(void)
						dev_info.min_dstate = obj->integer.value;
						break;
					}
				}

				if (!dev_info.enabled || !dev_info.name ||
				    !dev_info.min_dstate)
					continue;

					status = acpi_get_handle(NULL, dev_info.name,
								 &list->handle);
				status = acpi_get_handle(NULL, dev_info.name, &list->handle);
				if (ACPI_FAILURE(status))
					continue;

@@ -170,12 +169,6 @@ static void lpi_device_get_constraints_amd(void)

				list->min_dstate = dev_info.min_dstate;

					if (list->min_dstate < 0) {
						acpi_handle_debug(lps0_device_handle,
								  "Incomplete constraint defined\n");
						continue;
					}
				}
				lpi_constraints_table_size++;
			}
		}