aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKatsuhiro Suzuki <suzuki.katsuhiro@socionext.com>2018-04-26 21:49:04 -0400
committerLinus Walleij <linus.walleij@linaro.org>2018-05-02 08:36:31 -0400
commite8349221a0487353bce30116593bfa116595b5b5 (patch)
treea08554aebe5728679e8e9f4d3798bb3534da194f
parentea813dce6771ef3b56702fc14ac7595aa89ae404 (diff)
pinctrl: uniphier: add LD20 MPEG2-TS I/O pin-mux settings
The MPEG2-TS input/output core both accepts serial TS and parallel TS. The serial TS interface uses following pins: hscin0_s : HS0DOUT[0-3] hscin1_s : HS0DOUT[4-7] hscin2_s : HS1BCLKIN, HS1SYNCIN, HS1VALIN, HS1DIN0 hscin3_s : HS1DIN[2-5] hscout0_s: HS0DOUT[0-3] hscout1_s: HS0DOUT[4-7] And the parallel TS interface uses following pins: hscin0_p : HS0BCLKIN, HS0SYNCIN, HS0VALIN, HS0DIN[0-7] hscin1_p : HS1BCLKIN, HS1SYNCIN, HS1VALIN, HS1DIN[0-7] hscout0_p: HS0BCLKOUT, HS0SYNCOUT, HS0VALOUT, HS0DOUT[0-7] Signed-off-by: Katsuhiro Suzuki <suzuki.katsuhiro@socionext.com> Acked-by: Masahiro Yamada <yamada.masahiro@socionext.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
-rw-r--r--drivers/pinctrl/uniphier/pinctrl-uniphier-ld20.c54
1 files changed, 54 insertions, 0 deletions
diff --git a/drivers/pinctrl/uniphier/pinctrl-uniphier-ld20.c b/drivers/pinctrl/uniphier/pinctrl-uniphier-ld20.c
index bf8f0c3bea5e..9f449b35e300 100644
--- a/drivers/pinctrl/uniphier/pinctrl-uniphier-ld20.c
+++ b/drivers/pinctrl/uniphier/pinctrl-uniphier-ld20.c
@@ -566,6 +566,33 @@ static const int ether_rgmii_muxvals[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
566static const unsigned ether_rmii_pins[] = {30, 31, 32, 33, 34, 35, 36, 37, 39, 566static const unsigned ether_rmii_pins[] = {30, 31, 32, 33, 34, 35, 36, 37, 39,
567 41, 42, 45}; 567 41, 42, 45};
568static const int ether_rmii_muxvals[] = {0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1}; 568static const int ether_rmii_muxvals[] = {0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1};
569static const unsigned hscin0_ci_pins[] = {102, 103, 104, 105, 106, 107, 108,
570 109, 110, 111, 112};
571static const int hscin0_ci_muxvals[] = {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1};
572static const unsigned hscin0_p_pins[] = {102, 103, 104, 105, 106, 107, 108, 109,
573 110, 111, 112};
574static const int hscin0_p_muxvals[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
575static const unsigned hscin0_s_pins[] = {116, 117, 118, 119};
576static const int hscin0_s_muxvals[] = {3, 3, 3, 3};
577static const unsigned hscin1_p_pins[] = {124, 125, 126, 127, 128, 129, 130, 131,
578 132, 133, 134};
579static const int hscin1_p_muxvals[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
580static const unsigned hscin1_s_pins[] = {120, 121, 122, 123};
581static const int hscin1_s_muxvals[] = {3, 3, 3, 3};
582static const unsigned hscin2_s_pins[] = {124, 125, 126, 127};
583static const int hscin2_s_muxvals[] = {3, 3, 3, 3};
584static const unsigned hscin3_s_pins[] = {129, 130, 131, 132};
585static const int hscin3_s_muxvals[] = {3, 3, 3, 3};
586static const unsigned hscout0_ci_pins[] = {113, 114, 115, 116, 117, 118, 119,
587 120, 121, 122, 123};
588static const int hscout0_ci_muxvals[] = {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1};
589static const unsigned hscout0_p_pins[] = {113, 114, 115, 116, 117, 118, 119,
590 120, 121, 122, 123};
591static const int hscout0_p_muxvals[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
592static const unsigned hscout0_s_pins[] = {116, 117, 118, 119};
593static const int hscout0_s_muxvals[] = {4, 4, 4, 4};
594static const unsigned hscout1_s_pins[] = {120, 121, 122, 123};
595static const int hscout1_s_muxvals[] = {4, 4, 4, 4};
569static const unsigned i2c0_pins[] = {63, 64}; 596static const unsigned i2c0_pins[] = {63, 64};
570static const int i2c0_muxvals[] = {0, 0}; 597static const int i2c0_muxvals[] = {0, 0};
571static const unsigned i2c1_pins[] = {65, 66}; 598static const unsigned i2c1_pins[] = {65, 66};
@@ -641,6 +668,17 @@ static const struct uniphier_pinctrl_group uniphier_ld20_groups[] = {
641 UNIPHIER_PINCTRL_GROUP(emmc_dat8), 668 UNIPHIER_PINCTRL_GROUP(emmc_dat8),
642 UNIPHIER_PINCTRL_GROUP(ether_rgmii), 669 UNIPHIER_PINCTRL_GROUP(ether_rgmii),
643 UNIPHIER_PINCTRL_GROUP(ether_rmii), 670 UNIPHIER_PINCTRL_GROUP(ether_rmii),
671 UNIPHIER_PINCTRL_GROUP(hscin0_ci),
672 UNIPHIER_PINCTRL_GROUP(hscin0_p),
673 UNIPHIER_PINCTRL_GROUP(hscin0_s),
674 UNIPHIER_PINCTRL_GROUP(hscin1_p),
675 UNIPHIER_PINCTRL_GROUP(hscin1_s),
676 UNIPHIER_PINCTRL_GROUP(hscin2_s),
677 UNIPHIER_PINCTRL_GROUP(hscin3_s),
678 UNIPHIER_PINCTRL_GROUP(hscout0_ci),
679 UNIPHIER_PINCTRL_GROUP(hscout0_p),
680 UNIPHIER_PINCTRL_GROUP(hscout0_s),
681 UNIPHIER_PINCTRL_GROUP(hscout1_s),
644 UNIPHIER_PINCTRL_GROUP(i2c0), 682 UNIPHIER_PINCTRL_GROUP(i2c0),
645 UNIPHIER_PINCTRL_GROUP(i2c1), 683 UNIPHIER_PINCTRL_GROUP(i2c1),
646 UNIPHIER_PINCTRL_GROUP(i2c3), 684 UNIPHIER_PINCTRL_GROUP(i2c3),
@@ -668,6 +706,16 @@ static const char * const aoutiec1_groups[] = {"aoutiec1"};
668static const char * const emmc_groups[] = {"emmc", "emmc_dat8"}; 706static const char * const emmc_groups[] = {"emmc", "emmc_dat8"};
669static const char * const ether_rgmii_groups[] = {"ether_rgmii"}; 707static const char * const ether_rgmii_groups[] = {"ether_rgmii"};
670static const char * const ether_rmii_groups[] = {"ether_rmii"}; 708static const char * const ether_rmii_groups[] = {"ether_rmii"};
709static const char * const hscin0_groups[] = {"hscin0_ci",
710 "hscin0_p",
711 "hscin0_s"};
712static const char * const hscin1_groups[] = {"hscin1_p", "hscin1_s"};
713static const char * const hscin2_groups[] = {"hscin2_s"};
714static const char * const hscin3_groups[] = {"hscin3_s"};
715static const char * const hscout0_groups[] = {"hscout0_ci",
716 "hscout0_p",
717 "hscout0_s"};
718static const char * const hscout1_groups[] = {"hscout1_s"};
671static const char * const i2c0_groups[] = {"i2c0"}; 719static const char * const i2c0_groups[] = {"i2c0"};
672static const char * const i2c1_groups[] = {"i2c1"}; 720static const char * const i2c1_groups[] = {"i2c1"};
673static const char * const i2c3_groups[] = {"i2c3"}; 721static const char * const i2c3_groups[] = {"i2c3"};
@@ -691,6 +739,12 @@ static const struct uniphier_pinmux_function uniphier_ld20_functions[] = {
691 UNIPHIER_PINMUX_FUNCTION(emmc), 739 UNIPHIER_PINMUX_FUNCTION(emmc),
692 UNIPHIER_PINMUX_FUNCTION(ether_rgmii), 740 UNIPHIER_PINMUX_FUNCTION(ether_rgmii),
693 UNIPHIER_PINMUX_FUNCTION(ether_rmii), 741 UNIPHIER_PINMUX_FUNCTION(ether_rmii),
742 UNIPHIER_PINMUX_FUNCTION(hscin0),
743 UNIPHIER_PINMUX_FUNCTION(hscin1),
744 UNIPHIER_PINMUX_FUNCTION(hscin2),
745 UNIPHIER_PINMUX_FUNCTION(hscin3),
746 UNIPHIER_PINMUX_FUNCTION(hscout0),
747 UNIPHIER_PINMUX_FUNCTION(hscout1),
694 UNIPHIER_PINMUX_FUNCTION(i2c0), 748 UNIPHIER_PINMUX_FUNCTION(i2c0),
695 UNIPHIER_PINMUX_FUNCTION(i2c1), 749 UNIPHIER_PINMUX_FUNCTION(i2c1),
696 UNIPHIER_PINMUX_FUNCTION(i2c3), 750 UNIPHIER_PINMUX_FUNCTION(i2c3),