diff options
author | Lin Ming <ming.m.lin@intel.com> | 2008-09-26 22:38:07 -0400 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2008-10-22 23:14:44 -0400 |
commit | 93851b4d13de48753eaae76ed190eef7355e2c19 (patch) | |
tree | b320e20b7871f8024e992c6d130aa88106077528 /drivers/acpi | |
parent | b68bacf225e5e9758472e99505d76125ced3ea88 (diff) |
ACPICA: Reduce error to warning for incorrect method arg count
Previously aborted with error if too few arguments were passed to
a control method via the external ACPICA interface. Now issue a
warning instead and continue. Handles the case where the method
inadvertently declares too many arguments, but does not actually
use the extra ones. Applies mainly to the predefined methods.
http://bugzilla.kernel.org/show_bug.cgi?id=11032
Signed-off-by: Lin Ming <ming.m.lin@intel.com>
Signed-off-by: Bob Moore <robert.moore@intel.com>
Signed-off-by: Len Brown <len.brown@intel.com>
Diffstat (limited to 'drivers/acpi')
-rw-r--r-- | drivers/acpi/namespace/nseval.c | 17 |
1 files changed, 9 insertions, 8 deletions
diff --git a/drivers/acpi/namespace/nseval.c b/drivers/acpi/namespace/nseval.c index 0a1ae670a847..42dae12f2ef8 100644 --- a/drivers/acpi/namespace/nseval.c +++ b/drivers/acpi/namespace/nseval.c | |||
@@ -148,21 +148,22 @@ acpi_status acpi_ns_evaluate(struct acpi_evaluate_info * info) | |||
148 | info->param_count++; | 148 | info->param_count++; |
149 | } | 149 | } |
150 | 150 | ||
151 | /* Error if too few arguments were passed in */ | 151 | /* |
152 | * Warning if too few or too many arguments have been passed by the | ||
153 | * caller. We don't want to abort here with an error because an | ||
154 | * incorrect number of arguments may not cause the method to fail. | ||
155 | * However, the method will fail if there are too few arguments passed | ||
156 | * and the method attempts to use one of the missing ones. | ||
157 | */ | ||
152 | 158 | ||
153 | if (info->param_count < info->obj_desc->method.param_count) { | 159 | if (info->param_count < info->obj_desc->method.param_count) { |
154 | ACPI_ERROR((AE_INFO, | 160 | ACPI_WARNING((AE_INFO, |
155 | "Insufficient arguments - " | 161 | "Insufficient arguments - " |
156 | "method [%4.4s] needs %d, found %d", | 162 | "method [%4.4s] needs %d, found %d", |
157 | acpi_ut_get_node_name(info->resolved_node), | 163 | acpi_ut_get_node_name(info->resolved_node), |
158 | info->obj_desc->method.param_count, | 164 | info->obj_desc->method.param_count, |
159 | info->param_count)); | 165 | info->param_count)); |
160 | return_ACPI_STATUS(AE_MISSING_ARGUMENTS); | 166 | } else if (info->param_count > |
161 | } | ||
162 | |||
163 | /* Just a warning if too many arguments */ | ||
164 | |||
165 | else if (info->param_count > | ||
166 | info->obj_desc->method.param_count) { | 167 | info->obj_desc->method.param_count) { |
167 | ACPI_WARNING((AE_INFO, | 168 | ACPI_WARNING((AE_INFO, |
168 | "Excess arguments - " | 169 | "Excess arguments - " |