1 /******************************************************************************* 2 * 3 * Module Name: rsserial - GPIO/SerialBus resource descriptors 4 * 5 ******************************************************************************/ 6 7 /* 8 * Copyright (C) 2000 - 2014, Intel Corp. 9 * All rights reserved. 10 * 11 * Redistribution and use in source and binary forms, with or without 12 * modification, are permitted provided that the following conditions 13 * are met: 14 * 1. Redistributions of source code must retain the above copyright 15 * notice, this list of conditions, and the following disclaimer, 16 * without modification. 17 * 2. Redistributions in binary form must reproduce at minimum a disclaimer 18 * substantially similar to the "NO WARRANTY" disclaimer below 19 * ("Disclaimer") and any redistribution must be conditioned upon 20 * including a substantially similar Disclaimer requirement for further 21 * binary redistribution. 22 * 3. Neither the names of the above-listed copyright holders nor the names 23 * of any contributors may be used to endorse or promote products derived 24 * from this software without specific prior written permission. 25 * 26 * Alternatively, this software may be distributed under the terms of the 27 * GNU General Public License ("GPL") version 2 as published by the Free 28 * Software Foundation. 29 * 30 * NO WARRANTY 31 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 32 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 33 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR 34 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 35 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 36 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 37 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 38 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 40 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 41 * POSSIBILITY OF SUCH DAMAGES. 42 */ 43 44 #define __RSIRQ_C__ 45 46 #include "acpi.h" 47 #include "accommon.h" 48 #include "acresrc.h" 49 50 #define _COMPONENT ACPI_RESOURCES 51 ACPI_MODULE_NAME ("rsserial") 52 53 54 /******************************************************************************* 55 * 56 * AcpiRsConvertGpio 57 * 58 ******************************************************************************/ 59 60 ACPI_RSCONVERT_INFO AcpiRsConvertGpio[18] = 61 { 62 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_GPIO, 63 ACPI_RS_SIZE (ACPI_RESOURCE_GPIO), 64 ACPI_RSC_TABLE_SIZE (AcpiRsConvertGpio)}, 65 66 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_GPIO, 67 sizeof (AML_RESOURCE_GPIO), 68 0}, 69 70 /* 71 * These fields are contiguous in both the source and destination: 72 * RevisionId 73 * ConnectionType 74 */ 75 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.Gpio.RevisionId), 76 AML_OFFSET (Gpio.RevisionId), 77 2}, 78 79 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.Gpio.ProducerConsumer), 80 AML_OFFSET (Gpio.Flags), 81 0}, 82 83 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.Gpio.Sharable), 84 AML_OFFSET (Gpio.IntFlags), 85 3}, 86 87 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.Gpio.WakeCapable), 88 AML_OFFSET (Gpio.IntFlags), 89 4}, 90 91 {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET (Data.Gpio.IoRestriction), 92 AML_OFFSET (Gpio.IntFlags), 93 0}, 94 95 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.Gpio.Triggering), 96 AML_OFFSET (Gpio.IntFlags), 97 0}, 98 99 {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET (Data.Gpio.Polarity), 100 AML_OFFSET (Gpio.IntFlags), 101 1}, 102 103 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.Gpio.PinConfig), 104 AML_OFFSET (Gpio.PinConfig), 105 1}, 106 107 /* 108 * These fields are contiguous in both the source and destination: 109 * DriveStrength 110 * DebounceTimeout 111 */ 112 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.Gpio.DriveStrength), 113 AML_OFFSET (Gpio.DriveStrength), 114 2}, 115 116 /* Pin Table */ 117 118 {ACPI_RSC_COUNT_GPIO_PIN, ACPI_RS_OFFSET (Data.Gpio.PinTableLength), 119 AML_OFFSET (Gpio.PinTableOffset), 120 AML_OFFSET (Gpio.ResSourceOffset)}, 121 122 {ACPI_RSC_MOVE_GPIO_PIN, ACPI_RS_OFFSET (Data.Gpio.PinTable), 123 AML_OFFSET (Gpio.PinTableOffset), 124 0}, 125 126 /* Resource Source */ 127 128 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.Gpio.ResourceSource.Index), 129 AML_OFFSET (Gpio.ResSourceIndex), 130 1}, 131 132 {ACPI_RSC_COUNT_GPIO_RES, ACPI_RS_OFFSET (Data.Gpio.ResourceSource.StringLength), 133 AML_OFFSET (Gpio.ResSourceOffset), 134 AML_OFFSET (Gpio.VendorOffset)}, 135 136 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.Gpio.ResourceSource.StringPtr), 137 AML_OFFSET (Gpio.ResSourceOffset), 138 0}, 139 140 /* Vendor Data */ 141 142 {ACPI_RSC_COUNT_GPIO_VEN, ACPI_RS_OFFSET (Data.Gpio.VendorLength), 143 AML_OFFSET (Gpio.VendorLength), 144 1}, 145 146 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.Gpio.VendorData), 147 AML_OFFSET (Gpio.VendorOffset), 148 0}, 149 }; 150 151 152 /******************************************************************************* 153 * 154 * AcpiRsConvertI2cSerialBus 155 * 156 ******************************************************************************/ 157 158 ACPI_RSCONVERT_INFO AcpiRsConvertI2cSerialBus[16] = 159 { 160 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, 161 ACPI_RS_SIZE (ACPI_RESOURCE_I2C_SERIALBUS), 162 ACPI_RSC_TABLE_SIZE (AcpiRsConvertI2cSerialBus)}, 163 164 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, 165 sizeof (AML_RESOURCE_I2C_SERIALBUS), 166 0}, 167 168 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.RevisionId), 169 AML_OFFSET (CommonSerialBus.RevisionId), 170 1}, 171 172 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.Type), 173 AML_OFFSET (CommonSerialBus.Type), 174 1}, 175 176 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.SlaveMode), 177 AML_OFFSET (CommonSerialBus.Flags), 178 0}, 179 180 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.ProducerConsumer), 181 AML_OFFSET (CommonSerialBus.Flags), 182 1}, 183 184 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeRevisionId), 185 AML_OFFSET (CommonSerialBus.TypeRevisionId), 186 1}, 187 188 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeDataLength), 189 AML_OFFSET (CommonSerialBus.TypeDataLength), 190 1}, 191 192 /* Vendor data */ 193 194 {ACPI_RSC_COUNT_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorLength), 195 AML_OFFSET (CommonSerialBus.TypeDataLength), 196 AML_RESOURCE_I2C_MIN_DATA_LEN}, 197 198 {ACPI_RSC_MOVE_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorData), 199 0, 200 sizeof (AML_RESOURCE_I2C_SERIALBUS)}, 201 202 /* Resource Source */ 203 204 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.Index), 205 AML_OFFSET (CommonSerialBus.ResSourceIndex), 206 1}, 207 208 {ACPI_RSC_COUNT_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringLength), 209 AML_OFFSET (CommonSerialBus.TypeDataLength), 210 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 211 212 {ACPI_RSC_MOVE_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringPtr), 213 AML_OFFSET (CommonSerialBus.TypeDataLength), 214 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 215 216 /* I2C bus type specific */ 217 218 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.I2cSerialBus.AccessMode), 219 AML_OFFSET (I2cSerialBus.TypeSpecificFlags), 220 0}, 221 222 {ACPI_RSC_MOVE32, ACPI_RS_OFFSET (Data.I2cSerialBus.ConnectionSpeed), 223 AML_OFFSET (I2cSerialBus.ConnectionSpeed), 224 1}, 225 226 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.I2cSerialBus.SlaveAddress), 227 AML_OFFSET (I2cSerialBus.SlaveAddress), 228 1}, 229 }; 230 231 232 /******************************************************************************* 233 * 234 * AcpiRsConvertSpiSerialBus 235 * 236 ******************************************************************************/ 237 238 ACPI_RSCONVERT_INFO AcpiRsConvertSpiSerialBus[20] = 239 { 240 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, 241 ACPI_RS_SIZE (ACPI_RESOURCE_SPI_SERIALBUS), 242 ACPI_RSC_TABLE_SIZE (AcpiRsConvertSpiSerialBus)}, 243 244 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, 245 sizeof (AML_RESOURCE_SPI_SERIALBUS), 246 0}, 247 248 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.RevisionId), 249 AML_OFFSET (CommonSerialBus.RevisionId), 250 1}, 251 252 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.Type), 253 AML_OFFSET (CommonSerialBus.Type), 254 1}, 255 256 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.SlaveMode), 257 AML_OFFSET (CommonSerialBus.Flags), 258 0}, 259 260 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.ProducerConsumer), 261 AML_OFFSET (CommonSerialBus.Flags), 262 1}, 263 264 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeRevisionId), 265 AML_OFFSET (CommonSerialBus.TypeRevisionId), 266 1}, 267 268 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeDataLength), 269 AML_OFFSET (CommonSerialBus.TypeDataLength), 270 1}, 271 272 /* Vendor data */ 273 274 {ACPI_RSC_COUNT_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorLength), 275 AML_OFFSET (CommonSerialBus.TypeDataLength), 276 AML_RESOURCE_SPI_MIN_DATA_LEN}, 277 278 {ACPI_RSC_MOVE_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorData), 279 0, 280 sizeof (AML_RESOURCE_SPI_SERIALBUS)}, 281 282 /* Resource Source */ 283 284 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.Index), 285 AML_OFFSET (CommonSerialBus.ResSourceIndex), 286 1}, 287 288 {ACPI_RSC_COUNT_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringLength), 289 AML_OFFSET (CommonSerialBus.TypeDataLength), 290 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 291 292 {ACPI_RSC_MOVE_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringPtr), 293 AML_OFFSET (CommonSerialBus.TypeDataLength), 294 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 295 296 /* Spi bus type specific */ 297 298 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.SpiSerialBus.WireMode), 299 AML_OFFSET (SpiSerialBus.TypeSpecificFlags), 300 0}, 301 302 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.SpiSerialBus.DevicePolarity), 303 AML_OFFSET (SpiSerialBus.TypeSpecificFlags), 304 1}, 305 306 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.SpiSerialBus.DataBitLength), 307 AML_OFFSET (SpiSerialBus.DataBitLength), 308 1}, 309 310 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.SpiSerialBus.ClockPhase), 311 AML_OFFSET (SpiSerialBus.ClockPhase), 312 1}, 313 314 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.SpiSerialBus.ClockPolarity), 315 AML_OFFSET (SpiSerialBus.ClockPolarity), 316 1}, 317 318 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.SpiSerialBus.DeviceSelection), 319 AML_OFFSET (SpiSerialBus.DeviceSelection), 320 1}, 321 322 {ACPI_RSC_MOVE32, ACPI_RS_OFFSET (Data.SpiSerialBus.ConnectionSpeed), 323 AML_OFFSET (SpiSerialBus.ConnectionSpeed), 324 1}, 325 }; 326 327 328 /******************************************************************************* 329 * 330 * AcpiRsConvertUartSerialBus 331 * 332 ******************************************************************************/ 333 334 ACPI_RSCONVERT_INFO AcpiRsConvertUartSerialBus[22] = 335 { 336 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, 337 ACPI_RS_SIZE (ACPI_RESOURCE_UART_SERIALBUS), 338 ACPI_RSC_TABLE_SIZE (AcpiRsConvertUartSerialBus)}, 339 340 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, 341 sizeof (AML_RESOURCE_UART_SERIALBUS), 342 0}, 343 344 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.RevisionId), 345 AML_OFFSET (CommonSerialBus.RevisionId), 346 1}, 347 348 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.Type), 349 AML_OFFSET (CommonSerialBus.Type), 350 1}, 351 352 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.SlaveMode), 353 AML_OFFSET (CommonSerialBus.Flags), 354 0}, 355 356 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.ProducerConsumer), 357 AML_OFFSET (CommonSerialBus.Flags), 358 1}, 359 360 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeRevisionId), 361 AML_OFFSET (CommonSerialBus.TypeRevisionId), 362 1}, 363 364 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeDataLength), 365 AML_OFFSET (CommonSerialBus.TypeDataLength), 366 1}, 367 368 /* Vendor data */ 369 370 {ACPI_RSC_COUNT_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorLength), 371 AML_OFFSET (CommonSerialBus.TypeDataLength), 372 AML_RESOURCE_UART_MIN_DATA_LEN}, 373 374 {ACPI_RSC_MOVE_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorData), 375 0, 376 sizeof (AML_RESOURCE_UART_SERIALBUS)}, 377 378 /* Resource Source */ 379 380 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.Index), 381 AML_OFFSET (CommonSerialBus.ResSourceIndex), 382 1}, 383 384 {ACPI_RSC_COUNT_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringLength), 385 AML_OFFSET (CommonSerialBus.TypeDataLength), 386 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 387 388 {ACPI_RSC_MOVE_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringPtr), 389 AML_OFFSET (CommonSerialBus.TypeDataLength), 390 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 391 392 /* Uart bus type specific */ 393 394 {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET (Data.UartSerialBus.FlowControl), 395 AML_OFFSET (UartSerialBus.TypeSpecificFlags), 396 0}, 397 398 {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET (Data.UartSerialBus.StopBits), 399 AML_OFFSET (UartSerialBus.TypeSpecificFlags), 400 2}, 401 402 {ACPI_RSC_3BITFLAG, ACPI_RS_OFFSET (Data.UartSerialBus.DataBits), 403 AML_OFFSET (UartSerialBus.TypeSpecificFlags), 404 4}, 405 406 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.UartSerialBus.Endian), 407 AML_OFFSET (UartSerialBus.TypeSpecificFlags), 408 7}, 409 410 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.UartSerialBus.Parity), 411 AML_OFFSET (UartSerialBus.Parity), 412 1}, 413 414 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.UartSerialBus.LinesEnabled), 415 AML_OFFSET (UartSerialBus.LinesEnabled), 416 1}, 417 418 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.UartSerialBus.RxFifoSize), 419 AML_OFFSET (UartSerialBus.RxFifoSize), 420 1}, 421 422 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.UartSerialBus.TxFifoSize), 423 AML_OFFSET (UartSerialBus.TxFifoSize), 424 1}, 425 426 {ACPI_RSC_MOVE32, ACPI_RS_OFFSET (Data.UartSerialBus.DefaultBaudRate), 427 AML_OFFSET (UartSerialBus.DefaultBaudRate), 428 1}, 429 };