summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/acpi/dsdt.c91
1 files changed, 50 insertions, 41 deletions
diff --git a/sys/dev/acpi/dsdt.c b/sys/dev/acpi/dsdt.c
index c1b3973933d..e708c3b708f 100644
--- a/sys/dev/acpi/dsdt.c
+++ b/sys/dev/acpi/dsdt.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: dsdt.c,v 1.80 2007/02/18 02:25:05 jordan Exp $ */
+/* $OpenBSD: dsdt.c,v 1.81 2007/02/20 16:52:40 marco Exp $ */
/*
* Copyright (c) 2005 Jordan Hargrave <jordan@openbsd.org>
*
@@ -1051,15 +1051,18 @@ aml_getbuffer(struct aml_value *val, int *bitlen)
case AML_OBJTYPE_INTEGER:
case AML_OBJTYPE_STATICINT:
*bitlen = aml_intlen;
- return &val->v_integer;
+ return (&val->v_integer);
+
case AML_OBJTYPE_BUFFER:
case AML_OBJTYPE_STRING:
*bitlen = val->length<<3;
- return val->v_buffer;
+ return (val->v_buffer);
+
default:
aml_die("getvbi");
}
- return NULL;
+
+ return (NULL);
}
/*
@@ -1079,9 +1082,8 @@ aml_fieldio(struct aml_scope *scope, struct aml_value *field,
blen = field->v_field.bitlen;
dnprintf(55,"--fieldio: %s [%s] bp:%.4x bl:%.4x\n",
- mode == ACPI_IOREAD ? "rd" : "wr",
- aml_nodename(field->node),
- bpos, blen);
+ mode == ACPI_IOREAD ? "rd" : "wr",
+ aml_nodename(field->node), bpos, blen);
aml_lockfield(scope, field);
switch (field->v_field.type) {
@@ -1095,11 +1097,12 @@ aml_fieldio(struct aml_scope *scope, struct aml_value *field,
aml_fieldio(scope, &tf, res, mode);
#ifdef ACPI_DEBUG
dnprintf(55, "-- post indexfield %x,%x @ %x,%x\n",
- bpos & 3, blen,
- field->v_field.ref2->v_field.bitpos,
- field->v_field.ref2->v_field.bitlen);
+ bpos & 3, blen,
+ field->v_field.ref2->v_field.bitpos,
+ field->v_field.ref2->v_field.bitlen);
+
iobuf = aml_getbuffer(res, &aligned);
- aml_dump(aligned>>3, iobuf);
+ aml_dump(aligned >> 3, iobuf);
#endif
break;
case AMLOP_BANKFIELD:
@@ -1112,11 +1115,12 @@ aml_fieldio(struct aml_scope *scope, struct aml_value *field,
aml_fieldio(scope, &tf, res, mode);
#ifdef ACPI_DEBUG
dnprintf(55, "-- post bankfield %x,%x @ %x,%x\n",
- bpos & 3, blen,
- field->v_field.ref2->v_field.bitpos,
- field->v_field.ref2->v_field.bitlen);
+ bpos & 3, blen,
+ field->v_field.ref2->v_field.bitpos,
+ field->v_field.ref2->v_field.bitlen);
+
iobuf = aml_getbuffer(res, &aligned);
- aml_dump(aligned>>3, iobuf);
+ aml_dump(aligned >> 3, iobuf);
#endif
break;
case AMLOP_FIELD:
@@ -1143,8 +1147,8 @@ aml_fieldio(struct aml_scope *scope, struct aml_value *field,
/* Pre-allocate return value for reads */
if (mode == ACPI_IOREAD)
- _aml_setvalue(res, AML_OBJTYPE_BUFFER,
- (field->v_field.bitlen+7)>>3, NULL);
+ _aml_setvalue(res, AML_OBJTYPE_BUFFER,
+ (field->v_field.bitlen+7)>>3, NULL);
/* Get aligned bitpos/bitlength */
blen = ((bpos & mask) + blen + mask) & ~mask;
@@ -1157,63 +1161,65 @@ aml_fieldio(struct aml_scope *scope, struct aml_value *field,
if (aligned) {
iobuf = aml_getbuffer(res, &aligned);
aml_gasio(scope->sc, pop->v_opregion.iospace,
- iobase, pop->v_opregion.iolen, bpos, blen, mask+1,
- iobuf, mode);
+ iobase, pop->v_opregion.iolen, bpos, blen,
+ mask + 1, iobuf, mode);
#ifdef ACPI_DEBUG
dnprintf(55, "aligned: %s @ %.4x:%.4x + %.4x\n",
- mode == ACPI_IOREAD ? "rd" : "wr",
- bpos, blen, aligned);
- aml_dump(blen>>3, iobuf);
+ mode == ACPI_IOREAD ? "rd" : "wr",
+ bpos, blen, aligned);
+
+ aml_dump(blen >> 3, iobuf);
#endif
}
else if (mode == ACPI_IOREAD) {
iobuf = acpi_os_malloc(blen>>3);
aml_gasio(scope->sc, pop->v_opregion.iospace,
- iobase, pop->v_opregion.iolen, bpos, blen, mask+1,
- iobuf, mode);
+ iobase, pop->v_opregion.iolen, bpos, blen,
+ mask + 1, iobuf, mode);
/* ASSERT: res is buffer type as it was set above */
aml_bufcpy(res->v_buffer, 0, iobuf,
- field->v_field.bitpos & mask,
- field->v_field.bitlen);
+ field->v_field.bitpos & mask,
+ field->v_field.bitlen);
#ifdef ACPI_DEBUG
dnprintf(55,"non-aligned read: %.4x:%.4x : ",
field->v_field.bitpos & mask,
field->v_field.bitlen);
- aml_dump(blen>>3, iobuf);
+
+ aml_dump(blen >> 3, iobuf);
dnprintf(55,"post-read: ");
aml_dump((field->v_field.bitlen+7)>>3, res->v_buffer);
#endif
acpi_os_free(iobuf);
}
else {
- iobuf = acpi_os_malloc(blen>>3);
+ iobuf = acpi_os_malloc(blen >> 3);
switch (AML_FIELD_UPDATE(field->v_field.flags)) {
case AML_FIELD_WRITEASONES:
- memset(iobuf, 0xFF, blen>>3);
+ memset(iobuf, 0xFF, blen >> 3);
break;
case AML_FIELD_PRESERVE:
aml_gasio(scope->sc, pop->v_opregion.iospace,
- iobase, pop->v_opregion.iolen, bpos, blen, mask+1,
- iobuf, ACPI_IOREAD);
+ iobase, pop->v_opregion.iolen, bpos, blen,
+ mask + 1, iobuf, ACPI_IOREAD);
break;
}
/* Copy into IOBUF */
iobuf2 = aml_getbuffer(res, &aligned);
- aml_bufcpy(iobuf, field->v_field.bitpos & mask,
- iobuf2, 0,
- field->v_field.bitlen);
+ aml_bufcpy(iobuf, field->v_field.bitpos & mask,
+ iobuf2, 0, field->v_field.bitlen);
#ifdef ACPI_DEBUG
dnprintf(55,"non-aligned write: %.4x:%.4x : ",
- field->v_field.bitpos & mask,
- field->v_field.bitlen);
- aml_dump(blen>>3, iobuf);
+ field->v_field.bitpos & mask,
+ field->v_field.bitlen);
+
+ aml_dump(blen >> 3, iobuf);
#endif
aml_gasio(scope->sc, pop->v_opregion.iospace,
- iobase, pop->v_opregion.iolen, bpos, blen, mask+1,
- iobuf, mode);
+ iobase, pop->v_opregion.iolen, bpos, blen,
+ mask + 1, iobuf, mode);
acpi_os_free(iobuf);
}
@@ -1583,8 +1589,10 @@ aml_setvalue(struct aml_scope *scope, struct aml_value *lhs,
aml_fieldio(scope, lhs, rhs, ACPI_IOWRITE);
break;
case AML_OBJTYPE_DEBUGOBJ:
+#ifdef ACPI_DEBUG
printf("-- debug --\n");
aml_showvalue(rhs, 50);
+#endif
break;
case AML_OBJTYPE_STATICINT:
if (lhs->node) {
@@ -1601,14 +1609,15 @@ aml_setvalue(struct aml_scope *scope, struct aml_value *lhs,
if (rhs->type == AML_OBJTYPE_BUFFER)
_aml_setvalue(lhs, AML_OBJTYPE_BUFFER, rhs->length,
rhs->v_buffer);
- else if (rhs->type == AML_OBJTYPE_INTEGER || rhs->type == AML_OBJTYPE_STATICINT)
+ else if (rhs->type == AML_OBJTYPE_INTEGER ||
+ rhs->type == AML_OBJTYPE_STATICINT)
_aml_setvalue(lhs, AML_OBJTYPE_BUFFER,
sizeof(rhs->v_integer), &rhs->v_integer);
else if (rhs->type == AML_OBJTYPE_STRING)
_aml_setvalue(lhs, AML_OBJTYPE_BUFFER, rhs->length+1,
rhs->v_string);
else {
- //aml_showvalue(rhs);
+ /* aml_showvalue(rhs); */
aml_die("setvalue.buf : %x", aml_pc(scope->pos));
}
break;