summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormsmith <msmith@FreeBSD.org>2000-12-01 10:19:28 +0000
committermsmith <msmith@FreeBSD.org>2000-12-01 10:19:28 +0000
commitc4c211fc902d26011ade6bfadc712cf3bcba9837 (patch)
treee46a1292c4f301bdc9579a66a3d5e312ebd8b438
parentbee39eb0e05331c63c793b8796fa8727eacb5eb0 (diff)
downloadFreeBSD-src-c4c211fc902d26011ade6bfadc712cf3bcba9837.zip
FreeBSD-src-c4c211fc902d26011ade6bfadc712cf3bcba9837.tar.gz
AcpiOsMem primitives as required by the new ACPI CA snapshot
-rw-r--r--sys/dev/acpica/Osd/OsdMemory.c92
1 files changed, 91 insertions, 1 deletions
diff --git a/sys/dev/acpica/Osd/OsdMemory.c b/sys/dev/acpica/Osd/OsdMemory.c
index ecc1d41..7eb5fe1 100644
--- a/sys/dev/acpica/Osd/OsdMemory.c
+++ b/sys/dev/acpica/Osd/OsdMemory.c
@@ -1,4 +1,5 @@
/*-
+ * Copyright (c) 2000 Mitsaru Iwasaki
* Copyright (c) 2000 Michael Smith
* Copyright (c) 2000 BSDi
* All rights reserved.
@@ -64,7 +65,7 @@ AcpiOsFree (void *Memory)
}
ACPI_STATUS
-AcpiOsMapMemory (void *PhysicalAddress, UINT32 Length, void **LogicalAddress)
+AcpiOsMapMemory (ACPI_PHYSICAL_ADDRESS PhysicalAddress, UINT32 Length, void **LogicalAddress)
{
*LogicalAddress = pmap_mapdev((vm_offset_t)PhysicalAddress, Length);
if (*LogicalAddress == NULL)
@@ -94,3 +95,92 @@ AcpiOsWritable (void *Pointer, UINT32 Length)
return(TRUE);
}
+static __inline
+UINT32
+AcpiOsMemInX (UINT32 Length, ACPI_PHYSICAL_ADDRESS InAddr)
+{
+ UINT32 Value;
+ void *LogicalAddress;
+
+ if (AcpiOsMapMemory(InAddr, Length, &LogicalAddress) != AE_OK) {
+ return(0);
+ }
+
+ switch (Length) {
+ case 1:
+ Value = (*(volatile u_int8_t *)LogicalAddress) & 0xff;
+ break;
+ case 2:
+ Value = (*(volatile u_int16_t *)LogicalAddress) & 0xffff;
+ break;
+ case 4:
+ Value = (*(volatile u_int32_t *)LogicalAddress);
+ break;
+ }
+
+ AcpiOsUnmapMemory(LogicalAddress, Length);
+
+ return(Value);
+}
+
+UINT8
+AcpiOsMemIn8 (ACPI_PHYSICAL_ADDRESS InAddr)
+{
+ return((UINT8)AcpiOsMemInX(1, InAddr));
+}
+
+UINT16
+AcpiOsMemIn16 (ACPI_PHYSICAL_ADDRESS InAddr)
+{
+ return((UINT16)AcpiOsMemInX(2, InAddr));
+}
+
+UINT32
+AcpiOsMemIn32 (ACPI_PHYSICAL_ADDRESS InAddr)
+{
+ return((UINT32)AcpiOsMemInX(4, InAddr));
+}
+
+static __inline
+void
+AcpiOsMemOutX (UINT32 Length, ACPI_PHYSICAL_ADDRESS OutAddr, UINT32 Value)
+{
+ void *LogicalAddress;
+
+ if (AcpiOsMapMemory(OutAddr, Length, &LogicalAddress) != AE_OK) {
+ return;
+ }
+
+ switch (Length) {
+ case 1:
+ (*(volatile u_int8_t *)LogicalAddress) = Value & 0xff;
+ break;
+ case 2:
+ (*(volatile u_int16_t *)LogicalAddress) = Value & 0xffff;
+ break;
+ case 4:
+ (*(volatile u_int32_t *)LogicalAddress) = Value;
+ break;
+ }
+
+ AcpiOsUnmapMemory(LogicalAddress, Length);
+}
+
+void
+AcpiOsMemOut8 (ACPI_PHYSICAL_ADDRESS OutAddr, UINT8 Value)
+{
+ AcpiOsMemOutX(1, OutAddr, (UINT32)Value);
+}
+
+void
+AcpiOsMemOut16 (ACPI_PHYSICAL_ADDRESS OutAddr, UINT16 Value)
+{
+ AcpiOsMemOutX(2, OutAddr, (UINT32)Value);
+}
+
+void
+AcpiOsMemOut32 (ACPI_PHYSICAL_ADDRESS OutAddr, UINT32 Value)
+{
+ AcpiOsMemOutX(4, OutAddr, (UINT32)Value);
+}
+
OpenPOWER on IntegriCloud