// SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 /******************************************************************************* * * Module Name: rsserial - GPIO/serial_bus resource descriptors * ******************************************************************************/ #include #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.shareable), 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.shareable), 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_csi2_serial_bus * ******************************************************************************/ struct acpi_rsconvert_info acpi_rs_convert_csi2_serial_bus[14] = { { ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, ACPI_RS_SIZE(struct acpi_resource_csi2_serialbus), ACPI_RSC_TABLE_SIZE(acpi_rs_convert_csi2_serial_bus) }, { ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, sizeof(struct aml_resource_csi2_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.csi2_serial_bus.type), AML_OFFSET(csi2_serial_bus.type), 1 }, { ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.csi2_serial_bus.producer_consumer), AML_OFFSET(csi2_serial_bus.flags), 1 }, { ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET(data.csi2_serial_bus.slave_mode), AML_OFFSET(csi2_serial_bus.flags), 0 }, { ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET(data.csi2_serial_bus.phy_type), AML_OFFSET(csi2_serial_bus.type_specific_flags), 0 }, { ACPI_RSC_6BITFLAG, ACPI_RS_OFFSET(data.csi2_serial_bus.local_port_instance), AML_OFFSET(csi2_serial_bus.type_specific_flags), 2 }, { ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.csi2_serial_bus.type_revision_id), AML_OFFSET(csi2_serial_bus.type_revision_id), 1 }, /* Vendor data */ { ACPI_RSC_COUNT_SERIAL_VEN, ACPI_RS_OFFSET(data.csi2_serial_bus.vendor_length), AML_OFFSET(csi2_serial_bus.type_data_length), AML_RESOURCE_CSI2_MIN_DATA_LEN }, { ACPI_RSC_MOVE_SERIAL_VEN, ACPI_RS_OFFSET(data.csi2_serial_bus.vendor_data), 0, sizeof(struct aml_resource_csi2_serialbus) }, /* Resource Source */ { ACPI_RSC_MOVE8, ACPI_RS_OFFSET(data.csi2_serial_bus.resource_source.index), AML_OFFSET(csi2_serial_bus.res_source_index), 1 }, { ACPI_RSC_COUNT_SERIAL_RES, ACPI_RS_OFFSET(data.csi2_serial_bus.resource_source.string_length), AML_OFFSET(csi2_serial_bus.type_data_length), sizeof(struct aml_resource_csi2_serialbus) }, { ACPI_RSC_MOVE_SERIAL_RES, ACPI_RS_OFFSET(data.csi2_serial_bus.resource_source.string_ptr), AML_OFFSET(csi2_serial_bus.type_data_length), sizeof(struct aml_resource_csi2_serialbus) }, }; /******************************************************************************* * * 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.shareable), 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.shareable), 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.shareable), 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 }, };