Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/acpi Include device decoding type in acpi_mem resources



details:   https://anonhg.NetBSD.org/src/rev/b7816fff858d
branches:  trunk
changeset: 1006041:b7816fff858d
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Tue Dec 31 13:39:15 2019 +0000

description:
Include device decoding type in acpi_mem resources

diffstat:

 sys/dev/acpi/acpi_resource.c |  21 ++++++++++++---------
 sys/dev/acpi/acpivar.h       |   6 ++++--
 2 files changed, 16 insertions(+), 11 deletions(-)

diffs (118 lines):

diff -r dcef28f137e0 -r b7816fff858d sys/dev/acpi/acpi_resource.c
--- a/sys/dev/acpi/acpi_resource.c      Tue Dec 31 13:07:09 2019 +0000
+++ b/sys/dev/acpi/acpi_resource.c      Tue Dec 31 13:39:15 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: acpi_resource.c,v 1.39 2019/12/31 12:27:50 jmcneill Exp $      */
+/*     $NetBSD: acpi_resource.c,v 1.40 2019/12/31 13:39:15 jmcneill Exp $      */
 
 /*
  * Copyright 2001 Wasabi Systems, Inc.
@@ -67,7 +67,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_resource.c,v 1.39 2019/12/31 12:27:50 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_resource.c,v 1.40 2019/12/31 13:39:15 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/device.h>
@@ -148,7 +148,7 @@
                        (*ops->memory)(arg->dev, arg->context,
                            res->Data.FixedMemory32.Address,
                            res->Data.FixedMemory32.AddressLength,
-                           0);
+                           0, 0);
                break;
 
        case ACPI_RESOURCE_TYPE_MEMORY32:
@@ -162,7 +162,7 @@
                                (*ops->memory)(arg->dev, arg->context,
                                    res->Data.Memory32.Minimum,
                                    res->Data.Memory32.AddressLength,
-                                   0);
+                                   0, 0);
                } else {
                        ACPI_DEBUG_PRINT((ACPI_DB_RESOURCES,
                                             "Memory32 0x%x-0x%x/%u\n",
@@ -189,7 +189,7 @@
                                (*ops->memory)(arg->dev, arg->context,
                                    res->Data.Memory24.Minimum,
                                    res->Data.Memory24.AddressLength,
-                                   0);
+                                   0, 0);
                } else {
                        ACPI_DEBUG_PRINT((ACPI_DB_RESOURCES,
                                             "Memory24 0x%x-0x%x/%u\n",
@@ -259,7 +259,8 @@
                                        (*ops->memory)(arg->dev, arg->context,
                                            res->Data.Address32.Address.Minimum,
                                            res->Data.Address32.Address.AddressLength,
-                                           res->Data.Address32.Address.TranslationOffset);
+                                           res->Data.Address32.Address.TranslationOffset,
+                                           res->Data.Address32.Decode);
                        } else {
                                if (ops->memrange)
                                        (*ops->memrange)(arg->dev, arg->context,
@@ -313,7 +314,8 @@
                                        (*ops->memory)(arg->dev, arg->context,
                                            res->Data.Address64.Address.Minimum,
                                            res->Data.Address64.Address.AddressLength,
-                                           res->Data.Address64.Address.TranslationOffset);
+                                           res->Data.Address64.Address.TranslationOffset,
+                                           res->Data.Address64.Decode);
                        } else {
                                if (ops->memrange)
                                        (*ops->memrange)(arg->dev, arg->context,
@@ -652,7 +654,7 @@
                    uint32_t, uint32_t, uint32_t);
 
 static void    acpi_res_parse_memory(device_t, void *, uint64_t,
-                   uint64_t, uint64_t);
+                   uint64_t, uint64_t, uint8_t);
 static void    acpi_res_parse_memrange(device_t, void *, uint64_t,
                    uint64_t, uint64_t, uint64_t);
 
@@ -802,7 +804,7 @@
 
 static void
 acpi_res_parse_memory(device_t dev, void *context, uint64_t base,
-    uint64_t length, uint64_t offset)
+    uint64_t length, uint64_t offset, uint8_t decode)
 {
        struct acpi_resources *res = context;
        struct acpi_mem *ar;
@@ -819,6 +821,7 @@
        ar->ar_base = base;
        ar->ar_length = length;
        ar->ar_offset = offset;
+       ar->ar_decode = decode;
 
        SIMPLEQ_INSERT_TAIL(&res->ar_mem, ar, ar_list);
 }
diff -r dcef28f137e0 -r b7816fff858d sys/dev/acpi/acpivar.h
--- a/sys/dev/acpi/acpivar.h    Tue Dec 31 13:07:09 2019 +0000
+++ b/sys/dev/acpi/acpivar.h    Tue Dec 31 13:39:15 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: acpivar.h,v 1.79 2019/12/31 12:27:50 jmcneill Exp $    */
+/*     $NetBSD: acpivar.h,v 1.80 2019/12/31 13:39:15 jmcneill Exp $    */
 
 /*
  * Copyright 2001 Wasabi Systems, Inc.
@@ -227,6 +227,7 @@
        bus_addr_t      ar_base;
        bus_size_t      ar_length;
        bus_addr_t      ar_offset;
+       uint8_t         ar_decode;
 };
 
 struct acpi_memrange {
@@ -285,7 +286,8 @@
        void    (*iorange)(device_t, void *, uint32_t, uint32_t,
                    uint32_t, uint32_t);
 
-       void    (*memory)(device_t, void *, uint64_t, uint64_t, uint64_t);
+       void    (*memory)(device_t, void *, uint64_t, uint64_t,
+                   uint64_t, uint8_t);
        void    (*memrange)(device_t, void *, uint64_t, uint64_t,
                    uint64_t, uint64_t);
 



Home | Main Index | Thread Index | Old Index