forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge tag 'pinctrl-for-v3.6' of git://git.kernel.org/pub/scm/linux/ke…
…rnel/git/linusw/linux-pinctrl Pull pin control changes from Linus Walleij: "These are the accumulated pin control patches for v3.6: - Various cleanups to the U300 driver - Refactor the pin control core to automatically remove any GPIO ranges when the drivers are removed, instead of having the drivers do this explicitly. - Add a function for registering a batch of GPIO ranges. - Fix a number of incorrect but non-regressive error checks. - Incremental improvements to the COH901, i.MX and Nomadik drivers - Add a one-register-per-pin entirely Device Tree-based pin control driver from Tony Lindgren." * tag 'pinctrl-for-v3.6' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl: pinctrl: Add one-register-per-pin type device tree based pinctrl driver pinctrl/nomadik: add spi2_oc1_2 pin group pinctrl/nomadik: kerneldoc fix pinctrl/nomadik: use devm_* allocators for gpio probe pinctrl/nomadik: add pin group to mco function pinctrl/nomadik: add hsit_a_2 pin group pinctrl/nomadik: add pin group smcs1 and smps0 pinctrl/nomadik: fix hsir_a_1_pins pin list pinctrl: pinctrl-imx: fix map setting problem if NO_PAD_CTL is set pinctrl/coh901: use clk_prepare_[en|dis]able() pinctrl/pinctrl-tegra: remove IS_ERR checking of pmx->pctl pinctrl/pinctrl-spear: remove IS_ERR checking of pmx->pctl pinctrl/u300: drop unused variable pinctrl: select the proper symbol pinctrl: add pinctrl_add_gpio_ranges function pinctrl: remove pinctrl_remove_gpio_range pinctrl/pinctrl-core: cleanup pinctrl_register pinctrl/u300: delete pointless debug print pinctrl/pinctrl-u300: remove devm_kfree at driver unload
- Loading branch information
Showing
13 changed files
with
1,160 additions
and
81 deletions.
There are no files selected for viewing
93 changes: 93 additions & 0 deletions
93
Documentation/devicetree/bindings/pinctrl/pinctrl-single.txt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
One-register-per-pin type device tree based pinctrl driver | ||
|
||
Required properties: | ||
- compatible : "pinctrl-single" | ||
|
||
- reg : offset and length of the register set for the mux registers | ||
|
||
- pinctrl-single,register-width : pinmux register access width in bits | ||
|
||
- pinctrl-single,function-mask : mask of allowed pinmux function bits | ||
in the pinmux register | ||
|
||
Optional properties: | ||
- pinctrl-single,function-off : function off mode for disabled state if | ||
available and same for all registers; if not specified, disabling of | ||
pin functions is ignored | ||
|
||
This driver assumes that there is only one register for each pin, | ||
and uses the common pinctrl bindings as specified in the pinctrl-bindings.txt | ||
document in this directory. | ||
|
||
The pin configuration nodes for pinctrl-single are specified as pinctrl | ||
register offset and value pairs using pinctrl-single,pins. Only the bits | ||
specified in pinctrl-single,function-mask are updated. For example, setting | ||
a pin for a device could be done with: | ||
|
||
pinctrl-single,pins = <0xdc 0x118>; | ||
|
||
Where 0xdc is the offset from the pinctrl register base address for the | ||
device pinctrl register, and 0x118 contains the desired value of the | ||
pinctrl register. See the device example and static board pins example | ||
below for more information. | ||
|
||
Example: | ||
|
||
/* SoC common file */ | ||
|
||
/* first controller instance for pins in core domain */ | ||
pmx_core: pinmux@4a100040 { | ||
compatible = "pinctrl-single"; | ||
reg = <0x4a100040 0x0196>; | ||
#address-cells = <1>; | ||
#size-cells = <0>; | ||
pinctrl-single,register-width = <16>; | ||
pinctrl-single,function-mask = <0xffff>; | ||
}; | ||
|
||
/* second controller instance for pins in wkup domain */ | ||
pmx_wkup: pinmux@4a31e040 { | ||
compatible = "pinctrl-single; | ||
reg = <0x4a31e040 0x0038>; | ||
#address-cells = <1>; | ||
#size-cells = <0>; | ||
pinctrl-single,register-width = <16>; | ||
pinctrl-single,function-mask = <0xffff>; | ||
}; | ||
|
||
|
||
/* board specific .dts file */ | ||
|
||
&pmx_core { | ||
|
||
/* | ||
* map all board specific static pins enabled by the pinctrl driver | ||
* itself during the boot (or just set them up in the bootloader) | ||
*/ | ||
pinctrl-names = "default"; | ||
pinctrl-0 = <&board_pins>; | ||
|
||
board_pins: pinmux_board_pins { | ||
pinctrl-single,pins = < | ||
0x6c 0xf | ||
0x6e 0xf | ||
0x70 0xf | ||
0x72 0xf | ||
>; | ||
}; | ||
|
||
/* map uart2 pins */ | ||
uart2_pins: pinmux_uart2_pins { | ||
pinctrl-single,pins = < | ||
0xd8 0x118 | ||
0xda 0 | ||
0xdc 0x118 | ||
0xde 0 | ||
>; | ||
}; | ||
}; | ||
|
||
&uart2 { | ||
pinctrl-names = "default"; | ||
pinctrl-0 = <&uart2_pins>; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.