aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pinctrl/sh-pfc/pfc-r8a7794.c
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2015-09-04 13:22:09 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2015-09-04 13:22:09 -0400
commit88a99886c26fec8bf662e7b6bc080431a8660326 (patch)
tree615b9a9a959ab093f6d8d0dd94d3bbc5299fc4c6 /drivers/pinctrl/sh-pfc/pfc-r8a7794.c
parent8d2faea672606827c2018143ec7d88c760f2d6de (diff)
parent1ab36387ea4face01aac3560b396b1e2ce07c4ff (diff)
Merge tag 'pinctrl-v4.3-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl
Pull pin control updates from Linus Walleij: "This is the bulk of pin control changes for the v4.3 development cycle. Like with GPIO it's a lot of stuff. If my subsystems are any sign of the overall tempo of the kernel v4.3 will be a gigantic diff. [ It looks like 4.3 is calmer than 4.2 in most other subsystems, but we'll see - Linus ] Core changes: - It is possible configure groups in debugfs. - Consolidation of chained IRQ handler install/remove replacing all call sites where irq_set_handler_data() and irq_set_chained_handler() were done in succession with a combined call to irq_set_chained_handler_and_data(). This series was created by Thomas Gleixner after the problem was observed by Russell King. - Tglx also made another series of patches switching __irq_set_handler_locked() for irq_set_handler_locked() which is way cleaner. - Tglx also wrote a good bunch of patches to make use of irq_desc_get_xxx() accessors and avoid looking up irq_descs from IRQ numbers. The goal is to get rid of the irq number from the handlers in the IRQ flow which is nice. Driver feature enhancements: - Power management support for the SiRF SoC Atlas 7. - Power down support for the Qualcomm driver. - Intel Cherryview and Baytrail: switch drivers to use raw spinlocks in IRQ handlers to play nice with the realtime patch set. - Rework and new modes handling for Qualcomm SPMI-MPP. - Pinconf power source config for SH PFC. New drivers and subdrivers: - A new driver for Conexant Digicolor CX92755. - A new driver for UniPhier PH1-LD4, PH1-Pro4, PH1-sLD8, PH1-Pro5, ProXtream2 and PH1-LD6b SoC pin control support. - Reverse-egineered the S/PDIF settings for the Allwinner sun4i driver. - Support for Qualcomm Technologies QDF2xxx ARM64 SoCs - A new Freescale i.mx6ul subdriver. Cleanup: - Remove platform data support in a number of SH PFC subdrivers" * tag 'pinctrl-v4.3-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl: (95 commits) pinctrl: at91: fix null pointer dereference pinctrl: mediatek: Implement wake handler and suspend resume pinctrl: mediatek: Fix multiple registration issue. pinctrl: sh-pfc: r8a7794: add USB pin groups pinctrl: at91: Use generic irq_{request,release}_resources() pinctrl: cherryview: Use raw_spinlock for locking pinctrl: baytrail: Use raw_spinlock for locking pinctrl: imx6ul: Remove .owner field pinctrl: zynq: Fix typos in smc0_nand_grp and smc0_nor_grp pinctrl: sh-pfc: Implement pinconf power-source param for voltage switching clk: rockchip: add pclk_pd_pmu to the list of rk3288 critical clocks pinctrl: sun4i: add spdif to pin description. pinctrl: atlas7: clear ugly branch statements for pull and drivestrength pinctrl: baytrail: Serialize all register access pinctrl: baytrail: Drop FSF mailing address pinctrl: rockchip: only enable gpio clock when it setting pinctrl/mediatek: fix spelling mistake in dev_err error message pinctrl: cherryview: Serialize all register access pinctrl: UniPhier: PH1-Pro5: add I2C ch6 pin-mux setting pinctrl: nomadik: reflect current input value ...
Diffstat (limited to 'drivers/pinctrl/sh-pfc/pfc-r8a7794.c')
-rw-r--r--drivers/pinctrl/sh-pfc/pfc-r8a7794.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/drivers/pinctrl/sh-pfc/pfc-r8a7794.c b/drivers/pinctrl/sh-pfc/pfc-r8a7794.c
index bfdcac4b3bc4..5248685dbb4e 100644
--- a/drivers/pinctrl/sh-pfc/pfc-r8a7794.c
+++ b/drivers/pinctrl/sh-pfc/pfc-r8a7794.c
@@ -2770,6 +2770,24 @@ static const unsigned int sdhi2_wp_pins[] = {
2770static const unsigned int sdhi2_wp_mux[] = { 2770static const unsigned int sdhi2_wp_mux[] = {
2771 SD2_WP_MARK, 2771 SD2_WP_MARK,
2772}; 2772};
2773/* - USB0 ------------------------------------------------------------------- */
2774static const unsigned int usb0_pins[] = {
2775 RCAR_GP_PIN(5, 24), /* PWEN */
2776 RCAR_GP_PIN(5, 25), /* OVC */
2777};
2778static const unsigned int usb0_mux[] = {
2779 USB0_PWEN_MARK,
2780 USB0_OVC_MARK,
2781};
2782/* - USB1 ------------------------------------------------------------------- */
2783static const unsigned int usb1_pins[] = {
2784 RCAR_GP_PIN(5, 26), /* PWEN */
2785 RCAR_GP_PIN(5, 27), /* OVC */
2786};
2787static const unsigned int usb1_mux[] = {
2788 USB1_PWEN_MARK,
2789 USB1_OVC_MARK,
2790};
2773 2791
2774static const struct sh_pfc_pin_group pinmux_groups[] = { 2792static const struct sh_pfc_pin_group pinmux_groups[] = {
2775 SH_PFC_PIN_GROUP(eth_link), 2793 SH_PFC_PIN_GROUP(eth_link),
@@ -2945,6 +2963,8 @@ static const struct sh_pfc_pin_group pinmux_groups[] = {
2945 SH_PFC_PIN_GROUP(sdhi2_ctrl), 2963 SH_PFC_PIN_GROUP(sdhi2_ctrl),
2946 SH_PFC_PIN_GROUP(sdhi2_cd), 2964 SH_PFC_PIN_GROUP(sdhi2_cd),
2947 SH_PFC_PIN_GROUP(sdhi2_wp), 2965 SH_PFC_PIN_GROUP(sdhi2_wp),
2966 SH_PFC_PIN_GROUP(usb0),
2967 SH_PFC_PIN_GROUP(usb1),
2948}; 2968};
2949 2969
2950static const char * const eth_groups[] = { 2970static const char * const eth_groups[] = {
@@ -3219,6 +3239,14 @@ static const char * const sdhi2_groups[] = {
3219 "sdhi2_wp", 3239 "sdhi2_wp",
3220}; 3240};
3221 3241
3242static const char * const usb0_groups[] = {
3243 "usb0",
3244};
3245
3246static const char * const usb1_groups[] = {
3247 "usb1",
3248};
3249
3222static const struct sh_pfc_function pinmux_functions[] = { 3250static const struct sh_pfc_function pinmux_functions[] = {
3223 SH_PFC_FUNCTION(eth), 3251 SH_PFC_FUNCTION(eth),
3224 SH_PFC_FUNCTION(hscif0), 3252 SH_PFC_FUNCTION(hscif0),
@@ -3253,6 +3281,8 @@ static const struct sh_pfc_function pinmux_functions[] = {
3253 SH_PFC_FUNCTION(sdhi0), 3281 SH_PFC_FUNCTION(sdhi0),
3254 SH_PFC_FUNCTION(sdhi1), 3282 SH_PFC_FUNCTION(sdhi1),
3255 SH_PFC_FUNCTION(sdhi2), 3283 SH_PFC_FUNCTION(sdhi2),
3284 SH_PFC_FUNCTION(usb0),
3285 SH_PFC_FUNCTION(usb1),
3256}; 3286};
3257 3287
3258static const struct pinmux_cfg_reg pinmux_config_regs[] = { 3288static const struct pinmux_cfg_reg pinmux_config_regs[] = {