2020-01-23 17:12:32 +01:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2013-05-23 18:13:23 +02:00
|
|
|
|
|
|
|
#ifndef SUPERIO_ACPI_PNP_DEFS_ASL
|
|
|
|
#define SUPERIO_ACPI_PNP_DEFS_ASL
|
|
|
|
|
|
|
|
#define _SUPERIO_ID(name, ldn) name ## ldn
|
|
|
|
#define SUPERIO_ID(name, ldn) _SUPERIO_ID(name, ldn)
|
|
|
|
|
|
|
|
#define STRINGIFY(x) #x
|
|
|
|
#define EXPAND_AND_STRINGIFY(x) STRINGIFY(x)
|
|
|
|
#define SUPERIO_UID(name, ldn) \
|
|
|
|
EXPAND_AND_STRINGIFY(SUPERIO_CHIP_NAME-SUPERIO_ID(name, ldn))
|
|
|
|
#define SUPERIO_NAME(name) EXPAND_AND_STRINGIFY(SUPERIO_CHIP_NAME name)
|
|
|
|
|
|
|
|
/* Some longer identifiers for readability */
|
|
|
|
#define PNP_ADDR_REG ADDR
|
|
|
|
#define PNP_DATA_REG DATA
|
|
|
|
#define PNP_LOGICAL_DEVICE LDN
|
|
|
|
#define PNP_DEVICE_ACTIVE ACTR
|
|
|
|
#define PNP_IO0_HIGH_BYTE IO0H
|
|
|
|
#define PNP_IO0_LOW_BYTE IO0L
|
|
|
|
#define PNP_IO1_HIGH_BYTE IO1H
|
|
|
|
#define PNP_IO1_LOW_BYTE IO1L
|
2017-06-03 12:51:10 +02:00
|
|
|
#define PNP_IO2_HIGH_BYTE IO2H
|
|
|
|
#define PNP_IO2_LOW_BYTE IO2L
|
2013-05-23 18:13:23 +02:00
|
|
|
#define PNP_IRQ0 IRQ0
|
|
|
|
#define PNP_IRQ1 IRQ1
|
|
|
|
#define PNP_DMA0 DMA0
|
|
|
|
|
2019-01-23 11:36:44 +01:00
|
|
|
#define CONF_MODE_MUTEX CMMX
|
2013-05-23 18:13:23 +02:00
|
|
|
#define ENTER_CONFIG_MODE ENCM
|
|
|
|
#define EXIT_CONFIG_MODE EXCM
|
|
|
|
#define SWITCH_LDN SWLD
|
|
|
|
#define PNP_NO_LDN_CHANGE 0xff
|
|
|
|
|
|
|
|
/* Values for ACPI's _STA method */
|
|
|
|
#define DEVICE_NOT_PRESENT 0x00
|
|
|
|
#define DEVICE_PRESENT_ACTIVE 0x0f
|
|
|
|
#define DEVICE_PRESENT_INACTIVE 0x0d
|
|
|
|
|
|
|
|
|
|
|
|
/* ================== Generic Method bodies ================= */
|
|
|
|
|
|
|
|
#define PNP_GENERIC_STA(LDN) \
|
|
|
|
ENTER_CONFIG_MODE (LDN)\
|
|
|
|
If (PNP_DEVICE_ACTIVE) {\
|
2022-12-12 02:34:43 +01:00
|
|
|
Local0 = DEVICE_PRESENT_ACTIVE \
|
2013-05-23 18:13:23 +02:00
|
|
|
}\
|
|
|
|
Else\
|
|
|
|
{\
|
2022-12-12 02:34:43 +01:00
|
|
|
Local0 = DEVICE_PRESENT_INACTIVE \
|
2013-05-23 18:13:23 +02:00
|
|
|
}\
|
|
|
|
EXIT_CONFIG_MODE ()\
|
|
|
|
Return (Local0)\
|
|
|
|
|
|
|
|
#define PNP_GENERIC_DIS(LDN) \
|
|
|
|
ENTER_CONFIG_MODE (LDN)\
|
2022-12-26 09:38:45 +01:00
|
|
|
PNP_DEVICE_ACTIVE = 0 \
|
2013-05-23 18:13:23 +02:00
|
|
|
EXIT_CONFIG_MODE ()\
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Current power state (returns the chip's state)
|
|
|
|
*/
|
|
|
|
#define PNP_DEFAULT_PSC \
|
2022-12-12 02:34:43 +01:00
|
|
|
Local0 = ^^_PSC () \
|
2013-05-23 18:13:23 +02:00
|
|
|
Return (Local0)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Current power state (returns the chip's state, if it's in
|
2020-03-22 01:17:54 +01:00
|
|
|
* power saving mode, 3 if this LDN is in power saving mode,
|
2013-05-23 18:13:23 +02:00
|
|
|
* 0 else)
|
|
|
|
*
|
|
|
|
* PM_REG Identifier of a register which powers down the device
|
|
|
|
* PM_LDN The logical device number to access the PM_REG
|
|
|
|
* bit
|
|
|
|
*/
|
2013-07-01 16:29:16 +02:00
|
|
|
#define PNP_GENERIC_PSC(PM_REG, PM_VAL, PM_LDN) \
|
2022-12-12 02:34:43 +01:00
|
|
|
Local0 = ^^_PSC () \
|
2013-05-23 18:13:23 +02:00
|
|
|
If (Local0) { Return (Local0) }\
|
|
|
|
ENTER_CONFIG_MODE (PM_LDN)\
|
2022-12-12 02:34:43 +01:00
|
|
|
Local0 = PM_REG \
|
2013-05-23 18:13:23 +02:00
|
|
|
EXIT_CONFIG_MODE ()\
|
2022-01-02 00:29:41 +01:00
|
|
|
If (Local0 == PM_VAL) { Return (3) }\
|
2013-05-23 18:13:23 +02:00
|
|
|
Else { Return (0) }\
|
|
|
|
|
|
|
|
/* Disable power saving mode */
|
2013-07-01 16:29:16 +02:00
|
|
|
#define PNP_GENERIC_PS0(PM_REG, PM_VAL, PM_LDN) \
|
2013-05-23 18:13:23 +02:00
|
|
|
ENTER_CONFIG_MODE (PM_LDN)\
|
2022-12-25 08:14:39 +01:00
|
|
|
PM_REG = ~PM_VAL \
|
2013-05-23 18:13:23 +02:00
|
|
|
EXIT_CONFIG_MODE ()
|
|
|
|
|
|
|
|
/* Enable power saving mode */
|
2020-03-22 01:17:54 +01:00
|
|
|
#define PNP_GENERIC_PS3(PM_REG, PM_VAL, PM_LDN) \
|
2013-05-23 18:13:23 +02:00
|
|
|
ENTER_CONFIG_MODE (PM_LDN)\
|
2022-12-12 02:34:43 +01:00
|
|
|
PM_REG = PM_VAL \
|
2013-05-23 18:13:23 +02:00
|
|
|
EXIT_CONFIG_MODE ()
|
|
|
|
|
|
|
|
|
|
|
|
/* ==================== Resource helpers ==================== */
|
|
|
|
|
|
|
|
#define PNP_READ_IO(IO_FROM, RESOURCE_TEMPLATE, IO_TAG) \
|
|
|
|
CreateWordField (RESOURCE_TEMPLATE, IO_TAG._MIN, IO_TAG##I)\
|
|
|
|
CreateWordField (RESOURCE_TEMPLATE, IO_TAG._MAX, IO_TAG##A)\
|
2022-12-16 04:40:39 +01:00
|
|
|
Local0 = (IO_FROM##_HIGH_BYTE << 8) | IO_FROM##_LOW_BYTE \
|
2022-12-12 02:34:43 +01:00
|
|
|
IO_TAG##I = Local0 \
|
|
|
|
IO_TAG##A = Local0
|
2013-05-23 18:13:23 +02:00
|
|
|
|
|
|
|
#define PNP_READ_IRQ(IRQ_FROM, RESOURCE_TEMPLATE, IRQ_TAG) \
|
|
|
|
CreateWordField (RESOURCE_TEMPLATE, IRQ_TAG._INT, IRQ_TAG##W)\
|
2022-12-26 08:17:06 +01:00
|
|
|
IRQ_TAG##W = 1 << IRQ_FROM
|
2013-05-23 18:13:23 +02:00
|
|
|
|
|
|
|
#define PNP_READ_DMA(DMA_FROM, RESOURCE_TEMPLATE, DMA_TAG) \
|
2017-10-16 23:14:25 +02:00
|
|
|
CreateByteField (RESOURCE_TEMPLATE, DMA_TAG._DMA, DMA_TAG##W)\
|
2022-12-26 08:17:06 +01:00
|
|
|
DMA_TAG##W = 1 << DMA_FROM
|
2013-05-23 18:13:23 +02:00
|
|
|
|
|
|
|
#define PNP_WRITE_IO(IO_TO, RESOURCE, IO_TAG) \
|
|
|
|
CreateWordField (RESOURCE, IO_TAG._MIN, IO_TAG##I)\
|
2022-12-16 07:54:16 +01:00
|
|
|
IO_TO##_LOW_BYTE = IO_TAG##I & 0xff \
|
2022-12-12 02:34:43 +01:00
|
|
|
IO_TO##_HIGH_BYTE = IO_TAG##I >> 8
|
2013-05-23 18:13:23 +02:00
|
|
|
|
|
|
|
#define PNP_WRITE_IRQ(IRQ_TO, RESOURCE, IRQ_TAG) \
|
|
|
|
CreateWordField (RESOURCE, IRQ_TAG._INT, IRQ_TAG##W)\
|
2022-12-12 01:18:31 +01:00
|
|
|
IRQ_TO = FindSetLeftBit (IRQ_TAG##W) - 1
|
2013-05-23 18:13:23 +02:00
|
|
|
|
|
|
|
#define PNP_WRITE_DMA(DMA_TO, RESOURCE, DMA_TAG) \
|
2017-10-16 23:14:25 +02:00
|
|
|
CreateByteField (RESOURCE, DMA_TAG._DMA, DMA_TAG##W)\
|
2022-12-12 01:18:31 +01:00
|
|
|
DMA_TO = FindSetLeftBit (DMA_TAG##W) - 1
|
2013-05-23 18:13:23 +02:00
|
|
|
|
|
|
|
#endif
|