| // SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 |
| /******************************************************************************* |
| * |
| * Module Name: rsserial - GPIO/serial_bus resource descriptors |
| * |
| ******************************************************************************/ |
| |
| #include <acpi/acpi.h> |
| #include "accommon.h" |
| #include "acresrc.h" |
| |
| #define _COMPONENT ACPI_RESOURCES |
| ACPI_MODULE_NAME("rsserial") |
| |
| /******************************************************************************* |
| * |
| * acpi_rs_convert_gpio |
| * |
| ******************************************************************************/ |
| struct acpi_rsconvert_info acpi_rs_convert_gpio[18] = { |
| {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_GPIO, |
| ACPI_RS_SIZE(struct acpi_resource_gpio), |
| ACPI_RSC_TABLE_SIZE(acpi_rs_convert_gpio)}, |
| |
| {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_GPIO, |
| sizeof(struct aml_resource_gpio), |
| 0}, |
| |
| /* |
| * These fields are contiguous in both the source and destination: |
| * revision_id |
| * connection_type |
| */ |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.gpio.revision_id), |
| AML_OFFSET(gpio.revision_id), |
| 2}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.gpio.producer_consumer), |
| AML_OFFSET(gpio.flags), |
| 0}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.gpio.sharable), |
| AML_OFFSET(gpio.int_flags), |
| 3}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.gpio.wake_capable), |
| AML_OFFSET(gpio.int_flags), |
| 4}, |
| |
| {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET(data.gpio.io_restriction), |
| AML_OFFSET(gpio.int_flags), |
| 0}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.gpio.triggering), |
| AML_OFFSET(gpio.int_flags), |
| 0}, |
| |
| {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET(data.gpio.polarity), |
| AML_OFFSET(gpio.int_flags), |
| 1}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.gpio.pin_config), |
| AML_OFFSET(gpio.pin_config), |
| 1}, |
| |
| /* |
| * These fields are contiguous in both the source and destination: |
| * drive_strength |
| * debounce_timeout |
| */ |
| {ACPI_RSC_MOVE16, ACPI_RS_OFFSET(data.gpio.drive_strength), |
| AML_OFFSET(gpio.drive_strength), |
| 2}, |
| |
| /* Pin Table */ |
| |
| {ACPI_RSC_COUNT_GPIO_PIN, ACPI_RS_OFFSET(data.gpio.pin_table_length), |
| AML_OFFSET(gpio.pin_table_offset), |
| AML_OFFSET(gpio.res_source_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_PIN, ACPI_RS_OFFSET(data.gpio.pin_table), |
| AML_OFFSET(gpio.pin_table_offset), |
| 0}, |
| |
| /* Resource Source */ |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.gpio.resource_source.index), |
| AML_OFFSET(gpio.res_source_index), |
| 1}, |
| |
| {ACPI_RSC_COUNT_GPIO_RES, |
| ACPI_RS_OFFSET(data.gpio.resource_source.string_length), |
| AML_OFFSET(gpio.res_source_offset), |
| AML_OFFSET(gpio.vendor_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, |
| ACPI_RS_OFFSET(data.gpio.resource_source.string_ptr), |
| AML_OFFSET(gpio.res_source_offset), |
| 0}, |
| |
| /* Vendor Data */ |
| |
| {ACPI_RSC_COUNT_GPIO_VEN, ACPI_RS_OFFSET(data.gpio.vendor_length), |
| AML_OFFSET(gpio.vendor_length), |
| 1}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET(data.gpio.vendor_data), |
| AML_OFFSET(gpio.vendor_offset), |
| 0}, |
| }; |
| |
| /******************************************************************************* |
| * |
| * acpi_rs_convert_pinfunction |
| * |
| ******************************************************************************/ |
| |
| struct acpi_rsconvert_info acpi_rs_convert_pin_function[13] = { |
| {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_PIN_FUNCTION, |
| ACPI_RS_SIZE(struct acpi_resource_pin_function), |
| ACPI_RSC_TABLE_SIZE(acpi_rs_convert_pin_function)}, |
| |
| {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_PIN_FUNCTION, |
| sizeof(struct aml_resource_pin_function), |
| 0}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.pin_function.revision_id), |
| AML_OFFSET(pin_function.revision_id), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.pin_function.sharable), |
| AML_OFFSET(pin_function.flags), |
| 0}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.pin_function.pin_config), |
| AML_OFFSET(pin_function.pin_config), |
| 1}, |
| |
| {ACPI_RSC_MOVE16, ACPI_RS_OFFSET(data.pin_function.function_number), |
| AML_OFFSET(pin_function.function_number), |
| 2}, |
| |
| /* Pin Table */ |
| |
| /* |
| * It is OK to use GPIO operations here because none of them refer GPIO |
| * structures directly but instead use offsets given here. |
| */ |
| |
| {ACPI_RSC_COUNT_GPIO_PIN, |
| ACPI_RS_OFFSET(data.pin_function.pin_table_length), |
| AML_OFFSET(pin_function.pin_table_offset), |
| AML_OFFSET(pin_function.res_source_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_PIN, ACPI_RS_OFFSET(data.pin_function.pin_table), |
| AML_OFFSET(pin_function.pin_table_offset), |
| 0}, |
| |
| /* Resource Source */ |
| |
| {ACPI_RSC_MOVE8, |
| ACPI_RS_OFFSET(data.pin_function.resource_source.index), |
| AML_OFFSET(pin_function.res_source_index), |
| 1}, |
| |
| {ACPI_RSC_COUNT_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_function.resource_source.string_length), |
| AML_OFFSET(pin_function.res_source_offset), |
| AML_OFFSET(pin_function.vendor_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_function.resource_source.string_ptr), |
| AML_OFFSET(pin_function.res_source_offset), |
| 0}, |
| |
| /* Vendor Data */ |
| |
| {ACPI_RSC_COUNT_GPIO_VEN, |
| ACPI_RS_OFFSET(data.pin_function.vendor_length), |
| AML_OFFSET(pin_function.vendor_length), |
| 1}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET(data.pin_function.vendor_data), |
| AML_OFFSET(pin_function.vendor_offset), |
| 0}, |
| }; |
| |
| /******************************************************************************* |
| * |
| * acpi_rs_convert_i2c_serial_bus |
| * |
| ******************************************************************************/ |
| |
| struct acpi_rsconvert_info acpi_rs_convert_i2c_serial_bus[17] = { |
| {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, |
| ACPI_RS_SIZE(struct acpi_resource_i2c_serialbus), |
| ACPI_RSC_TABLE_SIZE(acpi_rs_convert_i2c_serial_bus)}, |
| |
| {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, |
| sizeof(struct aml_resource_i2c_serialbus), |
| 0}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.common_serial_bus.revision_id), |
| AML_OFFSET(common_serial_bus.revision_id), |
| 1}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.common_serial_bus.type), |
| AML_OFFSET(common_serial_bus.type), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.common_serial_bus.slave_mode), |
| AML_OFFSET(common_serial_bus.flags), |
| 0}, |
| |
| {ACPI_RSC_1BITFLAG, |
| ACPI_RS_OFFSET(data.common_serial_bus.producer_consumer), |
| AML_OFFSET(common_serial_bus.flags), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, |
| ACPI_RS_OFFSET(data.common_serial_bus.connection_sharing), |
| AML_OFFSET(common_serial_bus.flags), |
| 2}, |
| |
| {ACPI_RSC_MOVE8, |
| ACPI_RS_OFFSET(data.common_serial_bus.type_revision_id), |
| AML_OFFSET(common_serial_bus.type_revision_id), |
| 1}, |
| |
| {ACPI_RSC_MOVE16, |
| ACPI_RS_OFFSET(data.common_serial_bus.type_data_length), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| 1}, |
| |
| /* Vendor data */ |
| |
| {ACPI_RSC_COUNT_SERIAL_VEN, |
| ACPI_RS_OFFSET(data.common_serial_bus.vendor_length), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| AML_RESOURCE_I2C_MIN_DATA_LEN}, |
| |
| {ACPI_RSC_MOVE_SERIAL_VEN, |
| ACPI_RS_OFFSET(data.common_serial_bus.vendor_data), |
| 0, |
| sizeof(struct aml_resource_i2c_serialbus)}, |
| |
| /* Resource Source */ |
| |
| {ACPI_RSC_MOVE8, |
| ACPI_RS_OFFSET(data.common_serial_bus.resource_source.index), |
| AML_OFFSET(common_serial_bus.res_source_index), |
| 1}, |
| |
| {ACPI_RSC_COUNT_SERIAL_RES, |
| ACPI_RS_OFFSET(data.common_serial_bus.resource_source.string_length), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| sizeof(struct aml_resource_common_serialbus)}, |
| |
| {ACPI_RSC_MOVE_SERIAL_RES, |
| ACPI_RS_OFFSET(data.common_serial_bus.resource_source.string_ptr), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| sizeof(struct aml_resource_common_serialbus)}, |
| |
| /* I2C bus type specific */ |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.i2c_serial_bus.access_mode), |
| AML_OFFSET(i2c_serial_bus.type_specific_flags), |
| 0}, |
| |
| {ACPI_RSC_MOVE32, ACPI_RS_OFFSET(data.i2c_serial_bus.connection_speed), |
| AML_OFFSET(i2c_serial_bus.connection_speed), |
| 1}, |
| |
| {ACPI_RSC_MOVE16, ACPI_RS_OFFSET(data.i2c_serial_bus.slave_address), |
| AML_OFFSET(i2c_serial_bus.slave_address), |
| 1}, |
| }; |
| |
| /******************************************************************************* |
| * |
| * acpi_rs_convert_spi_serial_bus |
| * |
| ******************************************************************************/ |
| |
| struct acpi_rsconvert_info acpi_rs_convert_spi_serial_bus[21] = { |
| {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, |
| ACPI_RS_SIZE(struct acpi_resource_spi_serialbus), |
| ACPI_RSC_TABLE_SIZE(acpi_rs_convert_spi_serial_bus)}, |
| |
| {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, |
| sizeof(struct aml_resource_spi_serialbus), |
| 0}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.common_serial_bus.revision_id), |
| AML_OFFSET(common_serial_bus.revision_id), |
| 1}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.common_serial_bus.type), |
| AML_OFFSET(common_serial_bus.type), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.common_serial_bus.slave_mode), |
| AML_OFFSET(common_serial_bus.flags), |
| 0}, |
| |
| {ACPI_RSC_1BITFLAG, |
| ACPI_RS_OFFSET(data.common_serial_bus.producer_consumer), |
| AML_OFFSET(common_serial_bus.flags), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, |
| ACPI_RS_OFFSET(data.common_serial_bus.connection_sharing), |
| AML_OFFSET(common_serial_bus.flags), |
| 2}, |
| |
| {ACPI_RSC_MOVE8, |
| ACPI_RS_OFFSET(data.common_serial_bus.type_revision_id), |
| AML_OFFSET(common_serial_bus.type_revision_id), |
| 1}, |
| |
| {ACPI_RSC_MOVE16, |
| ACPI_RS_OFFSET(data.common_serial_bus.type_data_length), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| 1}, |
| |
| /* Vendor data */ |
| |
| {ACPI_RSC_COUNT_SERIAL_VEN, |
| ACPI_RS_OFFSET(data.common_serial_bus.vendor_length), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| AML_RESOURCE_SPI_MIN_DATA_LEN}, |
| |
| {ACPI_RSC_MOVE_SERIAL_VEN, |
| ACPI_RS_OFFSET(data.common_serial_bus.vendor_data), |
| 0, |
| sizeof(struct aml_resource_spi_serialbus)}, |
| |
| /* Resource Source */ |
| |
| {ACPI_RSC_MOVE8, |
| ACPI_RS_OFFSET(data.common_serial_bus.resource_source.index), |
| AML_OFFSET(common_serial_bus.res_source_index), |
| 1}, |
| |
| {ACPI_RSC_COUNT_SERIAL_RES, |
| ACPI_RS_OFFSET(data.common_serial_bus.resource_source.string_length), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| sizeof(struct aml_resource_common_serialbus)}, |
| |
| {ACPI_RSC_MOVE_SERIAL_RES, |
| ACPI_RS_OFFSET(data.common_serial_bus.resource_source.string_ptr), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| sizeof(struct aml_resource_common_serialbus)}, |
| |
| /* Spi bus type specific */ |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.spi_serial_bus.wire_mode), |
| AML_OFFSET(spi_serial_bus.type_specific_flags), |
| 0}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.spi_serial_bus.device_polarity), |
| AML_OFFSET(spi_serial_bus.type_specific_flags), |
| 1}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.spi_serial_bus.data_bit_length), |
| AML_OFFSET(spi_serial_bus.data_bit_length), |
| 1}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.spi_serial_bus.clock_phase), |
| AML_OFFSET(spi_serial_bus.clock_phase), |
| 1}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.spi_serial_bus.clock_polarity), |
| AML_OFFSET(spi_serial_bus.clock_polarity), |
| 1}, |
| |
| {ACPI_RSC_MOVE16, ACPI_RS_OFFSET(data.spi_serial_bus.device_selection), |
| AML_OFFSET(spi_serial_bus.device_selection), |
| 1}, |
| |
| {ACPI_RSC_MOVE32, ACPI_RS_OFFSET(data.spi_serial_bus.connection_speed), |
| AML_OFFSET(spi_serial_bus.connection_speed), |
| 1}, |
| }; |
| |
| /******************************************************************************* |
| * |
| * acpi_rs_convert_uart_serial_bus |
| * |
| ******************************************************************************/ |
| |
| struct acpi_rsconvert_info acpi_rs_convert_uart_serial_bus[23] = { |
| {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, |
| ACPI_RS_SIZE(struct acpi_resource_uart_serialbus), |
| ACPI_RSC_TABLE_SIZE(acpi_rs_convert_uart_serial_bus)}, |
| |
| {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, |
| sizeof(struct aml_resource_uart_serialbus), |
| 0}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.common_serial_bus.revision_id), |
| AML_OFFSET(common_serial_bus.revision_id), |
| 1}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.common_serial_bus.type), |
| AML_OFFSET(common_serial_bus.type), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.common_serial_bus.slave_mode), |
| AML_OFFSET(common_serial_bus.flags), |
| 0}, |
| |
| {ACPI_RSC_1BITFLAG, |
| ACPI_RS_OFFSET(data.common_serial_bus.producer_consumer), |
| AML_OFFSET(common_serial_bus.flags), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, |
| ACPI_RS_OFFSET(data.common_serial_bus.connection_sharing), |
| AML_OFFSET(common_serial_bus.flags), |
| 2}, |
| |
| {ACPI_RSC_MOVE8, |
| ACPI_RS_OFFSET(data.common_serial_bus.type_revision_id), |
| AML_OFFSET(common_serial_bus.type_revision_id), |
| 1}, |
| |
| {ACPI_RSC_MOVE16, |
| ACPI_RS_OFFSET(data.common_serial_bus.type_data_length), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| 1}, |
| |
| /* Vendor data */ |
| |
| {ACPI_RSC_COUNT_SERIAL_VEN, |
| ACPI_RS_OFFSET(data.common_serial_bus.vendor_length), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| AML_RESOURCE_UART_MIN_DATA_LEN}, |
| |
| {ACPI_RSC_MOVE_SERIAL_VEN, |
| ACPI_RS_OFFSET(data.common_serial_bus.vendor_data), |
| 0, |
| sizeof(struct aml_resource_uart_serialbus)}, |
| |
| /* Resource Source */ |
| |
| {ACPI_RSC_MOVE8, |
| ACPI_RS_OFFSET(data.common_serial_bus.resource_source.index), |
| AML_OFFSET(common_serial_bus.res_source_index), |
| 1}, |
| |
| {ACPI_RSC_COUNT_SERIAL_RES, |
| ACPI_RS_OFFSET(data.common_serial_bus.resource_source.string_length), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| sizeof(struct aml_resource_common_serialbus)}, |
| |
| {ACPI_RSC_MOVE_SERIAL_RES, |
| ACPI_RS_OFFSET(data.common_serial_bus.resource_source.string_ptr), |
| AML_OFFSET(common_serial_bus.type_data_length), |
| sizeof(struct aml_resource_common_serialbus)}, |
| |
| /* Uart bus type specific */ |
| |
| {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET(data.uart_serial_bus.flow_control), |
| AML_OFFSET(uart_serial_bus.type_specific_flags), |
| 0}, |
| |
| {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET(data.uart_serial_bus.stop_bits), |
| AML_OFFSET(uart_serial_bus.type_specific_flags), |
| 2}, |
| |
| {ACPI_RSC_3BITFLAG, ACPI_RS_OFFSET(data.uart_serial_bus.data_bits), |
| AML_OFFSET(uart_serial_bus.type_specific_flags), |
| 4}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.uart_serial_bus.endian), |
| AML_OFFSET(uart_serial_bus.type_specific_flags), |
| 7}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.uart_serial_bus.parity), |
| AML_OFFSET(uart_serial_bus.parity), |
| 1}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.uart_serial_bus.lines_enabled), |
| AML_OFFSET(uart_serial_bus.lines_enabled), |
| 1}, |
| |
| {ACPI_RSC_MOVE16, ACPI_RS_OFFSET(data.uart_serial_bus.rx_fifo_size), |
| AML_OFFSET(uart_serial_bus.rx_fifo_size), |
| 1}, |
| |
| {ACPI_RSC_MOVE16, ACPI_RS_OFFSET(data.uart_serial_bus.tx_fifo_size), |
| AML_OFFSET(uart_serial_bus.tx_fifo_size), |
| 1}, |
| |
| {ACPI_RSC_MOVE32, |
| ACPI_RS_OFFSET(data.uart_serial_bus.default_baud_rate), |
| AML_OFFSET(uart_serial_bus.default_baud_rate), |
| 1}, |
| }; |
| |
| /******************************************************************************* |
| * |
| * acpi_rs_convert_pin_config |
| * |
| ******************************************************************************/ |
| |
| struct acpi_rsconvert_info acpi_rs_convert_pin_config[14] = { |
| {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_PIN_CONFIG, |
| ACPI_RS_SIZE(struct acpi_resource_pin_config), |
| ACPI_RSC_TABLE_SIZE(acpi_rs_convert_pin_config)}, |
| |
| {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_PIN_CONFIG, |
| sizeof(struct aml_resource_pin_config), |
| 0}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.pin_config.revision_id), |
| AML_OFFSET(pin_config.revision_id), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.pin_config.sharable), |
| AML_OFFSET(pin_config.flags), |
| 0}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.pin_config.producer_consumer), |
| AML_OFFSET(pin_config.flags), |
| 1}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.pin_config.pin_config_type), |
| AML_OFFSET(pin_config.pin_config_type), |
| 1}, |
| |
| {ACPI_RSC_MOVE32, ACPI_RS_OFFSET(data.pin_config.pin_config_value), |
| AML_OFFSET(pin_config.pin_config_value), |
| 1}, |
| |
| /* Pin Table */ |
| |
| /* |
| * It is OK to use GPIO operations here because none of them refer GPIO |
| * structures directly but instead use offsets given here. |
| */ |
| |
| {ACPI_RSC_COUNT_GPIO_PIN, |
| ACPI_RS_OFFSET(data.pin_config.pin_table_length), |
| AML_OFFSET(pin_config.pin_table_offset), |
| AML_OFFSET(pin_config.res_source_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_PIN, ACPI_RS_OFFSET(data.pin_config.pin_table), |
| AML_OFFSET(pin_config.pin_table_offset), |
| 0}, |
| |
| /* Resource Source */ |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.pin_config.resource_source.index), |
| AML_OFFSET(pin_config.res_source_index), |
| 1}, |
| |
| {ACPI_RSC_COUNT_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_config.resource_source.string_length), |
| AML_OFFSET(pin_config.res_source_offset), |
| AML_OFFSET(pin_config.vendor_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_config.resource_source.string_ptr), |
| AML_OFFSET(pin_config.res_source_offset), |
| 0}, |
| |
| /* Vendor Data */ |
| |
| {ACPI_RSC_COUNT_GPIO_VEN, ACPI_RS_OFFSET(data.pin_config.vendor_length), |
| AML_OFFSET(pin_config.vendor_length), |
| 1}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET(data.pin_config.vendor_data), |
| AML_OFFSET(pin_config.vendor_offset), |
| 0}, |
| }; |
| |
| /******************************************************************************* |
| * |
| * acpi_rs_convert_pin_group |
| * |
| ******************************************************************************/ |
| |
| struct acpi_rsconvert_info acpi_rs_convert_pin_group[10] = { |
| {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_PIN_GROUP, |
| ACPI_RS_SIZE(struct acpi_resource_pin_group), |
| ACPI_RSC_TABLE_SIZE(acpi_rs_convert_pin_group)}, |
| |
| {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_PIN_GROUP, |
| sizeof(struct aml_resource_pin_group), |
| 0}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.pin_group.revision_id), |
| AML_OFFSET(pin_group.revision_id), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.pin_group.producer_consumer), |
| AML_OFFSET(pin_group.flags), |
| 0}, |
| |
| /* Pin Table */ |
| |
| /* |
| * It is OK to use GPIO operations here because none of them refer GPIO |
| * structures directly but instead use offsets given here. |
| */ |
| |
| {ACPI_RSC_COUNT_GPIO_PIN, |
| ACPI_RS_OFFSET(data.pin_group.pin_table_length), |
| AML_OFFSET(pin_group.pin_table_offset), |
| AML_OFFSET(pin_group.label_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_PIN, ACPI_RS_OFFSET(data.pin_group.pin_table), |
| AML_OFFSET(pin_group.pin_table_offset), |
| 0}, |
| |
| /* Resource Label */ |
| |
| {ACPI_RSC_COUNT_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group.resource_label.string_length), |
| AML_OFFSET(pin_group.label_offset), |
| AML_OFFSET(pin_group.vendor_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group.resource_label.string_ptr), |
| AML_OFFSET(pin_group.label_offset), |
| 0}, |
| |
| /* Vendor Data */ |
| |
| {ACPI_RSC_COUNT_GPIO_VEN, ACPI_RS_OFFSET(data.pin_group.vendor_length), |
| AML_OFFSET(pin_group.vendor_length), |
| 1}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET(data.pin_group.vendor_data), |
| AML_OFFSET(pin_group.vendor_offset), |
| 0}, |
| }; |
| |
| /******************************************************************************* |
| * |
| * acpi_rs_convert_pin_group_function |
| * |
| ******************************************************************************/ |
| |
| struct acpi_rsconvert_info acpi_rs_convert_pin_group_function[13] = { |
| {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_PIN_GROUP_FUNCTION, |
| ACPI_RS_SIZE(struct acpi_resource_pin_group_function), |
| ACPI_RSC_TABLE_SIZE(acpi_rs_convert_pin_group_function)}, |
| |
| {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_PIN_GROUP_FUNCTION, |
| sizeof(struct aml_resource_pin_group_function), |
| 0}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.pin_group_function.revision_id), |
| AML_OFFSET(pin_group_function.revision_id), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.pin_group_function.sharable), |
| AML_OFFSET(pin_group_function.flags), |
| 0}, |
| |
| {ACPI_RSC_1BITFLAG, |
| ACPI_RS_OFFSET(data.pin_group_function.producer_consumer), |
| AML_OFFSET(pin_group_function.flags), |
| 1}, |
| |
| {ACPI_RSC_MOVE16, |
| ACPI_RS_OFFSET(data.pin_group_function.function_number), |
| AML_OFFSET(pin_group_function.function_number), |
| 1}, |
| |
| /* Resource Source */ |
| |
| {ACPI_RSC_MOVE8, |
| ACPI_RS_OFFSET(data.pin_group_function.resource_source.index), |
| AML_OFFSET(pin_group_function.res_source_index), |
| 1}, |
| |
| {ACPI_RSC_COUNT_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group_function.resource_source.string_length), |
| AML_OFFSET(pin_group_function.res_source_offset), |
| AML_OFFSET(pin_group_function.res_source_label_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group_function.resource_source.string_ptr), |
| AML_OFFSET(pin_group_function.res_source_offset), |
| 0}, |
| |
| /* Resource Source Label */ |
| |
| {ACPI_RSC_COUNT_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group_function.resource_source_label. |
| string_length), |
| AML_OFFSET(pin_group_function.res_source_label_offset), |
| AML_OFFSET(pin_group_function.vendor_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group_function.resource_source_label. |
| string_ptr), |
| AML_OFFSET(pin_group_function.res_source_label_offset), |
| 0}, |
| |
| /* Vendor Data */ |
| |
| {ACPI_RSC_COUNT_GPIO_VEN, |
| ACPI_RS_OFFSET(data.pin_group_function.vendor_length), |
| AML_OFFSET(pin_group_function.vendor_length), |
| 1}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group_function.vendor_data), |
| AML_OFFSET(pin_group_function.vendor_offset), |
| 0}, |
| }; |
| |
| /******************************************************************************* |
| * |
| * acpi_rs_convert_pin_group_config |
| * |
| ******************************************************************************/ |
| |
| struct acpi_rsconvert_info acpi_rs_convert_pin_group_config[14] = { |
| {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_PIN_GROUP_CONFIG, |
| ACPI_RS_SIZE(struct acpi_resource_pin_group_config), |
| ACPI_RSC_TABLE_SIZE(acpi_rs_convert_pin_group_config)}, |
| |
| {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_PIN_GROUP_CONFIG, |
| sizeof(struct aml_resource_pin_group_config), |
| 0}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.pin_group_config.revision_id), |
| AML_OFFSET(pin_group_config.revision_id), |
| 1}, |
| |
| {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.pin_group_config.sharable), |
| AML_OFFSET(pin_group_config.flags), |
| 0}, |
| |
| {ACPI_RSC_1BITFLAG, |
| ACPI_RS_OFFSET(data.pin_group_config.producer_consumer), |
| AML_OFFSET(pin_group_config.flags), |
| 1}, |
| |
| {ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.pin_group_config.pin_config_type), |
| AML_OFFSET(pin_group_config.pin_config_type), |
| 1}, |
| |
| {ACPI_RSC_MOVE32, |
| ACPI_RS_OFFSET(data.pin_group_config.pin_config_value), |
| AML_OFFSET(pin_group_config.pin_config_value), |
| 1}, |
| |
| /* Resource Source */ |
| |
| {ACPI_RSC_MOVE8, |
| ACPI_RS_OFFSET(data.pin_group_config.resource_source.index), |
| AML_OFFSET(pin_group_config.res_source_index), |
| 1}, |
| |
| {ACPI_RSC_COUNT_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group_config.resource_source.string_length), |
| AML_OFFSET(pin_group_config.res_source_offset), |
| AML_OFFSET(pin_group_config.res_source_label_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group_config.resource_source.string_ptr), |
| AML_OFFSET(pin_group_config.res_source_offset), |
| 0}, |
| |
| /* Resource Source Label */ |
| |
| {ACPI_RSC_COUNT_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group_config.resource_source_label. |
| string_length), |
| AML_OFFSET(pin_group_config.res_source_label_offset), |
| AML_OFFSET(pin_group_config.vendor_offset)}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group_config.resource_source_label.string_ptr), |
| AML_OFFSET(pin_group_config.res_source_label_offset), |
| 0}, |
| |
| /* Vendor Data */ |
| |
| {ACPI_RSC_COUNT_GPIO_VEN, |
| ACPI_RS_OFFSET(data.pin_group_config.vendor_length), |
| AML_OFFSET(pin_group_config.vendor_length), |
| 1}, |
| |
| {ACPI_RSC_MOVE_GPIO_RES, |
| ACPI_RS_OFFSET(data.pin_group_config.vendor_data), |
| AML_OFFSET(pin_group_config.vendor_offset), |
| 0}, |
| }; |