2005-04-16 15:20:36 -07:00
/*******************************************************************************
*
* Module Name : rsdump - Functions to display the resource structures .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
* Copyright ( C ) 2000 - 2005 , R . Byron Moore
* All rights reserved .
*
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions , and the following disclaimer ,
* without modification .
* 2. Redistributions in binary form must reproduce at minimum a disclaimer
* substantially similar to the " NO WARRANTY " disclaimer below
* ( " Disclaimer " ) and any redistribution must be conditioned upon
* including a substantially similar Disclaimer requirement for further
* binary redistribution .
* 3. Neither the names of the above - listed copyright holders nor the names
* of any contributors may be used to endorse or promote products derived
* from this software without specific prior written permission .
*
* Alternatively , this software may be distributed under the terms of the
* GNU General Public License ( " GPL " ) version 2 as published by the Free
* Software Foundation .
*
* NO WARRANTY
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* " AS IS " AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT
* LIMITED TO , THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT
* HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL , EXEMPLARY , OR CONSEQUENTIAL
* DAMAGES ( INCLUDING , BUT NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES ; LOSS OF USE , DATA , OR PROFITS ; OR BUSINESS INTERRUPTION )
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN CONTRACT ,
* STRICT LIABILITY , OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE , EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES .
*/
# include <acpi/acpi.h>
# include <acpi/acresrc.h>
# define _COMPONENT ACPI_RESOURCES
ACPI_MODULE_NAME ( " rsdump " )
2005-05-13 00:00:00 -04:00
# if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER)
2005-04-18 22:49:35 -04:00
/* Local prototypes */
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
static void
acpi_rs_dump_irq (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_address16 (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_address32 (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_address64 (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_dma (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_io (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_extended_irq (
union acpi_resource_data * data ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
static void
acpi_rs_dump_fixed_io (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_fixed_memory32 (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_memory24 (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_memory32 (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_start_depend_fns (
union acpi_resource_data * data ) ;
static void
acpi_rs_dump_vendor_specific (
union acpi_resource_data * data ) ;
2005-04-16 15:20:36 -07:00
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_irq
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_irq (
union acpi_resource_data * data )
{
struct acpi_resource_irq * irq_data = ( struct acpi_resource_irq * ) data ;
u8 index = 0 ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " IRQ Resource \n " ) ;
acpi_os_printf ( " %s Triggered \n " ,
2005-04-18 22:49:35 -04:00
ACPI_LEVEL_SENSITIVE = = irq_data - > edge_level ? " Level " : " Edge " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Active %s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_ACTIVE_LOW = = irq_data - > active_high_low ? " Low " : " High " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " %s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_SHARED = = irq_data - > shared_exclusive ? " Shared " : " Exclusive " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " %X Interrupts ( " , irq_data - > number_of_interrupts ) ;
for ( index = 0 ; index < irq_data - > number_of_interrupts ; index + + ) {
acpi_os_printf ( " %X " , irq_data - > interrupts [ index ] ) ;
}
acpi_os_printf ( " ) \n " ) ;
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_dma
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_dma (
union acpi_resource_data * data )
{
struct acpi_resource_dma * dma_data = ( struct acpi_resource_dma * ) data ;
u8 index = 0 ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " DMA Resource \n " ) ;
switch ( dma_data - > type ) {
case ACPI_COMPATIBILITY :
acpi_os_printf ( " Compatibility mode \n " ) ;
break ;
case ACPI_TYPE_A :
acpi_os_printf ( " Type A \n " ) ;
break ;
case ACPI_TYPE_B :
acpi_os_printf ( " Type B \n " ) ;
break ;
case ACPI_TYPE_F :
acpi_os_printf ( " Type F \n " ) ;
break ;
default :
acpi_os_printf ( " Invalid DMA type \n " ) ;
break ;
}
acpi_os_printf ( " %sBus Master \n " ,
2005-04-18 22:49:35 -04:00
ACPI_BUS_MASTER = = dma_data - > bus_master ? " " : " Not a " ) ;
2005-04-16 15:20:36 -07:00
switch ( dma_data - > transfer ) {
case ACPI_TRANSFER_8 :
acpi_os_printf ( " 8-bit only transfer \n " ) ;
break ;
case ACPI_TRANSFER_8_16 :
acpi_os_printf ( " 8 and 16-bit transfer \n " ) ;
break ;
case ACPI_TRANSFER_16 :
acpi_os_printf ( " 16 bit only transfer \n " ) ;
break ;
default :
acpi_os_printf ( " Invalid transfer preference \n " ) ;
break ;
}
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Number of Channels: %X ( " ,
dma_data - > number_of_channels ) ;
2005-04-16 15:20:36 -07:00
for ( index = 0 ; index < dma_data - > number_of_channels ; index + + ) {
acpi_os_printf ( " %X " , dma_data - > channels [ index ] ) ;
}
acpi_os_printf ( " ) \n " ) ;
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_start_depend_fns
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_start_depend_fns (
union acpi_resource_data * data )
{
struct acpi_resource_start_dpf * sdf_data = ( struct acpi_resource_start_dpf * ) data ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " Start Dependent Functions Resource \n " ) ;
switch ( sdf_data - > compatibility_priority ) {
case ACPI_GOOD_CONFIGURATION :
acpi_os_printf ( " Good configuration \n " ) ;
break ;
case ACPI_ACCEPTABLE_CONFIGURATION :
acpi_os_printf ( " Acceptable configuration \n " ) ;
break ;
case ACPI_SUB_OPTIMAL_CONFIGURATION :
acpi_os_printf ( " Sub-optimal configuration \n " ) ;
break ;
default :
acpi_os_printf ( " Invalid compatibility priority \n " ) ;
break ;
}
switch ( sdf_data - > performance_robustness ) {
case ACPI_GOOD_CONFIGURATION :
acpi_os_printf ( " Good configuration \n " ) ;
break ;
case ACPI_ACCEPTABLE_CONFIGURATION :
acpi_os_printf ( " Acceptable configuration \n " ) ;
break ;
case ACPI_SUB_OPTIMAL_CONFIGURATION :
acpi_os_printf ( " Sub-optimal configuration \n " ) ;
break ;
default :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Invalid performance robustness preference \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
}
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_io
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_io (
union acpi_resource_data * data )
{
struct acpi_resource_io * io_data = ( struct acpi_resource_io * ) data ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " Io Resource \n " ) ;
acpi_os_printf ( " %d bit decode \n " ,
2005-04-18 22:49:35 -04:00
ACPI_DECODE_16 = = io_data - > io_decode ? 16 : 10 ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Range minimum base: %08X \n " , io_data - > min_base_address ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Range maximum base: %08X \n " , io_data - > max_base_address ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Alignment: %08X \n " , io_data - > alignment ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Range Length: %08X \n " , io_data - > range_length ) ;
2005-04-16 15:20:36 -07:00
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_fixed_io
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_fixed_io (
union acpi_resource_data * data )
{
struct acpi_resource_fixed_io * fixed_io_data = ( struct acpi_resource_fixed_io * ) data ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " Fixed Io Resource \n " ) ;
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Range base address: %08X " , fixed_io_data - > base_address ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Range length: %08X " , fixed_io_data - > range_length ) ;
2005-04-16 15:20:36 -07:00
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_vendor_specific
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_vendor_specific (
union acpi_resource_data * data )
{
struct acpi_resource_vendor * vendor_data = ( struct acpi_resource_vendor * ) data ;
u16 index = 0 ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " Vendor Specific Resource \n " ) ;
acpi_os_printf ( " Length: %08X \n " , vendor_data - > length ) ;
for ( index = 0 ; index < vendor_data - > length ; index + + ) {
acpi_os_printf ( " Byte %X: %08X \n " ,
2005-04-18 22:49:35 -04:00
index , vendor_data - > reserved [ index ] ) ;
2005-04-16 15:20:36 -07:00
}
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_memory24
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_memory24 (
union acpi_resource_data * data )
{
struct acpi_resource_mem24 * memory24_data = ( struct acpi_resource_mem24 * ) data ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " 24-Bit Memory Range Resource \n " ) ;
acpi_os_printf ( " Read%s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_READ_WRITE_MEMORY = =
memory24_data - > read_write_attribute ?
" /Write " : " only " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Range minimum base: %08X \n " ,
2005-04-18 22:49:35 -04:00
memory24_data - > min_base_address ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Range maximum base: %08X \n " ,
2005-04-18 22:49:35 -04:00
memory24_data - > max_base_address ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Alignment: %08X \n " , memory24_data - > alignment ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Range length: %08X \n " , memory24_data - > range_length ) ;
2005-04-16 15:20:36 -07:00
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_memory32
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_memory32 (
union acpi_resource_data * data )
{
struct acpi_resource_mem32 * memory32_data = ( struct acpi_resource_mem32 * ) data ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " 32-Bit Memory Range Resource \n " ) ;
acpi_os_printf ( " Read%s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_READ_WRITE_MEMORY = =
memory32_data - > read_write_attribute ?
" /Write " : " only " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Range minimum base: %08X \n " ,
2005-04-18 22:49:35 -04:00
memory32_data - > min_base_address ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Range maximum base: %08X \n " ,
2005-04-18 22:49:35 -04:00
memory32_data - > max_base_address ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Alignment: %08X \n " , memory32_data - > alignment ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Range length: %08X \n " , memory32_data - > range_length ) ;
2005-04-16 15:20:36 -07:00
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_fixed_memory32
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN :
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_fixed_memory32 (
union acpi_resource_data * data )
{
2005-04-18 22:49:35 -04:00
struct acpi_resource_fixed_mem32 * fixed_memory32_data =
( struct acpi_resource_fixed_mem32 * ) data ;
2005-04-16 15:20:36 -07:00
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " 32-Bit Fixed Location Memory Range Resource \n " ) ;
acpi_os_printf ( " Read%s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_READ_WRITE_MEMORY = =
fixed_memory32_data - > read_write_attribute ? " /Write " : " Only " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Range base address: %08X \n " ,
2005-04-18 22:49:35 -04:00
fixed_memory32_data - > range_base_address ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Range length: %08X \n " ,
2005-04-18 22:49:35 -04:00
fixed_memory32_data - > range_length ) ;
2005-04-16 15:20:36 -07:00
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_address16
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_address16 (
union acpi_resource_data * data )
{
struct acpi_resource_address16 * address16_data = ( struct acpi_resource_address16 * ) data ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " 16-Bit Address Space Resource \n " ) ;
acpi_os_printf ( " Resource Type: " ) ;
switch ( address16_data - > resource_type ) {
case ACPI_MEMORY_RANGE :
acpi_os_printf ( " Memory Range \n " ) ;
switch ( address16_data - > attribute . memory . cache_attribute ) {
case ACPI_NON_CACHEABLE_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Noncacheable memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_CACHABLE_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Cacheable memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_WRITE_COMBINING_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Write-combining memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_PREFETCHABLE_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Prefetchable memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
default :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Invalid cache attribute \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
}
acpi_os_printf ( " Type Specific: Read%s \n " ,
ACPI_READ_WRITE_MEMORY = =
2005-04-18 22:49:35 -04:00
address16_data - > attribute . memory . read_write_attribute ?
" /Write " : " Only " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_IO_RANGE :
acpi_os_printf ( " I/O Range \n " ) ;
switch ( address16_data - > attribute . io . range_attribute ) {
case ACPI_NON_ISA_ONLY_RANGES :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Non-ISA Io Addresses \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_ISA_ONLY_RANGES :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: ISA Io Addresses \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_ENTIRE_RANGE :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: ISA and non-ISA Io Addresses \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
default :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Invalid range attribute \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
}
acpi_os_printf ( " Type Specific: %s Translation \n " ,
ACPI_SPARSE_TRANSLATION = =
2005-04-18 22:49:35 -04:00
address16_data - > attribute . io . translation_attribute ?
" Sparse " : " Dense " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_BUS_NUMBER_RANGE :
acpi_os_printf ( " Bus Number Range \n " ) ;
break ;
default :
acpi_os_printf ( " 0x%2.2X \n " , address16_data - > resource_type ) ;
break ;
}
acpi_os_printf ( " Resource %s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_CONSUMER = = address16_data - > producer_consumer ?
2005-04-16 15:20:36 -07:00
" Consumer " : " Producer " ) ;
acpi_os_printf ( " %s decode \n " ,
2005-04-18 22:49:35 -04:00
ACPI_SUB_DECODE = = address16_data - > decode ?
" Subtractive " : " Positive " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Min address is %s fixed \n " ,
2005-04-18 22:49:35 -04:00
ACPI_ADDRESS_FIXED = = address16_data - > min_address_fixed ?
" " : " not " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Max address is %s fixed \n " ,
2005-04-18 22:49:35 -04:00
ACPI_ADDRESS_FIXED = = address16_data - > max_address_fixed ?
" " : " not " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Granularity: %08X \n " ,
2005-04-18 22:49:35 -04:00
address16_data - > granularity ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address range min: %08X \n " ,
2005-04-18 22:49:35 -04:00
address16_data - > min_address_range ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address range max: %08X \n " ,
2005-04-18 22:49:35 -04:00
address16_data - > max_address_range ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address translation offset: %08X \n " ,
2005-04-18 22:49:35 -04:00
address16_data - > address_translation_offset ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address Length: %08X \n " ,
2005-04-18 22:49:35 -04:00
address16_data - > address_length ) ;
2005-04-16 15:20:36 -07:00
if ( 0xFF ! = address16_data - > resource_source . index ) {
acpi_os_printf ( " Resource Source Index: %X \n " ,
2005-04-18 22:49:35 -04:00
address16_data - > resource_source . index ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Resource Source: %s \n " ,
2005-04-18 22:49:35 -04:00
address16_data - > resource_source . string_ptr ) ;
2005-04-16 15:20:36 -07:00
}
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_address32
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_address32 (
union acpi_resource_data * data )
{
struct acpi_resource_address32 * address32_data = ( struct acpi_resource_address32 * ) data ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " 32-Bit Address Space Resource \n " ) ;
switch ( address32_data - > resource_type ) {
case ACPI_MEMORY_RANGE :
acpi_os_printf ( " Resource Type: Memory Range \n " ) ;
switch ( address32_data - > attribute . memory . cache_attribute ) {
case ACPI_NON_CACHEABLE_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Noncacheable memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_CACHABLE_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Cacheable memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_WRITE_COMBINING_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Write-combining memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_PREFETCHABLE_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Prefetchable memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
default :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Invalid cache attribute \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
}
acpi_os_printf ( " Type Specific: Read%s \n " ,
ACPI_READ_WRITE_MEMORY = =
2005-04-18 22:49:35 -04:00
address32_data - > attribute . memory . read_write_attribute ?
" /Write " : " Only " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_IO_RANGE :
acpi_os_printf ( " Resource Type: Io Range \n " ) ;
switch ( address32_data - > attribute . io . range_attribute ) {
case ACPI_NON_ISA_ONLY_RANGES :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Non-ISA Io Addresses \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_ISA_ONLY_RANGES :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: ISA Io Addresses \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_ENTIRE_RANGE :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: ISA and non-ISA Io Addresses \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
default :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Invalid Range attribute " ) ;
2005-04-16 15:20:36 -07:00
break ;
}
acpi_os_printf ( " Type Specific: %s Translation \n " ,
ACPI_SPARSE_TRANSLATION = =
2005-04-18 22:49:35 -04:00
address32_data - > attribute . io . translation_attribute ?
" Sparse " : " Dense " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_BUS_NUMBER_RANGE :
acpi_os_printf ( " Resource Type: Bus Number Range \n " ) ;
break ;
default :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Resource Type: 0x%2.2X \n " ,
address32_data - > resource_type ) ;
2005-04-16 15:20:36 -07:00
break ;
}
acpi_os_printf ( " Resource %s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_CONSUMER = = address32_data - > producer_consumer ?
" Consumer " : " Producer " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " %s decode \n " ,
2005-04-18 22:49:35 -04:00
ACPI_SUB_DECODE = = address32_data - > decode ?
" Subtractive " : " Positive " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Min address is %s fixed \n " ,
2005-04-18 22:49:35 -04:00
ACPI_ADDRESS_FIXED = = address32_data - > min_address_fixed ?
" " : " not " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Max address is %s fixed \n " ,
2005-04-18 22:49:35 -04:00
ACPI_ADDRESS_FIXED = = address32_data - > max_address_fixed ?
" " : " not " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Granularity: %08X \n " ,
2005-04-18 22:49:35 -04:00
address32_data - > granularity ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address range min: %08X \n " ,
2005-04-18 22:49:35 -04:00
address32_data - > min_address_range ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address range max: %08X \n " ,
2005-04-18 22:49:35 -04:00
address32_data - > max_address_range ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address translation offset: %08X \n " ,
2005-04-18 22:49:35 -04:00
address32_data - > address_translation_offset ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address Length: %08X \n " ,
2005-04-18 22:49:35 -04:00
address32_data - > address_length ) ;
2005-04-16 15:20:36 -07:00
if ( 0xFF ! = address32_data - > resource_source . index ) {
acpi_os_printf ( " Resource Source Index: %X \n " ,
2005-04-18 22:49:35 -04:00
address32_data - > resource_source . index ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Resource Source: %s \n " ,
2005-04-18 22:49:35 -04:00
address32_data - > resource_source . string_ptr ) ;
2005-04-16 15:20:36 -07:00
}
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_address64
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_address64 (
union acpi_resource_data * data )
{
struct acpi_resource_address64 * address64_data = ( struct acpi_resource_address64 * ) data ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " 64-Bit Address Space Resource \n " ) ;
switch ( address64_data - > resource_type ) {
case ACPI_MEMORY_RANGE :
acpi_os_printf ( " Resource Type: Memory Range \n " ) ;
switch ( address64_data - > attribute . memory . cache_attribute ) {
case ACPI_NON_CACHEABLE_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Noncacheable memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_CACHABLE_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Cacheable memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_WRITE_COMBINING_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Write-combining memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_PREFETCHABLE_MEMORY :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Prefetchable memory \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
default :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Invalid cache attribute \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
}
acpi_os_printf ( " Type Specific: Read%s \n " ,
ACPI_READ_WRITE_MEMORY = =
2005-04-18 22:49:35 -04:00
address64_data - > attribute . memory . read_write_attribute ?
" /Write " : " Only " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_IO_RANGE :
acpi_os_printf ( " Resource Type: Io Range \n " ) ;
switch ( address64_data - > attribute . io . range_attribute ) {
case ACPI_NON_ISA_ONLY_RANGES :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Non-ISA Io Addresses \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_ISA_ONLY_RANGES :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: ISA Io Addresses \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_ENTIRE_RANGE :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: ISA and non-ISA Io Addresses \n " ) ;
2005-04-16 15:20:36 -07:00
break ;
default :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Type Specific: Invalid Range attribute " ) ;
2005-04-16 15:20:36 -07:00
break ;
}
acpi_os_printf ( " Type Specific: %s Translation \n " ,
ACPI_SPARSE_TRANSLATION = =
2005-04-18 22:49:35 -04:00
address64_data - > attribute . io . translation_attribute ?
" Sparse " : " Dense " ) ;
2005-04-16 15:20:36 -07:00
break ;
case ACPI_BUS_NUMBER_RANGE :
acpi_os_printf ( " Resource Type: Bus Number Range \n " ) ;
break ;
default :
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Resource Type: 0x%2.2X \n " ,
address64_data - > resource_type ) ;
2005-04-16 15:20:36 -07:00
break ;
}
acpi_os_printf ( " Resource %s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_CONSUMER = = address64_data - > producer_consumer ?
" Consumer " : " Producer " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " %s decode \n " ,
2005-04-18 22:49:35 -04:00
ACPI_SUB_DECODE = = address64_data - > decode ?
" Subtractive " : " Positive " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Min address is %s fixed \n " ,
2005-04-18 22:49:35 -04:00
ACPI_ADDRESS_FIXED = = address64_data - > min_address_fixed ?
" " : " not " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Max address is %s fixed \n " ,
2005-04-18 22:49:35 -04:00
ACPI_ADDRESS_FIXED = = address64_data - > max_address_fixed ?
" " : " not " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Granularity: %8.8X%8.8X \n " ,
2005-04-18 22:49:35 -04:00
ACPI_FORMAT_UINT64 ( address64_data - > granularity ) ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address range min: %8.8X%8.8X \n " ,
2005-04-18 22:49:35 -04:00
ACPI_FORMAT_UINT64 ( address64_data - > min_address_range ) ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address range max: %8.8X%8.8X \n " ,
2005-04-18 22:49:35 -04:00
ACPI_FORMAT_UINT64 ( address64_data - > max_address_range ) ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address translation offset: %8.8X%8.8X \n " ,
2005-04-18 22:49:35 -04:00
ACPI_FORMAT_UINT64 ( address64_data - > address_translation_offset ) ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Address Length: %8.8X%8.8X \n " ,
2005-04-18 22:49:35 -04:00
ACPI_FORMAT_UINT64 ( address64_data - > address_length ) ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Type Specific Attributes: %8.8X%8.8X \n " ,
2005-04-18 22:49:35 -04:00
ACPI_FORMAT_UINT64 ( address64_data - > type_specific_attributes ) ) ;
2005-04-16 15:20:36 -07:00
if ( 0xFF ! = address64_data - > resource_source . index ) {
acpi_os_printf ( " Resource Source Index: %X \n " ,
2005-04-18 22:49:35 -04:00
address64_data - > resource_source . index ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Resource Source: %s \n " ,
2005-04-18 22:49:35 -04:00
address64_data - > resource_source . string_ptr ) ;
2005-04-16 15:20:36 -07:00
}
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_extended_irq
*
* PARAMETERS : Data - pointer to the resource structure to dump .
*
* RETURN : None
*
* DESCRIPTION : Prints out the various members of the Data structure type .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-18 22:49:35 -04:00
static void
2005-04-16 15:20:36 -07:00
acpi_rs_dump_extended_irq (
union acpi_resource_data * data )
{
struct acpi_resource_ext_irq * ext_irq_data = ( struct acpi_resource_ext_irq * ) data ;
u8 index = 0 ;
ACPI_FUNCTION_ENTRY ( ) ;
acpi_os_printf ( " Extended IRQ Resource \n " ) ;
acpi_os_printf ( " Resource %s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_CONSUMER = = ext_irq_data - > producer_consumer ?
" Consumer " : " Producer " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " %s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_LEVEL_SENSITIVE = = ext_irq_data - > edge_level ?
" Level " : " Edge " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Active %s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_ACTIVE_LOW = = ext_irq_data - > active_high_low ?
" low " : " high " ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " %s \n " ,
2005-04-18 22:49:35 -04:00
ACPI_SHARED = = ext_irq_data - > shared_exclusive ?
" Shared " : " Exclusive " ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " Interrupts : %X ( " , ext_irq_data - > number_of_interrupts ) ;
2005-04-16 15:20:36 -07:00
for ( index = 0 ; index < ext_irq_data - > number_of_interrupts ; index + + ) {
acpi_os_printf ( " %X " , ext_irq_data - > interrupts [ index ] ) ;
}
acpi_os_printf ( " ) \n " ) ;
if ( 0xFF ! = ext_irq_data - > resource_source . index ) {
acpi_os_printf ( " Resource Source Index: %X " ,
2005-04-18 22:49:35 -04:00
ext_irq_data - > resource_source . index ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Resource Source: %s " ,
2005-04-18 22:49:35 -04:00
ext_irq_data - > resource_source . string_ptr ) ;
2005-04-16 15:20:36 -07:00
}
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_resource_list
*
2005-04-18 22:49:35 -04:00
* PARAMETERS : Resource - pointer to the resource structure to dump .
2005-04-16 15:20:36 -07:00
*
* RETURN : None
*
* DESCRIPTION : Dispatches the structure to the correct dump routine .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void
acpi_rs_dump_resource_list (
struct acpi_resource * resource )
{
u8 count = 0 ;
u8 done = FALSE ;
ACPI_FUNCTION_ENTRY ( ) ;
if ( acpi_dbg_level & ACPI_LV_RESOURCES & & _COMPONENT & acpi_dbg_layer ) {
while ( ! done ) {
acpi_os_printf ( " Resource structure %X. \n " , count + + ) ;
switch ( resource - > id ) {
case ACPI_RSTYPE_IRQ :
acpi_rs_dump_irq ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_DMA :
acpi_rs_dump_dma ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_START_DPF :
acpi_rs_dump_start_depend_fns ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_END_DPF :
acpi_os_printf ( " end_dependent_functions Resource \n " ) ;
/* acpi_rs_dump_end_dependent_functions (Resource->Data);*/
break ;
case ACPI_RSTYPE_IO :
acpi_rs_dump_io ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_FIXED_IO :
acpi_rs_dump_fixed_io ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_VENDOR :
acpi_rs_dump_vendor_specific ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_END_TAG :
/*rs_dump_end_tag (Resource->Data);*/
acpi_os_printf ( " end_tag Resource \n " ) ;
done = TRUE ;
break ;
case ACPI_RSTYPE_MEM24 :
acpi_rs_dump_memory24 ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_MEM32 :
acpi_rs_dump_memory32 ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_FIXED_MEM32 :
acpi_rs_dump_fixed_memory32 ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_ADDRESS16 :
acpi_rs_dump_address16 ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_ADDRESS32 :
acpi_rs_dump_address32 ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_ADDRESS64 :
acpi_rs_dump_address64 ( & resource - > data ) ;
break ;
case ACPI_RSTYPE_EXT_IRQ :
acpi_rs_dump_extended_irq ( & resource - > data ) ;
break ;
default :
acpi_os_printf ( " Invalid resource type \n " ) ;
break ;
}
resource = ACPI_PTR_ADD ( struct acpi_resource , resource , resource - > length ) ;
}
}
return ;
}
/*******************************************************************************
*
* FUNCTION : acpi_rs_dump_irq_list
*
2005-04-18 22:49:35 -04:00
* PARAMETERS : route_table - pointer to the routing table to dump .
2005-04-16 15:20:36 -07:00
*
* RETURN : None
*
* DESCRIPTION : Dispatches the structures to the correct dump routine .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void
acpi_rs_dump_irq_list (
u8 * route_table )
{
u8 * buffer = route_table ;
u8 count = 0 ;
u8 done = FALSE ;
struct acpi_pci_routing_table * prt_element ;
ACPI_FUNCTION_ENTRY ( ) ;
if ( acpi_dbg_level & ACPI_LV_RESOURCES & & _COMPONENT & acpi_dbg_layer ) {
prt_element = ACPI_CAST_PTR ( struct acpi_pci_routing_table , buffer ) ;
while ( ! done ) {
acpi_os_printf ( " PCI IRQ Routing Table structure %X. \n " , count + + ) ;
acpi_os_printf ( " Address: %8.8X%8.8X \n " ,
2005-04-18 22:49:35 -04:00
ACPI_FORMAT_UINT64 ( prt_element - > address ) ) ;
2005-04-16 15:20:36 -07:00
acpi_os_printf ( " Pin: %X \n " , prt_element - > pin ) ;
acpi_os_printf ( " Source: %s \n " , prt_element - > source ) ;
2005-04-18 22:49:35 -04:00
acpi_os_printf ( " source_index: %X \n " , prt_element - > source_index ) ;
2005-04-16 15:20:36 -07:00
buffer + = prt_element - > length ;
prt_element = ACPI_CAST_PTR ( struct acpi_pci_routing_table , buffer ) ;
2005-04-18 22:49:35 -04:00
if ( 0 = = prt_element - > length ) {
2005-04-16 15:20:36 -07:00
done = TRUE ;
}
}
}
return ;
}
# endif