diff options
-rw-r--r-- | sys/dev/acpi/acpicpu.c | 39 |
1 files changed, 29 insertions, 10 deletions
diff --git a/sys/dev/acpi/acpicpu.c b/sys/dev/acpi/acpicpu.c index dc5e5329f2c..1a9bc4ae67d 100644 --- a/sys/dev/acpi/acpicpu.c +++ b/sys/dev/acpi/acpicpu.c @@ -1,4 +1,4 @@ -/* $OpenBSD: acpicpu.c,v 1.76 2016/09/02 13:59:51 pirofti Exp $ */ +/* $OpenBSD: acpicpu.c,v 1.77 2016/09/16 20:16:06 guenther Exp $ */ /* * Copyright (c) 2005 Marco Peereboom <marco@openbsd.org> * Copyright (c) 2015 Philip Guenther <guenther@openbsd.org> @@ -94,6 +94,10 @@ void acpicpu_setperf_ppc_change(struct acpicpu_pss *, int); #define ACPI_MAX_C2_LATENCY 100 #define ACPI_MAX_C3_LATENCY 1000 +#define CSD_COORD_SW_ALL 0xFC +#define CSD_COORD_SW_ANY 0xFD +#define CSD_COORD_HW_ALL 0xFE + /* Make sure throttling bits are valid,a=addr,o=offset,w=width */ #define valid_throttle(o,w,a) (a && w && (o+w)<=31 && (o>4 || (o+w)<=4)) @@ -467,21 +471,36 @@ acpicpu_add_cstatepkg(struct aml_value *val, void *arg) void acpicpu_add_cdeppkg(struct aml_value *val, void *arg) { + int64_t num_proc, coord_type, domain, cindex; + + /* + * errors: unexpected object type, bad length, mismatched length, + * and bad CSD revision + */ + if (val->type != AML_OBJTYPE_PACKAGE || val->length < 6 || + val->length != val->v_package[0]->v_integer || + val->v_package[1]->v_integer != 0) { #if 1 || defined(ACPI_DEBUG) && !defined(SMALL_KERNEL) - aml_showvalue(val); + aml_showvalue(val); #endif - if (val->type != AML_OBJTYPE_PACKAGE || val->length < 6 || - val->length != val->v_package[0]->v_integer) { printf("bogus CSD\n"); return; } - printf("\nCSD r=%lld d=%lld c=%llx n=%lld i=%lli\n", - val->v_package[1]->v_integer, - val->v_package[2]->v_integer, - val->v_package[3]->v_integer, - val->v_package[4]->v_integer, - val->v_package[5]->v_integer); + /* coordinating 'among' one CPU is trivial, ignore */ + num_proc = val->v_package[4]->v_integer; + if (num_proc == 1) + return; + + /* we practically assume the hardware will coordinate, so ignore */ + coord_type = val->v_package[3]->v_integer; + if (coord_type == CSD_COORD_HW_ALL) + return; + + domain = val->v_package[2]->v_integer; + cindex = val->v_package[5]->v_integer; + printf("\nCSD c=%#llx d=%lld n=%lld i=%lli\n", + coord_type, domain, num_proc, cindex); } int |