iPXE
Data Structures | Macros | Functions | Variables
acpi.h File Reference

ACPI data structures. More...

#include <stdint.h>
#include <byteswap.h>
#include <ipxe/refcnt.h>
#include <ipxe/list.h>
#include <ipxe/interface.h>
#include <ipxe/tables.h>
#include <ipxe/api.h>
#include <config/general.h>
#include <ipxe/null_acpi.h>
#include <ipxe/efi/efi_acpi.h>
#include <ipxe/linux/linux_acpi.h>
#include <bits/acpi.h>

Go to the source code of this file.

Data Structures

struct  acpi_address
 An ACPI generic address structure. More...
 
struct  acpi_small_resource
 An ACPI small resource descriptor header. More...
 
struct  acpi_end_resource
 An ACPI end resource descriptor. More...
 
struct  acpi_large_resource
 An ACPI large resource descriptor header. More...
 
struct  acpi_qword_address_space_resource
 An ACPI QWORD address space resource descriptor. More...
 
union  acpi_resource
 An ACPI resource descriptor. More...
 
struct  acpi_header
 An ACPI description header. More...
 
struct  acpi_rsdp
 Root System Description Pointer. More...
 
struct  acpi_rsdt
 ACPI Root System Description Table (RSDT) More...
 
struct  acpi_fadt
 Fixed ACPI Description Table (FADT) More...
 
struct  acpi_descriptor
 An ACPI descriptor (used to construct ACPI tables) More...
 
struct  acpi_model
 An ACPI table model. More...
 

Macros

#define ACPI_ADDRESS_TYPE_MEM   0x00
 A memory address space type. More...
 
#define ACPI_ADDRESS_TYPE_IO   0x01
 An I/O address space type. More...
 
#define ACPI_ADDRESS_TYPE_BUS   0x02
 A bus number address space type. More...
 
#define ACPI_SMALL_LEN_MASK   0x03
 ACPI small resource length mask. More...
 
#define ACPI_END_RESOURCE   0x78
 An ACPI end resource descriptor. More...
 
#define ACPI_LARGE   0x80
 ACPI large resource flag. More...
 
#define ACPI_QWORD_ADDRESS_SPACE_RESOURCE   0x8a
 An ACPI QWORD address space resource descriptor. More...
 
#define ACPI_SIGNATURE(a, b, c, d)   ( ( (a) << 0 ) | ( (b) << 8 ) | ( (c) << 16 ) | ( (d) << 24 ) )
 Build ACPI signature. More...
 
#define RSDP_SIGNATURE   { 'R', 'S', 'D', ' ', 'P', 'T', 'R', ' ' }
 Root System Description Pointer signature. More...
 
#define RSDT_SIGNATURE   ACPI_SIGNATURE ( 'R', 'S', 'D', 'T' )
 Root System Description Table (RSDT) signature. More...
 
#define FADT_SIGNATURE   ACPI_SIGNATURE ( 'F', 'A', 'C', 'P' )
 Fixed ACPI Description Table (FADT) signature. More...
 
#define ACPI_PM1_CNT   0
 ACPI PM1 Control Register (within PM1a_CNT_BLK or PM1A_CNT_BLK) More...
 
#define ACPI_PM1_CNT_SLP_TYP(x)   ( (x) << 10 )
 Sleep type. More...
 
#define ACPI_PM1_CNT_SLP_EN   ( 1 << 13 )
 Sleep enable. More...
 
#define ACPI_PM_TMR   0
 ACPI PM Timer Register (within PM_TMR_BLK) More...
 
#define DSDT_SIGNATURE   ACPI_SIGNATURE ( 'D', 'S', 'D', 'T' )
 Differentiated System Description Table (DSDT) signature. More...
 
#define SSDT_SIGNATURE   ACPI_SIGNATURE ( 'S', 'S', 'D', 'T' )
 Secondary System Description Table (SSDT) signature. More...
 
#define ACPI_MODELS   __table ( struct acpi_model, "acpi_models" )
 ACPI models. More...
 
#define __acpi_model   __table_entry ( ACPI_MODELS, 01 )
 Declare an ACPI model. More...
 
#define ACPI_INLINE(_subsys, _api_func)   SINGLE_API_INLINE ( ACPI_PREFIX_ ## _subsys, _api_func )
 Calculate static inline ACPI API function name. More...
 
#define PROVIDE_ACPI(_subsys, _api_func, _func)   PROVIDE_SINGLE_API ( ACPI_PREFIX_ ## _subsys, _api_func, _func )
 Provide an ACPI API implementation. More...
 
#define PROVIDE_ACPI_INLINE(_subsys, _api_func)   PROVIDE_SINGLE_API_INLINE ( ACPI_PREFIX_ ## _subsys, _api_func )
 Provide a static inline ACPI API implementation. More...
 
#define acpi_describe_TYPE(object_type)   typeof ( struct acpi_descriptor * ( object_type ) )
 

Functions

 FILE_LICENCE (GPL2_OR_LATER_OR_UBDL)
 
 FILE_SECBOOT (PERMITTED)
 
static unsigned int acpi_resource_tag (union acpi_resource *res)
 Get ACPI resource tag. More...
 
static size_t acpi_small_len (struct acpi_small_resource *res)
 Get length of ACPI small resource descriptor. More...
 
static size_t acpi_large_len (struct acpi_large_resource *res)
 Get length of ACPI large resource descriptor. More...
 
static size_t acpi_resource_len (union acpi_resource *res)
 Get length of ACPI resource descriptor. More...
 
static union acpi_resourceacpi_resource_next (union acpi_resource *res)
 Get next ACPI resource descriptor. More...
 
static const char * acpi_name (uint32_t signature)
 Transcribe ACPI table signature (for debugging) More...
 
static void acpi_init (struct acpi_descriptor *desc, struct acpi_model *model, struct refcnt *refcnt)
 Initialise ACPI descriptor. More...
 
const struct acpi_headeracpi_find_via_rsdt (uint32_t signature, unsigned int index)
 Locate ACPI table via RSDT. More...
 
const struct acpi_rsdtacpi_find_rsdt (void)
 Locate ACPI root system description table. More...
 
const struct acpi_headeracpi_find (uint32_t signature, unsigned int index)
 Locate ACPI table. More...
 
struct acpi_descriptoracpi_describe (struct interface *interface)
 Get object's ACPI descriptor. More...
 
void acpi_fix_checksum (struct acpi_header *acpi)
 Fix up ACPI table checksum. More...
 
const struct acpi_headeracpi_table (uint32_t signature, unsigned int index)
 Locate ACPI table. More...
 
int acpi_extract (uint32_t signature, void *data, int(*extract)(const struct acpi_header *zsdt, size_t len, size_t offset, void *data))
 Extract value from DSDT/SSDT. More...
 
void * acpi_ioremap (struct acpi_address *address, size_t len)
 Map an ACPI generic address. More...
 
void acpi_add (struct acpi_descriptor *desc)
 Add ACPI descriptor. More...
 
void acpi_del (struct acpi_descriptor *desc)
 Remove ACPI descriptor. More...
 
int acpi_install (int(*install)(struct acpi_header *acpi))
 Install ACPI tables. More...
 

Variables

const struct acpi_header *(* acpi_finder )(uint32_t signature, unsigned int index)
 

Detailed Description

ACPI data structures.

Definition in file acpi.h.

Macro Definition Documentation

◆ ACPI_ADDRESS_TYPE_MEM

#define ACPI_ADDRESS_TYPE_MEM   0x00

A memory address space type.

Definition at line 37 of file acpi.h.

◆ ACPI_ADDRESS_TYPE_IO

#define ACPI_ADDRESS_TYPE_IO   0x01

An I/O address space type.

Definition at line 40 of file acpi.h.

◆ ACPI_ADDRESS_TYPE_BUS

#define ACPI_ADDRESS_TYPE_BUS   0x02

A bus number address space type.

Definition at line 43 of file acpi.h.

◆ ACPI_SMALL_LEN_MASK

#define ACPI_SMALL_LEN_MASK   0x03

ACPI small resource length mask.

Definition at line 52 of file acpi.h.

◆ ACPI_END_RESOURCE

#define ACPI_END_RESOURCE   0x78

An ACPI end resource descriptor.

Definition at line 55 of file acpi.h.

◆ ACPI_LARGE

#define ACPI_LARGE   0x80

ACPI large resource flag.

Definition at line 74 of file acpi.h.

◆ ACPI_QWORD_ADDRESS_SPACE_RESOURCE

#define ACPI_QWORD_ADDRESS_SPACE_RESOURCE   0x8a

An ACPI QWORD address space resource descriptor.

Definition at line 77 of file acpi.h.

◆ ACPI_SIGNATURE

#define ACPI_SIGNATURE (   a,
  b,
  c,
 
)    ( ( (a) << 0 ) | ( (b) << 8 ) | ( (c) << 16 ) | ( (d) << 24 ) )

Build ACPI signature.

Parameters
aFirst character of ACPI signature
bSecond character of ACPI signature
cThird character of ACPI signature
dFourth character of ACPI signature
Return values
signatureACPI signature

Definition at line 226 of file acpi.h.

◆ RSDP_SIGNATURE

#define RSDP_SIGNATURE   { 'R', 'S', 'D', ' ', 'P', 'T', 'R', ' ' }

Root System Description Pointer signature.

Definition at line 230 of file acpi.h.

◆ RSDT_SIGNATURE

#define RSDT_SIGNATURE   ACPI_SIGNATURE ( 'R', 'S', 'D', 'T' )

Root System Description Table (RSDT) signature.

Definition at line 247 of file acpi.h.

◆ FADT_SIGNATURE

#define FADT_SIGNATURE   ACPI_SIGNATURE ( 'F', 'A', 'C', 'P' )

Fixed ACPI Description Table (FADT) signature.

Definition at line 258 of file acpi.h.

◆ ACPI_PM1_CNT

#define ACPI_PM1_CNT   0

ACPI PM1 Control Register (within PM1a_CNT_BLK or PM1A_CNT_BLK)

Definition at line 281 of file acpi.h.

◆ ACPI_PM1_CNT_SLP_TYP

#define ACPI_PM1_CNT_SLP_TYP (   x)    ( (x) << 10 )

Sleep type.

Definition at line 282 of file acpi.h.

◆ ACPI_PM1_CNT_SLP_EN

#define ACPI_PM1_CNT_SLP_EN   ( 1 << 13 )

Sleep enable.

Definition at line 283 of file acpi.h.

◆ ACPI_PM_TMR

#define ACPI_PM_TMR   0

ACPI PM Timer Register (within PM_TMR_BLK)

Definition at line 286 of file acpi.h.

◆ DSDT_SIGNATURE

#define DSDT_SIGNATURE   ACPI_SIGNATURE ( 'D', 'S', 'D', 'T' )

Differentiated System Description Table (DSDT) signature.

Definition at line 289 of file acpi.h.

◆ SSDT_SIGNATURE

#define SSDT_SIGNATURE   ACPI_SIGNATURE ( 'S', 'S', 'D', 'T' )

Secondary System Description Table (SSDT) signature.

Definition at line 292 of file acpi.h.

◆ ACPI_MODELS

#define ACPI_MODELS   __table ( struct acpi_model, "acpi_models" )

ACPI models.

Definition at line 341 of file acpi.h.

◆ __acpi_model

struct acpi_model ib_sbft_model __acpi_model   __table_entry ( ACPI_MODELS, 01 )

Declare an ACPI model.

IB sBFT model.

aBFT model

Definition at line 344 of file acpi.h.

◆ ACPI_INLINE

#define ACPI_INLINE (   _subsys,
  _api_func 
)    SINGLE_API_INLINE ( ACPI_PREFIX_ ## _subsys, _api_func )

Calculate static inline ACPI API function name.

Parameters
_prefixSubsystem prefix
_api_funcAPI function
Return values
_subsys_funcSubsystem API function

Definition at line 353 of file acpi.h.

◆ PROVIDE_ACPI

#define PROVIDE_ACPI (   _subsys,
  _api_func,
  _func 
)    PROVIDE_SINGLE_API ( ACPI_PREFIX_ ## _subsys, _api_func, _func )

Provide an ACPI API implementation.

Parameters
_prefixSubsystem prefix
_api_funcAPI function
_funcImplementing function

Definition at line 363 of file acpi.h.

◆ PROVIDE_ACPI_INLINE

#define PROVIDE_ACPI_INLINE (   _subsys,
  _api_func 
)    PROVIDE_SINGLE_API_INLINE ( ACPI_PREFIX_ ## _subsys, _api_func )

Provide a static inline ACPI API implementation.

Parameters
_prefixSubsystem prefix
_api_funcAPI function

Definition at line 372 of file acpi.h.

◆ acpi_describe_TYPE

#define acpi_describe_TYPE (   object_type)    typeof ( struct acpi_descriptor * ( object_type ) )

Definition at line 405 of file acpi.h.

Function Documentation

◆ FILE_LICENCE()

FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL  )

◆ FILE_SECBOOT()

FILE_SECBOOT ( PERMITTED  )

◆ acpi_resource_tag()

static unsigned int acpi_resource_tag ( union acpi_resource res)
inlinestatic

Get ACPI resource tag.

Parameters
resACPI resource descriptor
Return values
tagResource tag

Definition at line 121 of file acpi.h.

121  {
122 
123  return ( ( res->tag & ACPI_LARGE ) ?
124  res->tag : ( res->tag & ~ACPI_SMALL_LEN_MASK ) );
125 }
uint8_t tag
Tag byte.
Definition: acpi.h:104
#define ACPI_SMALL_LEN_MASK
ACPI small resource length mask.
Definition: acpi.h:52
#define ACPI_LARGE
ACPI large resource flag.
Definition: acpi.h:74

References ACPI_LARGE, ACPI_SMALL_LEN_MASK, and acpi_resource::tag.

Referenced by efipci_discover_one(), and efipci_ioremap().

◆ acpi_small_len()

static size_t acpi_small_len ( struct acpi_small_resource res)
inlinestatic

Get length of ACPI small resource descriptor.

Parameters
resSmall resource descriptor
Return values
lenLength of descriptor

Definition at line 133 of file acpi.h.

133  {
134 
135  return ( sizeof ( *res ) + ( res->tag & ACPI_SMALL_LEN_MASK ) );
136 }
#define ACPI_SMALL_LEN_MASK
ACPI small resource length mask.
Definition: acpi.h:52
uint8_t tag
Tag byte.
Definition: acpi.h:48

References ACPI_SMALL_LEN_MASK, and acpi_small_resource::tag.

Referenced by acpi_resource_len().

◆ acpi_large_len()

static size_t acpi_large_len ( struct acpi_large_resource res)
inlinestatic

Get length of ACPI large resource descriptor.

Parameters
resLarge resource descriptor
Return values
lenLength of descriptor

Definition at line 144 of file acpi.h.

144  {
145 
146  return ( sizeof ( *res ) + le16_to_cpu ( res->len ) );
147 }
uint16_t len
Length of data items.
Definition: acpi.h:70
#define le16_to_cpu(value)
Definition: byteswap.h:113

References le16_to_cpu, and acpi_large_resource::len.

Referenced by acpi_resource_len().

◆ acpi_resource_len()

static size_t acpi_resource_len ( union acpi_resource res)
inlinestatic

Get length of ACPI resource descriptor.

Parameters
resACPI resource descriptor
Return values
lenLength of descriptor

Definition at line 155 of file acpi.h.

155  {
156 
157  return ( ( res->tag & ACPI_LARGE ) ?
158  acpi_large_len ( &res->large ) :
159  acpi_small_len ( &res->small ) );
160 }
struct acpi_small_resource small
Small resource descriptor.
Definition: acpi.h:106
struct acpi_large_resource large
Large resource descriptor.
Definition: acpi.h:110
uint8_t tag
Tag byte.
Definition: acpi.h:104
static size_t acpi_small_len(struct acpi_small_resource *res)
Get length of ACPI small resource descriptor.
Definition: acpi.h:133
static size_t acpi_large_len(struct acpi_large_resource *res)
Get length of ACPI large resource descriptor.
Definition: acpi.h:144
#define ACPI_LARGE
ACPI large resource flag.
Definition: acpi.h:74

References ACPI_LARGE, acpi_large_len(), acpi_small_len(), acpi_resource::large, acpi_resource::small, and acpi_resource::tag.

Referenced by acpi_resource_next().

◆ acpi_resource_next()

static union acpi_resource* acpi_resource_next ( union acpi_resource res)
static

Get next ACPI resource descriptor.

Parameters
resACPI resource descriptor
Return values
nextNext ACPI resource descriptor

Definition at line 169 of file acpi.h.

169  {
170 
171  return ( ( ( void * ) res ) + acpi_resource_len ( res ) );
172 }
static size_t acpi_resource_len(union acpi_resource *res)
Get length of ACPI resource descriptor.
Definition: acpi.h:155

References acpi_resource_len().

Referenced by efipci_discover_one(), and efipci_ioremap().

◆ acpi_name()

static const char* acpi_name ( uint32_t  signature)
inlinestatic

Transcribe ACPI table signature (for debugging)

Parameters
signatureACPI table signature
Return values
nameACPI table signature name

Definition at line 207 of file acpi.h.

207  {
208  static union {
210  char name[5];
211  } u;
212 
213  u.signature = cpu_to_le32 ( signature );
214  return u.name;
215 }
const char * name
Definition: ath9k_hw.c:1986
union @18 u
#define cpu_to_le32(value)
Definition: byteswap.h:108
unsigned int uint32_t
Definition: stdint.h:12
u8 signature
CPU signature.
Definition: CIB_PRM.h:35

References cpu_to_le32, name, signature, and u.

Referenced by acpi_extract(), acpi_find_via_rsdt(), acpi_settings_fetch(), acpi_zsdt(), dummy_install(), efi_block_install(), and int13_install().

◆ acpi_init()

static void acpi_init ( struct acpi_descriptor desc,
struct acpi_model model,
struct refcnt refcnt 
)
inlinestatic

Initialise ACPI descriptor.

Parameters
descACPI descriptor
modelTable model
refcntReference count

Definition at line 312 of file acpi.h.

313  {
314 
315  desc->refcnt = refcnt;
316  desc->model = model;
317  INIT_LIST_HEAD ( &desc->list );
318 }
static void(*) struct refcnt refcnt)
Definition: pool.h:63
struct ena_llq_option desc
Descriptor counts.
Definition: ena.h:20
#define INIT_LIST_HEAD(list)
Initialise a list head.
Definition: list.h:46

References desc, INIT_LIST_HEAD, and refcnt.

Referenced by aoedev_open(), ib_srp_open(), and iscsi_open().

◆ acpi_find_via_rsdt()

const struct acpi_header* acpi_find_via_rsdt ( uint32_t  signature,
unsigned int  index 
)

Locate ACPI table via RSDT.

Parameters
signatureRequested table signature
indexRequested index of table with this signature
Return values
tableTable, or NULL if not found

Definition at line 106 of file acpi.c.

107  {
108  const struct acpi_rsdt *rsdt;
109  const struct acpi_header *table;
110  size_t len;
111  unsigned int count;
112  unsigned int i;
113 
114  /* Locate RSDT */
115  rsdt = acpi_find_rsdt();
116  if ( ! rsdt ) {
117  DBG ( "RSDT not found\n" );
118  return NULL;
119  }
120 
121  /* Read RSDT header */
122  if ( rsdt->acpi.signature != cpu_to_le32 ( RSDT_SIGNATURE ) ) {
123  DBGC ( colour, "RSDT %#08lx has invalid signature:\n",
124  virt_to_phys ( rsdt ) );
125  DBGC_HDA ( colour, virt_to_phys ( rsdt ), &rsdt->acpi,
126  sizeof ( rsdt->acpi ) );
127  return NULL;
128  }
129  len = le32_to_cpu ( rsdt->acpi.length );
130  if ( len < sizeof ( rsdt->acpi ) ) {
131  DBGC ( colour, "RSDT %#08lx has invalid length:\n",
132  virt_to_phys ( rsdt ) );
133  DBGC_HDA ( colour, virt_to_phys ( rsdt ), &rsdt->acpi,
134  sizeof ( rsdt->acpi ) );
135  return NULL;
136  }
137 
138  /* Calculate number of entries */
139  count = ( ( len - sizeof ( rsdt->acpi ) ) /
140  sizeof ( rsdt->entry[0] ) );
141 
142  /* Search through entries */
143  for ( i = 0 ; i < count ; i++ ) {
144 
145  /* Read table header */
146  table = phys_to_virt ( rsdt->entry[i] );
147 
148  /* Check table signature */
149  if ( table->signature != cpu_to_le32 ( signature ) )
150  continue;
151 
152  /* Check index */
153  if ( index-- )
154  continue;
155 
156  /* Check table integrity */
157  if ( acpi_checksum ( table ) != 0 ) {
158  DBGC ( colour, "RSDT %#08lx found %s with bad "
159  "checksum at %#08lx\n", virt_to_phys ( rsdt ),
160  acpi_name ( signature ),
161  virt_to_phys ( table ) );
162  break;
163  }
164 
165  DBGC ( colour, "RSDT %#08lx found %s at %#08lx\n",
166  virt_to_phys ( rsdt ), acpi_name ( signature ),
167  virt_to_phys ( table ) );
168  return table;
169  }
170 
171  DBGC ( colour, "RSDT %#08lx could not find %s\n",
172  virt_to_phys ( rsdt ), acpi_name ( signature ) );
173  return NULL;
174 }
#define RSDT_SIGNATURE
Root System Description Table (RSDT) signature.
Definition: acpi.h:247
uint32_t signature
ACPI signature (4 ASCII characters)
Definition: acpi.h:182
#define le32_to_cpu(value)
Definition: byteswap.h:114
const struct acpi_rsdt * acpi_find_rsdt(void)
Locate ACPI root system description table.
#define DBGC(...)
Definition: compiler.h:505
long index
Definition: bigint.h:65
ACPI Root System Description Table (RSDT)
Definition: acpi.h:250
#define colour
Colour for debug messages.
Definition: acpi.c:42
uint32_t length
Length of table, in bytes, including header.
Definition: acpi.h:184
#define DBGC_HDA(...)
Definition: compiler.h:506
ring len
Length.
Definition: dwmac.h:231
uint32_t entry[0]
ACPI table entries.
Definition: acpi.h:254
static unsigned int count
Number of entries.
Definition: dwmac.h:225
#define cpu_to_le32(value)
Definition: byteswap.h:108
An ACPI description header.
Definition: acpi.h:180
struct acpi_header acpi
ACPI header.
Definition: acpi.h:252
static const char * acpi_name(uint32_t signature)
Transcribe ACPI table signature (for debugging)
Definition: acpi.h:207
#define DBG(...)
Print a debugging message.
Definition: compiler.h:498
u8 signature
CPU signature.
Definition: CIB_PRM.h:35
#define NULL
NULL pointer (VOID *)
Definition: Base.h:322

References acpi_rsdt::acpi, acpi_find_rsdt(), acpi_name(), colour, count, cpu_to_le32, DBG, DBGC, DBGC_HDA, acpi_rsdt::entry, index, le32_to_cpu, len, acpi_header::length, NULL, RSDT_SIGNATURE, signature, and acpi_header::signature.

Referenced by acpi_find().

◆ acpi_find_rsdt()

const struct acpi_rsdt* acpi_find_rsdt ( void  )

Locate ACPI root system description table.

Return values
rsdtACPI root system description table, or NULL

Referenced by acpi_find_via_rsdt().

◆ acpi_find()

const struct acpi_header* acpi_find ( uint32_t  signature,
unsigned int  index 
)

Locate ACPI table.

Parameters
signatureRequested table signature
indexRequested index of table with this signature
Return values
tableTable, or NULL if not found

Definition at line 27 of file rsdp.h.

27  {
28 
30 }
const struct acpi_header * acpi_find_via_rsdt(uint32_t signature, unsigned int index)
Locate ACPI table via RSDT.
Definition: acpi.c:106
long index
Definition: bigint.h:65
u8 signature
CPU signature.
Definition: CIB_PRM.h:35

References acpi_find_via_rsdt(), index, NULL, and signature.

◆ acpi_describe()

struct acpi_descriptor* acpi_describe ( struct interface intf)

Get object's ACPI descriptor.

Parameters
intfInterface
Return values
descACPI descriptor, or NULL

Definition at line 321 of file acpi.c.

321  {
322  struct interface *dest;
323  acpi_describe_TYPE ( void * ) *op =
325  void *object = intf_object ( dest );
326  struct acpi_descriptor *desc;
327 
328  if ( op ) {
329  desc = op ( object );
330  } else {
331  desc = NULL;
332  }
333 
334  intf_put ( dest );
335  return desc;
336 }
void * intf_object(struct interface *intf)
Get pointer to object containing object interface.
Definition: interface.c:160
struct interface * intf
Original interface.
Definition: interface.h:159
struct ena_llq_option desc
Descriptor counts.
Definition: ena.h:20
An object interface.
Definition: interface.h:125
struct acpi_descriptor * acpi_describe(struct interface *intf)
Get object's ACPI descriptor.
Definition: acpi.c:321
#define acpi_describe_TYPE(object_type)
Definition: acpi.h:405
static uint16_t struct vmbus_xfer_pages_operations * op
Definition: netvsc.h:327
An ACPI descriptor (used to construct ACPI tables)
Definition: acpi.h:295
void intf_put(struct interface *intf)
Decrement reference count on an object interface.
Definition: interface.c:150
if(len >=6 *4) __asm__ __volatile__("movsl" if(len >=5 *4) __asm__ __volatile__("movsl" if(len >=4 *4) __asm__ __volatile__("movsl" if(len >=3 *4) __asm__ __volatile__("movsl" if(len >=2 *4) __asm__ __volatile__("movsl" if(len >=1 *4) __asm__ __volatile__("movsl" if((len % 4) >=2) __asm__ __volatile__("movsw" if((len % 2) >=1) __asm__ __volatile__("movsb" return dest
Definition: string.h:151
#define NULL
NULL pointer (VOID *)
Definition: Base.h:322
#define intf_get_dest_op(intf, type, dest)
Get object interface destination and operation method.
Definition: interface.h:270

References acpi_describe(), acpi_describe_TYPE, desc, dest, interface::intf, intf_get_dest_op, intf_object(), intf_put(), NULL, and op.

Referenced by acpi_describe(), and sanpath_open().

◆ acpi_fix_checksum()

void acpi_fix_checksum ( struct acpi_header acpi)

Fix up ACPI table checksum.

Parameters
acpiACPI table header

Definition at line 80 of file acpi.c.

80  {
81 
82  /* Update checksum */
83  acpi->checksum -= acpi_checksum ( acpi );
84 }
static EFI_ACPI_TABLE_PROTOCOL * acpi
ACPI table protocol protocol.
Definition: efi_block.c:67

References acpi.

Referenced by efi_block_install(), and int13_install().

◆ acpi_table()

const struct acpi_header* acpi_table ( uint32_t  signature,
unsigned int  index 
)

Locate ACPI table.

Parameters
signatureRequested table signature
indexRequested index of table with this signature
Return values
tableTable, or NULL if not found

Definition at line 93 of file acpi.c.

94  {
95 
96  return ( *acpi_finder ) ( signature, index );
97 }
const struct acpi_header *(* acpi_finder)(uint32_t signature, unsigned int index)
long index
Definition: bigint.h:65
u8 signature
CPU signature.
Definition: CIB_PRM.h:35

References acpi_finder, index, and signature.

Referenced by acpi_extract(), acpi_poweroff(), acpi_settings_fetch(), acpi_timer_probe(), ecam_find(), and spcr_console().

◆ acpi_extract()

int acpi_extract ( uint32_t  signature,
void *  data,
int(*)(const struct acpi_header *zsdt, size_t len, size_t offset, void *data extract 
)

Extract value from DSDT/SSDT.

Parameters
signatureSignature (e.g. "_S5_")
dataData buffer
extractExtraction method
Return values
rcReturn status code

Definition at line 228 of file acpi.c.

231  {
232  const struct acpi_fadt *fadt;
233  const struct acpi_header *dsdt;
234  const struct acpi_header *ssdt;
235  unsigned int i;
236  int rc;
237 
238  /* Try DSDT first */
239  fadt = container_of ( acpi_table ( FADT_SIGNATURE, 0 ),
240  struct acpi_fadt, acpi );
241  if ( fadt ) {
242  dsdt = phys_to_virt ( fadt->dsdt );
243  if ( ( rc = acpi_zsdt ( dsdt, signature, data,
244  extract ) ) == 0 )
245  return 0;
246  }
247 
248  /* Try all SSDTs */
249  for ( i = 0 ; ; i++ ) {
250  ssdt = acpi_table ( SSDT_SIGNATURE, i );
251  if ( ! ssdt )
252  break;
253  if ( ( rc = acpi_zsdt ( ssdt, signature, data,
254  extract ) ) == 0 )
255  return 0;
256  }
257 
258  DBGC ( colour, "ACPI could not find \"%s\"\n",
259  acpi_name ( signature ) );
260  return -ENOENT;
261 }
struct arbelprm_rc_send_wqe rc
Definition: arbel.h:14
#define DBGC(...)
Definition: compiler.h:505
#define SSDT_SIGNATURE
Secondary System Description Table (SSDT) signature.
Definition: acpi.h:292
#define ENOENT
No such file or directory.
Definition: errno.h:515
const struct acpi_header * acpi_table(uint32_t signature, unsigned int index)
Locate ACPI table.
Definition: acpi.c:93
#define container_of(ptr, type, field)
Get containing structure.
Definition: stddef.h:36
#define colour
Colour for debug messages.
Definition: acpi.c:42
Fixed ACPI Description Table (FADT)
Definition: acpi.h:261
static EFI_ACPI_TABLE_PROTOCOL * acpi
ACPI table protocol protocol.
Definition: efi_block.c:67
#define FADT_SIGNATURE
Fixed ACPI Description Table (FADT) signature.
Definition: acpi.h:258
An ACPI description header.
Definition: acpi.h:180
uint32_t dsdt
Physical address of DSDT.
Definition: acpi.h:267
static const char * acpi_name(uint32_t signature)
Transcribe ACPI table signature (for debugging)
Definition: acpi.h:207
uint8_t data[48]
Additional event data.
Definition: ena.h:22
static int acpi_zsdt(const struct acpi_header *zsdt, uint32_t signature, void *data, int(*extract)(const struct acpi_header *zsdt, size_t len, size_t offset, void *data))
Extract value from DSDT/SSDT.
Definition: acpi.c:185
u8 signature
CPU signature.
Definition: CIB_PRM.h:35

References acpi, acpi_name(), acpi_table(), acpi_zsdt(), colour, container_of, data, DBGC, acpi_fadt::dsdt, ENOENT, FADT_SIGNATURE, rc, signature, and SSDT_SIGNATURE.

Referenced by acpi_mac(), and acpi_poweroff().

◆ acpi_ioremap()

void* acpi_ioremap ( struct acpi_address address,
size_t  len 
)

Map an ACPI generic address.

Parameters
addressGeneric address
lenLength of region
Return values
io_addrI/O address, or NULL on error

Definition at line 270 of file acpi.c.

270  {
271  physaddr_t base = le64_to_cpu ( address->address );
272 
273  switch ( address->type ) {
275  return ioremap ( base, len );
277  return ( ( void * ) base );
278  default:
279  return NULL;
280  }
281 }
uint32_t base
Base.
Definition: librm.h:138
uint64_t address
Base address.
Definition: ena.h:24
#define ACPI_ADDRESS_TYPE_IO
An I/O address space type.
Definition: acpi.h:40
ring len
Length.
Definition: dwmac.h:231
unsigned long physaddr_t
Definition: stdint.h:20
#define ACPI_ADDRESS_TYPE_MEM
A memory address space type.
Definition: acpi.h:37
void * ioremap(unsigned long bus_addr, size_t len)
Map bus address as an I/O address.
#define le64_to_cpu(value)
Definition: byteswap.h:115
#define NULL
NULL pointer (VOID *)
Definition: Base.h:322

References ACPI_ADDRESS_TYPE_IO, ACPI_ADDRESS_TYPE_MEM, address, base, ioremap(), le64_to_cpu, len, and NULL.

Referenced by spcr_16550().

◆ acpi_add()

void acpi_add ( struct acpi_descriptor desc)

Add ACPI descriptor.

Parameters
descACPI descriptor

Definition at line 295 of file acpi.c.

295  {
296 
297  /* Add to list of descriptors */
298  ref_get ( desc->refcnt );
299  list_add_tail ( &desc->list, &desc->model->descs );
300 }
struct ena_llq_option desc
Descriptor counts.
Definition: ena.h:20
#define list_add_tail(new, head)
Add a new entry to the tail of a list.
Definition: list.h:94
#define ref_get(refcnt)
Get additional reference to object.
Definition: refcnt.h:93

References desc, list_add_tail, and ref_get.

Referenced by sanpath_open().

◆ acpi_del()

void acpi_del ( struct acpi_descriptor desc)

Remove ACPI descriptor.

Parameters
descACPI descriptor

Definition at line 307 of file acpi.c.

307  {
308 
309  /* Remove from list of descriptors */
310  list_check_contains_entry ( desc, &desc->model->descs, list );
311  list_del ( &desc->list );
312  ref_put ( desc->refcnt );
313 }
#define list_del(list)
Delete an entry from a list.
Definition: list.h:120
struct ena_llq_option desc
Descriptor counts.
Definition: ena.h:20
#define list_check_contains_entry(entry, head, member)
Check list contains a specified entry.
Definition: list.h:550
#define ref_put(refcnt)
Drop reference to object.
Definition: refcnt.h:107

References desc, list_check_contains_entry, list_del, and ref_put.

Referenced by sandev_undescribe(), and sanpath_open().

◆ acpi_install()

int acpi_install ( int(*)(struct acpi_header *acpi install)

Install ACPI tables.

Parameters
installTable installation method
Return values
rcReturn status code

Definition at line 344 of file acpi.c.

344  {
345  struct acpi_model *model;
346  int rc;
347 
348  for_each_table_entry ( model, ACPI_MODELS ) {
349  if ( ( rc = model->install ( install ) ) != 0 )
350  return rc;
351  }
352 
353  return 0;
354 }
struct arbelprm_rc_send_wqe rc
Definition: arbel.h:14
int(* install)(int(*install)(struct acpi_header *acpi))
Install ACPI tables.
Definition: acpi.h:337
An ACPI table model.
Definition: acpi.h:321
#define for_each_table_entry(pointer, table)
Iterate through all entries within a linker table.
Definition: tables.h:386
#define ACPI_MODELS
ACPI models.
Definition: acpi.h:341

References ACPI_MODELS, for_each_table_entry, acpi_model::install, and rc.

Referenced by dummy_san_describe(), efi_block_describe(), and int13_describe().

Variable Documentation

◆ acpi_finder

const struct acpi_header*( * acpi_finder) (uint32_t signature, unsigned int index)

Referenced by acpi_table().