1 /******************************************************************************* 2 * 3 * Module Name: rsserial - GPIO/SerialBus resource descriptors 4 * 5 ******************************************************************************/ 6 7 /* 8 * Copyright (C) 2000 - 2021, 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 MERCHANTABILITY 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 #include "acpi.h" 45 #include "accommon.h" 46 #include "acresrc.h" 47 48 #define _COMPONENT ACPI_RESOURCES 49 ACPI_MODULE_NAME ("rsserial") 50 51 52 /******************************************************************************* 53 * 54 * AcpiRsConvertGpio 55 * 56 ******************************************************************************/ 57 58 ACPI_RSCONVERT_INFO AcpiRsConvertGpio[18] = 59 { 60 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_GPIO, 61 ACPI_RS_SIZE (ACPI_RESOURCE_GPIO), 62 ACPI_RSC_TABLE_SIZE (AcpiRsConvertGpio)}, 63 64 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_GPIO, 65 sizeof (AML_RESOURCE_GPIO), 66 0}, 67 68 /* 69 * These fields are contiguous in both the source and destination: 70 * RevisionId 71 * ConnectionType 72 */ 73 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.Gpio.RevisionId), 74 AML_OFFSET (Gpio.RevisionId), 75 2}, 76 77 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.Gpio.ProducerConsumer), 78 AML_OFFSET (Gpio.Flags), 79 0}, 80 81 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.Gpio.Shareable), 82 AML_OFFSET (Gpio.IntFlags), 83 3}, 84 85 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.Gpio.WakeCapable), 86 AML_OFFSET (Gpio.IntFlags), 87 4}, 88 89 {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET (Data.Gpio.IoRestriction), 90 AML_OFFSET (Gpio.IntFlags), 91 0}, 92 93 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.Gpio.Triggering), 94 AML_OFFSET (Gpio.IntFlags), 95 0}, 96 97 {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET (Data.Gpio.Polarity), 98 AML_OFFSET (Gpio.IntFlags), 99 1}, 100 101 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.Gpio.PinConfig), 102 AML_OFFSET (Gpio.PinConfig), 103 1}, 104 105 /* 106 * These fields are contiguous in both the source and destination: 107 * DriveStrength 108 * DebounceTimeout 109 */ 110 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.Gpio.DriveStrength), 111 AML_OFFSET (Gpio.DriveStrength), 112 2}, 113 114 /* Pin Table */ 115 116 {ACPI_RSC_COUNT_GPIO_PIN, ACPI_RS_OFFSET (Data.Gpio.PinTableLength), 117 AML_OFFSET (Gpio.PinTableOffset), 118 AML_OFFSET (Gpio.ResSourceOffset)}, 119 120 {ACPI_RSC_MOVE_GPIO_PIN, ACPI_RS_OFFSET (Data.Gpio.PinTable), 121 AML_OFFSET (Gpio.PinTableOffset), 122 0}, 123 124 /* Resource Source */ 125 126 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.Gpio.ResourceSource.Index), 127 AML_OFFSET (Gpio.ResSourceIndex), 128 1}, 129 130 {ACPI_RSC_COUNT_GPIO_RES, ACPI_RS_OFFSET (Data.Gpio.ResourceSource.StringLength), 131 AML_OFFSET (Gpio.ResSourceOffset), 132 AML_OFFSET (Gpio.VendorOffset)}, 133 134 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.Gpio.ResourceSource.StringPtr), 135 AML_OFFSET (Gpio.ResSourceOffset), 136 0}, 137 138 /* Vendor Data */ 139 140 {ACPI_RSC_COUNT_GPIO_VEN, ACPI_RS_OFFSET (Data.Gpio.VendorLength), 141 AML_OFFSET (Gpio.VendorLength), 142 1}, 143 144 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.Gpio.VendorData), 145 AML_OFFSET (Gpio.VendorOffset), 146 0}, 147 }; 148 149 /******************************************************************************* 150 * 151 * AcpiRsConvertPinfunction 152 * 153 ******************************************************************************/ 154 155 ACPI_RSCONVERT_INFO AcpiRsConvertPinFunction[13] = 156 { 157 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_PIN_FUNCTION, 158 ACPI_RS_SIZE (ACPI_RESOURCE_PIN_FUNCTION), 159 ACPI_RSC_TABLE_SIZE (AcpiRsConvertPinFunction)}, 160 161 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_PIN_FUNCTION, 162 sizeof (AML_RESOURCE_PIN_FUNCTION), 163 0}, 164 165 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinFunction.RevisionId), 166 AML_OFFSET (PinFunction.RevisionId), 167 1}, 168 169 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.PinFunction.Shareable), 170 AML_OFFSET (PinFunction.Flags), 171 0}, 172 173 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinFunction.PinConfig), 174 AML_OFFSET (PinFunction.PinConfig), 175 1}, 176 177 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.PinFunction.FunctionNumber), 178 AML_OFFSET (PinFunction.FunctionNumber), 179 2}, 180 181 /* Pin Table */ 182 183 /* 184 * It is OK to use GPIO operations here because none of them refer GPIO 185 * structures directly but instead use offsets given here. 186 */ 187 188 {ACPI_RSC_COUNT_GPIO_PIN, ACPI_RS_OFFSET (Data.PinFunction.PinTableLength), 189 AML_OFFSET (PinFunction.PinTableOffset), 190 AML_OFFSET (PinFunction.ResSourceOffset)}, 191 192 {ACPI_RSC_MOVE_GPIO_PIN, ACPI_RS_OFFSET (Data.PinFunction.PinTable), 193 AML_OFFSET (PinFunction.PinTableOffset), 194 0}, 195 196 /* Resource Source */ 197 198 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinFunction.ResourceSource.Index), 199 AML_OFFSET (PinFunction.ResSourceIndex), 200 1}, 201 202 {ACPI_RSC_COUNT_GPIO_RES, ACPI_RS_OFFSET (Data.PinFunction.ResourceSource.StringLength), 203 AML_OFFSET (PinFunction.ResSourceOffset), 204 AML_OFFSET (PinFunction.VendorOffset)}, 205 206 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinFunction.ResourceSource.StringPtr), 207 AML_OFFSET (PinFunction.ResSourceOffset), 208 0}, 209 210 /* Vendor Data */ 211 212 {ACPI_RSC_COUNT_GPIO_VEN, ACPI_RS_OFFSET (Data.PinFunction.VendorLength), 213 AML_OFFSET (PinFunction.VendorLength), 214 1}, 215 216 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinFunction.VendorData), 217 AML_OFFSET (PinFunction.VendorOffset), 218 0}, 219 }; 220 221 222 /******************************************************************************* 223 * 224 * AcpiRsConvertCsi2SerialBus 225 * 226 ******************************************************************************/ 227 228 ACPI_RSCONVERT_INFO AcpiRsConvertCsi2SerialBus[14] = 229 { 230 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, 231 ACPI_RS_SIZE (ACPI_RESOURCE_CSI2_SERIALBUS), 232 ACPI_RSC_TABLE_SIZE (AcpiRsConvertCsi2SerialBus)}, 233 234 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, 235 sizeof (AML_RESOURCE_CSI2_SERIALBUS), 236 0}, 237 238 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.RevisionId), 239 AML_OFFSET (CommonSerialBus.RevisionId), 240 1}, 241 242 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.Csi2SerialBus.Type), 243 AML_OFFSET (Csi2SerialBus.Type), 244 1}, 245 246 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.Csi2SerialBus.ProducerConsumer), 247 AML_OFFSET (Csi2SerialBus.Flags), 248 1}, 249 250 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.Csi2SerialBus.SlaveMode), 251 AML_OFFSET (Csi2SerialBus.Flags), 252 0}, 253 254 {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET (Data.Csi2SerialBus.PhyType), 255 AML_OFFSET (Csi2SerialBus.TypeSpecificFlags), 256 0}, 257 258 {ACPI_RSC_6BITFLAG, ACPI_RS_OFFSET (Data.Csi2SerialBus.LocalPortInstance), 259 AML_OFFSET (Csi2SerialBus.TypeSpecificFlags), 260 2}, 261 262 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.Csi2SerialBus.TypeRevisionId), 263 AML_OFFSET (Csi2SerialBus.TypeRevisionId), 264 1}, 265 266 /* Vendor data */ 267 268 {ACPI_RSC_COUNT_SERIAL_VEN, ACPI_RS_OFFSET (Data.Csi2SerialBus.VendorLength), 269 AML_OFFSET (Csi2SerialBus.TypeDataLength), 270 AML_RESOURCE_CSI2_MIN_DATA_LEN}, 271 272 {ACPI_RSC_MOVE_SERIAL_VEN, ACPI_RS_OFFSET (Data.Csi2SerialBus.VendorData), 273 0, 274 sizeof (AML_RESOURCE_CSI2_SERIALBUS)}, 275 276 /* Resource Source */ 277 278 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.Csi2SerialBus.ResourceSource.Index), 279 AML_OFFSET (Csi2SerialBus.ResSourceIndex), 280 1}, 281 282 {ACPI_RSC_COUNT_SERIAL_RES, ACPI_RS_OFFSET (Data.Csi2SerialBus.ResourceSource.StringLength), 283 AML_OFFSET (Csi2SerialBus.TypeDataLength), 284 sizeof (AML_RESOURCE_CSI2_SERIALBUS)}, 285 286 {ACPI_RSC_MOVE_SERIAL_RES, ACPI_RS_OFFSET (Data.Csi2SerialBus.ResourceSource.StringPtr), 287 AML_OFFSET (Csi2SerialBus.TypeDataLength), 288 sizeof (AML_RESOURCE_CSI2_SERIALBUS)}, 289 }; 290 291 292 /******************************************************************************* 293 * 294 * AcpiRsConvertI2cSerialBus 295 * 296 ******************************************************************************/ 297 298 ACPI_RSCONVERT_INFO AcpiRsConvertI2cSerialBus[17] = 299 { 300 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, 301 ACPI_RS_SIZE (ACPI_RESOURCE_I2C_SERIALBUS), 302 ACPI_RSC_TABLE_SIZE (AcpiRsConvertI2cSerialBus)}, 303 304 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, 305 sizeof (AML_RESOURCE_I2C_SERIALBUS), 306 0}, 307 308 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.RevisionId), 309 AML_OFFSET (CommonSerialBus.RevisionId), 310 1}, 311 312 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.Type), 313 AML_OFFSET (CommonSerialBus.Type), 314 1}, 315 316 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.SlaveMode), 317 AML_OFFSET (CommonSerialBus.Flags), 318 0}, 319 320 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.ProducerConsumer), 321 AML_OFFSET (CommonSerialBus.Flags), 322 1}, 323 324 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.ConnectionSharing), 325 AML_OFFSET (CommonSerialBus.Flags), 326 2}, 327 328 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeRevisionId), 329 AML_OFFSET (CommonSerialBus.TypeRevisionId), 330 1}, 331 332 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeDataLength), 333 AML_OFFSET (CommonSerialBus.TypeDataLength), 334 1}, 335 336 /* Vendor data */ 337 338 {ACPI_RSC_COUNT_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorLength), 339 AML_OFFSET (CommonSerialBus.TypeDataLength), 340 AML_RESOURCE_I2C_MIN_DATA_LEN}, 341 342 {ACPI_RSC_MOVE_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorData), 343 0, 344 sizeof (AML_RESOURCE_I2C_SERIALBUS)}, 345 346 /* Resource Source */ 347 348 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.Index), 349 AML_OFFSET (CommonSerialBus.ResSourceIndex), 350 1}, 351 352 {ACPI_RSC_COUNT_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringLength), 353 AML_OFFSET (CommonSerialBus.TypeDataLength), 354 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 355 356 {ACPI_RSC_MOVE_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringPtr), 357 AML_OFFSET (CommonSerialBus.TypeDataLength), 358 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 359 360 /* I2C bus type specific */ 361 362 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.I2cSerialBus.AccessMode), 363 AML_OFFSET (I2cSerialBus.TypeSpecificFlags), 364 0}, 365 366 {ACPI_RSC_MOVE32, ACPI_RS_OFFSET (Data.I2cSerialBus.ConnectionSpeed), 367 AML_OFFSET (I2cSerialBus.ConnectionSpeed), 368 1}, 369 370 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.I2cSerialBus.SlaveAddress), 371 AML_OFFSET (I2cSerialBus.SlaveAddress), 372 1}, 373 }; 374 375 376 /******************************************************************************* 377 * 378 * AcpiRsConvertSpiSerialBus 379 * 380 ******************************************************************************/ 381 382 ACPI_RSCONVERT_INFO AcpiRsConvertSpiSerialBus[21] = 383 { 384 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, 385 ACPI_RS_SIZE (ACPI_RESOURCE_SPI_SERIALBUS), 386 ACPI_RSC_TABLE_SIZE (AcpiRsConvertSpiSerialBus)}, 387 388 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, 389 sizeof (AML_RESOURCE_SPI_SERIALBUS), 390 0}, 391 392 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.RevisionId), 393 AML_OFFSET (CommonSerialBus.RevisionId), 394 1}, 395 396 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.Type), 397 AML_OFFSET (CommonSerialBus.Type), 398 1}, 399 400 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.SlaveMode), 401 AML_OFFSET (CommonSerialBus.Flags), 402 0}, 403 404 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.ProducerConsumer), 405 AML_OFFSET (CommonSerialBus.Flags), 406 1}, 407 408 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.ConnectionSharing), 409 AML_OFFSET (CommonSerialBus.Flags), 410 2}, 411 412 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeRevisionId), 413 AML_OFFSET (CommonSerialBus.TypeRevisionId), 414 1}, 415 416 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeDataLength), 417 AML_OFFSET (CommonSerialBus.TypeDataLength), 418 1}, 419 420 /* Vendor data */ 421 422 {ACPI_RSC_COUNT_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorLength), 423 AML_OFFSET (CommonSerialBus.TypeDataLength), 424 AML_RESOURCE_SPI_MIN_DATA_LEN}, 425 426 {ACPI_RSC_MOVE_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorData), 427 0, 428 sizeof (AML_RESOURCE_SPI_SERIALBUS)}, 429 430 /* Resource Source */ 431 432 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.Index), 433 AML_OFFSET (CommonSerialBus.ResSourceIndex), 434 1}, 435 436 {ACPI_RSC_COUNT_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringLength), 437 AML_OFFSET (CommonSerialBus.TypeDataLength), 438 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 439 440 {ACPI_RSC_MOVE_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringPtr), 441 AML_OFFSET (CommonSerialBus.TypeDataLength), 442 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 443 444 /* Spi bus type specific */ 445 446 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.SpiSerialBus.WireMode), 447 AML_OFFSET (SpiSerialBus.TypeSpecificFlags), 448 0}, 449 450 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.SpiSerialBus.DevicePolarity), 451 AML_OFFSET (SpiSerialBus.TypeSpecificFlags), 452 1}, 453 454 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.SpiSerialBus.DataBitLength), 455 AML_OFFSET (SpiSerialBus.DataBitLength), 456 1}, 457 458 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.SpiSerialBus.ClockPhase), 459 AML_OFFSET (SpiSerialBus.ClockPhase), 460 1}, 461 462 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.SpiSerialBus.ClockPolarity), 463 AML_OFFSET (SpiSerialBus.ClockPolarity), 464 1}, 465 466 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.SpiSerialBus.DeviceSelection), 467 AML_OFFSET (SpiSerialBus.DeviceSelection), 468 1}, 469 470 {ACPI_RSC_MOVE32, ACPI_RS_OFFSET (Data.SpiSerialBus.ConnectionSpeed), 471 AML_OFFSET (SpiSerialBus.ConnectionSpeed), 472 1}, 473 }; 474 475 476 /******************************************************************************* 477 * 478 * AcpiRsConvertUartSerialBus 479 * 480 ******************************************************************************/ 481 482 ACPI_RSCONVERT_INFO AcpiRsConvertUartSerialBus[23] = 483 { 484 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_SERIAL_BUS, 485 ACPI_RS_SIZE (ACPI_RESOURCE_UART_SERIALBUS), 486 ACPI_RSC_TABLE_SIZE (AcpiRsConvertUartSerialBus)}, 487 488 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_SERIAL_BUS, 489 sizeof (AML_RESOURCE_UART_SERIALBUS), 490 0}, 491 492 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.RevisionId), 493 AML_OFFSET (CommonSerialBus.RevisionId), 494 1}, 495 496 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.Type), 497 AML_OFFSET (CommonSerialBus.Type), 498 1}, 499 500 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.SlaveMode), 501 AML_OFFSET (CommonSerialBus.Flags), 502 0}, 503 504 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.ProducerConsumer), 505 AML_OFFSET (CommonSerialBus.Flags), 506 1}, 507 508 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.CommonSerialBus.ConnectionSharing), 509 AML_OFFSET (CommonSerialBus.Flags), 510 2}, 511 512 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeRevisionId), 513 AML_OFFSET (CommonSerialBus.TypeRevisionId), 514 1}, 515 516 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.CommonSerialBus.TypeDataLength), 517 AML_OFFSET (CommonSerialBus.TypeDataLength), 518 1}, 519 520 /* Vendor data */ 521 522 {ACPI_RSC_COUNT_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorLength), 523 AML_OFFSET (CommonSerialBus.TypeDataLength), 524 AML_RESOURCE_UART_MIN_DATA_LEN}, 525 526 {ACPI_RSC_MOVE_SERIAL_VEN, ACPI_RS_OFFSET (Data.CommonSerialBus.VendorData), 527 0, 528 sizeof (AML_RESOURCE_UART_SERIALBUS)}, 529 530 /* Resource Source */ 531 532 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.Index), 533 AML_OFFSET (CommonSerialBus.ResSourceIndex), 534 1}, 535 536 {ACPI_RSC_COUNT_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringLength), 537 AML_OFFSET (CommonSerialBus.TypeDataLength), 538 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 539 540 {ACPI_RSC_MOVE_SERIAL_RES, ACPI_RS_OFFSET (Data.CommonSerialBus.ResourceSource.StringPtr), 541 AML_OFFSET (CommonSerialBus.TypeDataLength), 542 sizeof (AML_RESOURCE_COMMON_SERIALBUS)}, 543 544 /* Uart bus type specific */ 545 546 {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET (Data.UartSerialBus.FlowControl), 547 AML_OFFSET (UartSerialBus.TypeSpecificFlags), 548 0}, 549 550 {ACPI_RSC_2BITFLAG, ACPI_RS_OFFSET (Data.UartSerialBus.StopBits), 551 AML_OFFSET (UartSerialBus.TypeSpecificFlags), 552 2}, 553 554 {ACPI_RSC_3BITFLAG, ACPI_RS_OFFSET (Data.UartSerialBus.DataBits), 555 AML_OFFSET (UartSerialBus.TypeSpecificFlags), 556 4}, 557 558 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.UartSerialBus.Endian), 559 AML_OFFSET (UartSerialBus.TypeSpecificFlags), 560 7}, 561 562 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.UartSerialBus.Parity), 563 AML_OFFSET (UartSerialBus.Parity), 564 1}, 565 566 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.UartSerialBus.LinesEnabled), 567 AML_OFFSET (UartSerialBus.LinesEnabled), 568 1}, 569 570 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.UartSerialBus.RxFifoSize), 571 AML_OFFSET (UartSerialBus.RxFifoSize), 572 1}, 573 574 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.UartSerialBus.TxFifoSize), 575 AML_OFFSET (UartSerialBus.TxFifoSize), 576 1}, 577 578 {ACPI_RSC_MOVE32, ACPI_RS_OFFSET (Data.UartSerialBus.DefaultBaudRate), 579 AML_OFFSET (UartSerialBus.DefaultBaudRate), 580 1}, 581 }; 582 583 584 /******************************************************************************* 585 * 586 * AcpiRsConvertPinConfig 587 * 588 ******************************************************************************/ 589 590 ACPI_RSCONVERT_INFO AcpiRsConvertPinConfig[14] = 591 { 592 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_PIN_CONFIG, 593 ACPI_RS_SIZE (ACPI_RESOURCE_PIN_CONFIG), 594 ACPI_RSC_TABLE_SIZE (AcpiRsConvertPinConfig)}, 595 596 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_PIN_CONFIG, 597 sizeof (AML_RESOURCE_PIN_CONFIG), 598 0}, 599 600 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinConfig.RevisionId), 601 AML_OFFSET (PinConfig.RevisionId), 602 1}, 603 604 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.PinConfig.Shareable), 605 AML_OFFSET (PinConfig.Flags), 606 0}, 607 608 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.PinConfig.ProducerConsumer), 609 AML_OFFSET (PinConfig.Flags), 610 1}, 611 612 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinConfig.PinConfigType), 613 AML_OFFSET (PinConfig.PinConfigType), 614 1}, 615 616 {ACPI_RSC_MOVE32, ACPI_RS_OFFSET (Data.PinConfig.PinConfigValue), 617 AML_OFFSET (PinConfig.PinConfigValue), 618 1}, 619 620 /* Pin Table */ 621 622 /* 623 * It is OK to use GPIO operations here because none of them refer GPIO 624 * structures directly but instead use offsets given here. 625 */ 626 627 {ACPI_RSC_COUNT_GPIO_PIN, ACPI_RS_OFFSET (Data.PinConfig.PinTableLength), 628 AML_OFFSET (PinConfig.PinTableOffset), 629 AML_OFFSET (PinConfig.ResSourceOffset)}, 630 631 {ACPI_RSC_MOVE_GPIO_PIN, ACPI_RS_OFFSET (Data.PinConfig.PinTable), 632 AML_OFFSET (PinConfig.PinTableOffset), 633 0}, 634 635 /* Resource Source */ 636 637 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinConfig.ResourceSource.Index), 638 AML_OFFSET (PinConfig.ResSourceIndex), 639 1}, 640 641 {ACPI_RSC_COUNT_GPIO_RES, ACPI_RS_OFFSET (Data.PinConfig.ResourceSource.StringLength), 642 AML_OFFSET (PinConfig.ResSourceOffset), 643 AML_OFFSET (PinConfig.VendorOffset)}, 644 645 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinConfig.ResourceSource.StringPtr), 646 AML_OFFSET (PinConfig.ResSourceOffset), 647 0}, 648 649 /* Vendor Data */ 650 651 {ACPI_RSC_COUNT_GPIO_VEN, ACPI_RS_OFFSET (Data.PinConfig.VendorLength), 652 AML_OFFSET (PinConfig.VendorLength), 653 1}, 654 655 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinConfig.VendorData), 656 AML_OFFSET (PinConfig.VendorOffset), 657 0}, 658 }; 659 660 /******************************************************************************* 661 * 662 * AcpiRsConvertPinGroup 663 * 664 ******************************************************************************/ 665 666 ACPI_RSCONVERT_INFO AcpiRsConvertPinGroup[10] = 667 { 668 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_PIN_GROUP, 669 ACPI_RS_SIZE (ACPI_RESOURCE_PIN_GROUP), 670 ACPI_RSC_TABLE_SIZE (AcpiRsConvertPinGroup)}, 671 672 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_PIN_GROUP, 673 sizeof (AML_RESOURCE_PIN_GROUP), 674 0}, 675 676 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinGroup.RevisionId), 677 AML_OFFSET (PinGroup.RevisionId), 678 1}, 679 680 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.PinGroup.ProducerConsumer), 681 AML_OFFSET (PinGroup.Flags), 682 0}, 683 684 /* Pin Table */ 685 686 /* 687 * It is OK to use GPIO operations here because none of them refer GPIO 688 * structures directly but instead use offsets given here. 689 */ 690 691 {ACPI_RSC_COUNT_GPIO_PIN, ACPI_RS_OFFSET (Data.PinGroup.PinTableLength), 692 AML_OFFSET (PinGroup.PinTableOffset), 693 AML_OFFSET (PinGroup.LabelOffset)}, 694 695 {ACPI_RSC_MOVE_GPIO_PIN, ACPI_RS_OFFSET (Data.PinGroup.PinTable), 696 AML_OFFSET (PinGroup.PinTableOffset), 697 0}, 698 699 /* Resource Label */ 700 701 {ACPI_RSC_COUNT_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroup.ResourceLabel.StringLength), 702 AML_OFFSET (PinGroup.LabelOffset), 703 AML_OFFSET (PinGroup.VendorOffset)}, 704 705 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroup.ResourceLabel.StringPtr), 706 AML_OFFSET (PinGroup.LabelOffset), 707 0}, 708 709 /* Vendor Data */ 710 711 {ACPI_RSC_COUNT_GPIO_VEN, ACPI_RS_OFFSET (Data.PinGroup.VendorLength), 712 AML_OFFSET (PinGroup.VendorLength), 713 1}, 714 715 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroup.VendorData), 716 AML_OFFSET (PinGroup.VendorOffset), 717 0}, 718 }; 719 720 /******************************************************************************* 721 * 722 * AcpiRsConvertPinGroupFunction 723 * 724 ******************************************************************************/ 725 726 ACPI_RSCONVERT_INFO AcpiRsConvertPinGroupFunction[13] = 727 { 728 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_PIN_GROUP_FUNCTION, 729 ACPI_RS_SIZE (ACPI_RESOURCE_PIN_GROUP_FUNCTION), 730 ACPI_RSC_TABLE_SIZE (AcpiRsConvertPinGroupFunction)}, 731 732 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_PIN_GROUP_FUNCTION, 733 sizeof (AML_RESOURCE_PIN_GROUP_FUNCTION), 734 0}, 735 736 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinGroupFunction.RevisionId), 737 AML_OFFSET (PinGroupFunction.RevisionId), 738 1}, 739 740 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.PinGroupFunction.Shareable), 741 AML_OFFSET (PinGroupFunction.Flags), 742 0}, 743 744 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.PinGroupFunction.ProducerConsumer), 745 AML_OFFSET (PinGroupFunction.Flags), 746 1}, 747 748 {ACPI_RSC_MOVE16, ACPI_RS_OFFSET (Data.PinGroupFunction.FunctionNumber), 749 AML_OFFSET (PinGroupFunction.FunctionNumber), 750 1}, 751 752 /* Resource Source */ 753 754 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinGroupFunction.ResourceSource.Index), 755 AML_OFFSET (PinGroupFunction.ResSourceIndex), 756 1}, 757 758 {ACPI_RSC_COUNT_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroupFunction.ResourceSource.StringLength), 759 AML_OFFSET (PinGroupFunction.ResSourceOffset), 760 AML_OFFSET (PinGroupFunction.ResSourceLabelOffset)}, 761 762 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroupFunction.ResourceSource.StringPtr), 763 AML_OFFSET (PinGroupFunction.ResSourceOffset), 764 0}, 765 766 /* Resource Source Label */ 767 768 {ACPI_RSC_COUNT_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroupFunction.ResourceSourceLabel.StringLength), 769 AML_OFFSET (PinGroupFunction.ResSourceLabelOffset), 770 AML_OFFSET (PinGroupFunction.VendorOffset)}, 771 772 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroupFunction.ResourceSourceLabel.StringPtr), 773 AML_OFFSET (PinGroupFunction.ResSourceLabelOffset), 774 0}, 775 776 /* Vendor Data */ 777 778 {ACPI_RSC_COUNT_GPIO_VEN, ACPI_RS_OFFSET (Data.PinGroupFunction.VendorLength), 779 AML_OFFSET (PinGroupFunction.VendorLength), 780 1}, 781 782 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroupFunction.VendorData), 783 AML_OFFSET (PinGroupFunction.VendorOffset), 784 0}, 785 }; 786 787 /******************************************************************************* 788 * 789 * AcpiRsConvertPinGroupConfig 790 * 791 ******************************************************************************/ 792 793 ACPI_RSCONVERT_INFO AcpiRsConvertPinGroupConfig[14] = 794 { 795 {ACPI_RSC_INITGET, ACPI_RESOURCE_TYPE_PIN_GROUP_CONFIG, 796 ACPI_RS_SIZE (ACPI_RESOURCE_PIN_GROUP_CONFIG), 797 ACPI_RSC_TABLE_SIZE (AcpiRsConvertPinGroupConfig)}, 798 799 {ACPI_RSC_INITSET, ACPI_RESOURCE_NAME_PIN_GROUP_CONFIG, 800 sizeof (AML_RESOURCE_PIN_GROUP_CONFIG), 801 0}, 802 803 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinGroupConfig.RevisionId), 804 AML_OFFSET (PinGroupConfig.RevisionId), 805 1}, 806 807 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.PinGroupConfig.Shareable), 808 AML_OFFSET (PinGroupConfig.Flags), 809 0}, 810 811 {ACPI_RSC_1BITFLAG, ACPI_RS_OFFSET (Data.PinGroupConfig.ProducerConsumer), 812 AML_OFFSET (PinGroupConfig.Flags), 813 1}, 814 815 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinGroupConfig.PinConfigType), 816 AML_OFFSET (PinGroupConfig.PinConfigType), 817 1}, 818 819 {ACPI_RSC_MOVE32, ACPI_RS_OFFSET (Data.PinGroupConfig.PinConfigValue), 820 AML_OFFSET (PinGroupConfig.PinConfigValue), 821 1}, 822 823 /* Resource Source */ 824 825 {ACPI_RSC_MOVE8, ACPI_RS_OFFSET (Data.PinGroupConfig.ResourceSource.Index), 826 AML_OFFSET (PinGroupConfig.ResSourceIndex), 827 1}, 828 829 {ACPI_RSC_COUNT_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroupConfig.ResourceSource.StringLength), 830 AML_OFFSET (PinGroupConfig.ResSourceOffset), 831 AML_OFFSET (PinGroupConfig.ResSourceLabelOffset)}, 832 833 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroupConfig.ResourceSource.StringPtr), 834 AML_OFFSET (PinGroupConfig.ResSourceOffset), 835 0}, 836 837 /* Resource Source Label */ 838 839 {ACPI_RSC_COUNT_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroupConfig.ResourceSourceLabel.StringLength), 840 AML_OFFSET (PinGroupConfig.ResSourceLabelOffset), 841 AML_OFFSET (PinGroupConfig.VendorOffset)}, 842 843 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroupConfig.ResourceSourceLabel.StringPtr), 844 AML_OFFSET (PinGroupConfig.ResSourceLabelOffset), 845 0}, 846 847 /* Vendor Data */ 848 849 {ACPI_RSC_COUNT_GPIO_VEN, ACPI_RS_OFFSET (Data.PinGroupConfig.VendorLength), 850 AML_OFFSET (PinGroupConfig.VendorLength), 851 1}, 852 853 {ACPI_RSC_MOVE_GPIO_RES, ACPI_RS_OFFSET (Data.PinGroupConfig.VendorData), 854 AML_OFFSET (PinGroupConfig.VendorOffset), 855 0}, 856 }; 857