* Mostly format cleanups and comment clarifications.

* Corrected AcpiOsReadable and AcpiOsWritable to always return true in kernel and to better check bit flags otherwise.
* Removed comment about implementing acpi object cache with slab (object_cache). ACPI's own is simple, light and nice enough.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@33887 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Fredrik Holmqvist 2009-11-04 22:18:13 +00:00
parent bd34734f11
commit 66db0536d2
2 changed files with 85 additions and 89 deletions

View File

@ -127,12 +127,12 @@
#define ACPI_USE_SYSTEM_CLIBRARY
#define ACPI_USE_STANDARD_HEADERS
/* TODO: add mutex or benaphore code
#define ACPI_MUTEX_TYPE ACPI_OSL_MUTEX
#define ACPI_MUTEX sem_id
/* TODO: add mutex or benaphore code
we don't use mutex atm as it doesn't support timeout.
define ACPI_MUTEX_TYPE ACPI_OSL_MUTEX
define ACPI_MUTEX mutex *
*/
//#define ACPI_MUTEX_DEBUG
#define ACPI_USE_NATIVE_DIVIDE
#define ACPI_THREAD_ID thread_id
@ -152,12 +152,9 @@
#include <KernelExport.h>
/* ACPI's own impl is adequate. */
#define ACPI_USE_LOCAL_CACHE
/* TODO: Use Haiku's slab code */
//#define ACPI_CACHE_T struct kmem_cache
#define ACPI_FLUSH_CPU_CACHE() __asm __volatile("wbinvd");
/* Based on FreeBSD's due to lack of documentation */

View File

@ -114,11 +114,10 @@
*****************************************************************************/
#include <stdio.h>
#include <unistd.h>
#include <sys/time.h>
#include <OS.h>
#include <stdio.h>
#include <time.h>
#include <unistd.h>
#include "acpi.h"
#include "accommon.h"
@ -126,9 +125,9 @@
#include "acparser.h"
#include "acdebug.h"
#ifdef _KERNEL_MODE
#include <KernelExport.h>
#include <dpc.h>
#include <PCI.h>
#include <vm.h>
@ -177,16 +176,6 @@ FILE *AcpiGbl_OutputFile;
static uint32 sACPIRoot = 0;
static void *sInterruptHandlerData[32];
// Upcalls to AcpiExec
//ACPI_PHYSICAL_ADDRESS
//AeLocalGetRootPointer();
//void
//AeTableOverride(ACPI_TABLE_HEADER *ExistingTable, ACPI_TABLE_HEADER **NewTable);
//typedef void* (*PTHREAD_CALLBACK)(void *);
/******************************************************************************
*
@ -208,7 +197,7 @@ AcpiOsInitialize()
AcpiGbl_OutputFile = NULL;
#endif
DEBUG_FUNCTION();
return AE_OK;
return AE_OK;
}
@ -216,7 +205,7 @@ ACPI_STATUS
AcpiOsTerminate()
{
DEBUG_FUNCTION();
return AE_OK;
return AE_OK;
}
@ -268,11 +257,11 @@ AcpiOsPredefinedOverride(const ACPI_PREDEFINED_NAMES *initVal,
ACPI_STRING *newVal)
{
DEBUG_FUNCTION();
if (!initVal || !newVal)
return AE_BAD_PARAMETER;
if (!initVal || !newVal)
return AE_BAD_PARAMETER;
*newVal = NULL;
return AE_OK;
*newVal = NULL;
return AE_OK;
}
@ -294,16 +283,16 @@ AcpiOsTableOverride(ACPI_TABLE_HEADER *existingTable,
ACPI_TABLE_HEADER **newTable)
{
DEBUG_FUNCTION();
if (!existingTable || !newTable)
return AE_BAD_PARAMETER;
if (!existingTable || !newTable)
return AE_BAD_PARAMETER;
*newTable = NULL;
*newTable = NULL;
#ifdef ACPI_EXEC_APP
AeTableOverride(existingTable, newTable);
return AE_OK;
AeTableOverride(existingTable, newTable);
return AE_OK;
#else
return AE_NO_ACPI_TABLES;
return AE_NO_ACPI_TABLES;
#endif
}
@ -323,7 +312,7 @@ void
AcpiOsRedirectOutput(void *destination)
{
DEBUG_FUNCTION();
AcpiGbl_OutputFile = destination;
AcpiGbl_OutputFile = destination;
}
@ -341,12 +330,12 @@ AcpiOsRedirectOutput(void *destination)
void ACPI_INTERNAL_VAR_XFACE
AcpiOsPrintf(const char *fmt, ...)
{
va_list args;
va_list args;
DEBUG_FUNCTION();
va_start(args, fmt);
AcpiOsVprintf(fmt, args);
va_end(args);
va_start(args, fmt);
AcpiOsVprintf(fmt, args);
va_end(args);
}
@ -366,23 +355,23 @@ void
AcpiOsVprintf(const char *fmt, va_list args)
{
#ifndef _KERNEL_MODE
INT32 count = 0;
UINT8 flags;
INT32 count = 0;
UINT8 flags;
flags = AcpiGbl_DbOutputFlags;
if (flags & ACPI_DB_REDIRECTABLE_OUTPUT) {
// Output is directable to either a file (if open) or the console
if (AcpiGbl_DebugFile) {
// Output file is open, send the output there
count = vfprintf(AcpiGbl_DebugFile, fmt, args);
} else {
// No redirection, send output to console (once only!)
flags |= ACPI_DB_CONSOLE_OUTPUT;
}
}
flags = AcpiGbl_DbOutputFlags;
if (flags & ACPI_DB_REDIRECTABLE_OUTPUT) {
// Output is directable to either a file (if open) or the console
if (AcpiGbl_DebugFile) {
// Output file is open, send the output there
count = vfprintf(AcpiGbl_DebugFile, fmt, args);
} else {
// No redirection, send output to console (once only!)
flags |= ACPI_DB_CONSOLE_OUTPUT;
}
}
if (flags & ACPI_DB_CONSOLE_OUTPUT) {
count = vfprintf(AcpiGbl_OutputFile, fmt, args);
if (flags & ACPI_DB_CONSOLE_OUTPUT) {
count = vfprintf(AcpiGbl_OutputFile, fmt, args);
}
#else
static char outputBuffer[1024];
@ -426,6 +415,7 @@ AcpiOsGetLine(char *buffer)
return i;
}
/******************************************************************************
*
* FUNCTION: AcpiOsMapMemory
@ -444,7 +434,8 @@ AcpiOsMapMemory(ACPI_PHYSICAL_ADDRESS where, ACPI_SIZE length)
#ifdef _KERNEL_MODE
void *there;
area_id area = map_physical_memory("acpi_physical_mem_area", (void *)where,
length, B_ANY_KERNEL_BLOCK_ADDRESS, B_KERNEL_READ_AREA | B_KERNEL_WRITE_AREA, &there);
length, B_ANY_KERNEL_BLOCK_ADDRESS,
B_KERNEL_READ_AREA | B_KERNEL_WRITE_AREA, &there);
DEBUG_FUNCTION_F("addr: 0x%08lx; length: %lu; mapped: %p; area: %ld",
(addr_t)where, (size_t)length, there, area);
@ -457,7 +448,7 @@ AcpiOsMapMemory(ACPI_PHYSICAL_ADDRESS where, ACPI_SIZE length)
return NULL;
#endif
//return ACPI_TO_POINTER((ACPI_SIZE) where);
// return ACPI_TO_POINTER((ACPI_SIZE) where);
}
@ -496,9 +487,9 @@ AcpiOsUnmapMemory(void *where, ACPI_SIZE length)
void *
AcpiOsAllocate(ACPI_SIZE size)
{
void *mem = (void *) malloc(size);
void *mem = (void *) malloc(size);
DEBUG_FUNCTION_VF("result: %p", mem);
return mem;
return mem;
}
@ -517,7 +508,7 @@ void
AcpiOsFree(void *mem)
{
DEBUG_FUNCTION_VF("mem: %p", mem);
free(mem);
free(mem);
}
@ -537,8 +528,8 @@ ACPI_STATUS
AcpiOsCreateSemaphore(UINT32 maxUnits, UINT32 initialUnits,
ACPI_SEMAPHORE *outHandle)
{
if (!outHandle)
return AE_BAD_PARAMETER;
if (!outHandle)
return AE_BAD_PARAMETER;
*outHandle = create_sem(initialUnits, "acpi_sem");
DEBUG_FUNCTION_F("max: %lu; count: %lu; result: %ld",
@ -566,7 +557,7 @@ ACPI_STATUS
AcpiOsDeleteSemaphore(ACPI_SEMAPHORE handle)
{
DEBUG_FUNCTION_F("sem: %ld", handle);
return delete_sem(handle) == B_OK ? AE_OK : AE_BAD_PARAMETER;
return delete_sem(handle) == B_OK ? AE_OK : AE_BAD_PARAMETER;
}
@ -586,7 +577,7 @@ AcpiOsDeleteSemaphore(ACPI_SEMAPHORE handle)
ACPI_STATUS
AcpiOsWaitSemaphore(ACPI_SEMAPHORE handle, UINT32 units, UINT16 timeout)
{
ACPI_STATUS result = AE_OK;
ACPI_STATUS result = AE_OK;
DEBUG_FUNCTION_VF("sem: %ld; count: %lu; timeout: %u",
handle, units, timeout);
@ -612,7 +603,7 @@ AcpiOsWaitSemaphore(ACPI_SEMAPHORE handle, UINT32 units, UINT16 timeout)
}
DEBUG_FUNCTION_VF("sem: %ld; count: %lu; timeout: %u result: %lu",
handle, units, timeout, (uint32)result);
return result;
return result;
}
@ -655,7 +646,7 @@ AcpiOsCreateLock(ACPI_SPINLOCK *outHandle)
return AE_NO_MEMORY;
**outHandle = 0;
return AE_OK;
return AE_OK;
}
@ -663,7 +654,7 @@ void
AcpiOsDeleteLock(ACPI_SPINLOCK handle)
{
DEBUG_FUNCTION();
free(handle);
free(handle);
}
@ -754,7 +745,6 @@ AcpiOsRemoveInterruptHandler(UINT32 interruptNumber,
}
/******************************************************************************
*
* FUNCTION: AcpiOsExecute
@ -808,8 +798,8 @@ void
AcpiOsStall(UINT32 microseconds)
{
DEBUG_FUNCTION_F("microseconds: %lu", microseconds);
if (microseconds)
spin(microseconds);
if (microseconds)
spin(microseconds);
}
@ -867,8 +857,8 @@ ACPI_STATUS
AcpiOsValidateInterface(char *interface)
{
DEBUG_FUNCTION_F("interface: \"%s\"", interface);
//TODO: This looks unimplemented.
return AE_SUPPORT;
// TODO: This looks unimplemented.
return AE_SUPPORT;
}
@ -1104,17 +1094,20 @@ AcpiOsWriteMemory(ACPI_PHYSICAL_ADDRESS address, UINT32 value, UINT32 width)
BOOLEAN
AcpiOsReadable(void *pointer, ACPI_SIZE length)
{
#ifdef _KERNEL_MODE
return true;
#else
area_id id;
area_info info;
DEBUG_FUNCTION_F("addr: %p; length: %lu", pointer, (size_t)length);
id = area_for(pointer);
if (id == B_ERROR)
return false;
if (get_area_info(id, &info) != B_OK)
return false;
return info.protection & B_KERNEL_READ_AREA &&
(pointer + length) <= (info.address + info.ram_size);
if (id == B_ERROR) return false;
if (get_area_info(id, &info) != B_OK) return false;
return (info.protection & B_READ_AREA) != 0 &&
pointer + length <= info.address + info.ram_size;
#endif
}
@ -1133,17 +1126,21 @@ AcpiOsReadable(void *pointer, ACPI_SIZE length)
BOOLEAN
AcpiOsWritable(void *pointer, ACPI_SIZE length)
{
#ifdef _KERNEL_MODE
return true;
#else
area_id id;
area_info info;
DEBUG_FUNCTION_F("addr: %p; length: %lu", pointer, (size_t)length);
id = area_for(pointer);
if (id == B_ERROR)
return false;
if (get_area_info(id, &info) != B_OK)
return false;
return info.protection & (B_KERNEL_READ_AREA | B_KERNEL_WRITE_AREA) &&
(pointer + length) <= (info.address + info.ram_size);
if (id == B_ERROR) return false;
if (get_area_info(id, &info) != B_OK) return false;
return (info.protection & B_READ_AREA) != 0 &&
(info.protection & B_WRITE_AREA) != 0 &&
pointer + length <= info.address + info.ram_size;
#endif
}
@ -1165,11 +1162,10 @@ ACPI_THREAD_ID
AcpiOsGetThreadId()
{
thread_id thread = find_thread(NULL);
//TODO: Handle if thread_id is 0.
// TODO: We arn't allowed threads with id 0, handle this case.
// ACPI treats a 0 return as an error,
// but we are thread 0 in early boot
return thread == 0 ? 1 : thread;
return thread;
}
@ -1207,6 +1203,7 @@ AcpiOsSignal(UINT32 function, void *info)
return AE_OK;
}
/*
* Adapted from FreeBSD since the documentation of its intended impl
* is lacking.
@ -1217,6 +1214,7 @@ AcpiOsSignal(UINT32 function, void *info)
#define GL_BIT_OWNED 0x02
#define GL_BIT_MASK (GL_BIT_PENDING | GL_BIT_OWNED)
/*
* Adapted from FreeBSD since the documentation of its intended impl
* is lacking.
@ -1239,6 +1237,7 @@ AcpiOsAcquireGlobalLock(uint32 *lock)
return ((new < GL_BIT_MASK) ? GL_ACQUIRED : GL_BUSY);
}
/*
* Adapted from FreeBSD since the documentation of its intended impl
* is lacking.