mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
49 lines
1.5 KiB
Plaintext
49 lines
1.5 KiB
Plaintext
|
GPIO controller on CE4100 / Sodaville SoCs
|
||
|
==========================================
|
||
|
|
||
|
The bindings for CE4100's GPIO controller match the generic description
|
||
|
which is covered by the gpio.txt file in this folder.
|
||
|
|
||
|
The only additional property is the intel,muxctl property which holds the
|
||
|
value which is written into the MUXCNTL register.
|
||
|
|
||
|
There is no compatible property for now because the driver is probed via
|
||
|
PCI id (vendor 0x8086 device 0x2e67).
|
||
|
|
||
|
The interrupt specifier consists of two cells encoded as follows:
|
||
|
- <1st cell>: The interrupt-number that identifies the interrupt source.
|
||
|
- <2nd cell>: The level-sense information, encoded as follows:
|
||
|
4 - active high level-sensitive
|
||
|
8 - active low level-sensitive
|
||
|
|
||
|
Example of the GPIO device and one user:
|
||
|
|
||
|
pcigpio: gpio@b,1 {
|
||
|
/* two cells for GPIO and interrupt */
|
||
|
#gpio-cells = <2>;
|
||
|
#interrupt-cells = <2>;
|
||
|
compatible = "pci8086,2e67.2",
|
||
|
"pci8086,2e67",
|
||
|
"pciclassff0000",
|
||
|
"pciclassff00";
|
||
|
|
||
|
reg = <0x15900 0x0 0x0 0x0 0x0>;
|
||
|
/* Interrupt line of the gpio device */
|
||
|
interrupts = <15 1>;
|
||
|
/* It is an interrupt and GPIO controller itself */
|
||
|
interrupt-controller;
|
||
|
gpio-controller;
|
||
|
intel,muxctl = <0>;
|
||
|
};
|
||
|
|
||
|
testuser@20 {
|
||
|
compatible = "example,testuser";
|
||
|
/* User the 11th GPIO line as an active high triggered
|
||
|
* level interrupt
|
||
|
*/
|
||
|
interrupts = <11 8>;
|
||
|
interrupt-parent = <&pcigpio>;
|
||
|
/* Use this GPIO also with the gpio functions */
|
||
|
gpios = <&pcigpio 11 0>;
|
||
|
};
|