diff options
author | Katsuhiro Suzuki <suzuki.katsuhiro@socionext.com> | 2018-04-26 21:49:04 -0400 |
---|---|---|
committer | Linus Walleij <linus.walleij@linaro.org> | 2018-05-02 08:36:31 -0400 |
commit | e8349221a0487353bce30116593bfa116595b5b5 (patch) | |
tree | a08554aebe5728679e8e9f4d3798bb3534da194f | |
parent | ea813dce6771ef3b56702fc14ac7595aa89ae404 (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.c | 54 |
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, | |||
566 | static const unsigned ether_rmii_pins[] = {30, 31, 32, 33, 34, 35, 36, 37, 39, | 566 | static const unsigned ether_rmii_pins[] = {30, 31, 32, 33, 34, 35, 36, 37, 39, |
567 | 41, 42, 45}; | 567 | 41, 42, 45}; |
568 | static const int ether_rmii_muxvals[] = {0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1}; | 568 | static const int ether_rmii_muxvals[] = {0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1}; |
569 | static const unsigned hscin0_ci_pins[] = {102, 103, 104, 105, 106, 107, 108, | ||
570 | 109, 110, 111, 112}; | ||
571 | static const int hscin0_ci_muxvals[] = {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}; | ||
572 | static const unsigned hscin0_p_pins[] = {102, 103, 104, 105, 106, 107, 108, 109, | ||
573 | 110, 111, 112}; | ||
574 | static const int hscin0_p_muxvals[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; | ||
575 | static const unsigned hscin0_s_pins[] = {116, 117, 118, 119}; | ||
576 | static const int hscin0_s_muxvals[] = {3, 3, 3, 3}; | ||
577 | static const unsigned hscin1_p_pins[] = {124, 125, 126, 127, 128, 129, 130, 131, | ||
578 | 132, 133, 134}; | ||
579 | static const int hscin1_p_muxvals[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; | ||
580 | static const unsigned hscin1_s_pins[] = {120, 121, 122, 123}; | ||
581 | static const int hscin1_s_muxvals[] = {3, 3, 3, 3}; | ||
582 | static const unsigned hscin2_s_pins[] = {124, 125, 126, 127}; | ||
583 | static const int hscin2_s_muxvals[] = {3, 3, 3, 3}; | ||
584 | static const unsigned hscin3_s_pins[] = {129, 130, 131, 132}; | ||
585 | static const int hscin3_s_muxvals[] = {3, 3, 3, 3}; | ||
586 | static const unsigned hscout0_ci_pins[] = {113, 114, 115, 116, 117, 118, 119, | ||
587 | 120, 121, 122, 123}; | ||
588 | static const int hscout0_ci_muxvals[] = {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}; | ||
589 | static const unsigned hscout0_p_pins[] = {113, 114, 115, 116, 117, 118, 119, | ||
590 | 120, 121, 122, 123}; | ||
591 | static const int hscout0_p_muxvals[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; | ||
592 | static const unsigned hscout0_s_pins[] = {116, 117, 118, 119}; | ||
593 | static const int hscout0_s_muxvals[] = {4, 4, 4, 4}; | ||
594 | static const unsigned hscout1_s_pins[] = {120, 121, 122, 123}; | ||
595 | static const int hscout1_s_muxvals[] = {4, 4, 4, 4}; | ||
569 | static const unsigned i2c0_pins[] = {63, 64}; | 596 | static const unsigned i2c0_pins[] = {63, 64}; |
570 | static const int i2c0_muxvals[] = {0, 0}; | 597 | static const int i2c0_muxvals[] = {0, 0}; |
571 | static const unsigned i2c1_pins[] = {65, 66}; | 598 | static 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"}; | |||
668 | static const char * const emmc_groups[] = {"emmc", "emmc_dat8"}; | 706 | static const char * const emmc_groups[] = {"emmc", "emmc_dat8"}; |
669 | static const char * const ether_rgmii_groups[] = {"ether_rgmii"}; | 707 | static const char * const ether_rgmii_groups[] = {"ether_rgmii"}; |
670 | static const char * const ether_rmii_groups[] = {"ether_rmii"}; | 708 | static const char * const ether_rmii_groups[] = {"ether_rmii"}; |
709 | static const char * const hscin0_groups[] = {"hscin0_ci", | ||
710 | "hscin0_p", | ||
711 | "hscin0_s"}; | ||
712 | static const char * const hscin1_groups[] = {"hscin1_p", "hscin1_s"}; | ||
713 | static const char * const hscin2_groups[] = {"hscin2_s"}; | ||
714 | static const char * const hscin3_groups[] = {"hscin3_s"}; | ||
715 | static const char * const hscout0_groups[] = {"hscout0_ci", | ||
716 | "hscout0_p", | ||
717 | "hscout0_s"}; | ||
718 | static const char * const hscout1_groups[] = {"hscout1_s"}; | ||
671 | static const char * const i2c0_groups[] = {"i2c0"}; | 719 | static const char * const i2c0_groups[] = {"i2c0"}; |
672 | static const char * const i2c1_groups[] = {"i2c1"}; | 720 | static const char * const i2c1_groups[] = {"i2c1"}; |
673 | static const char * const i2c3_groups[] = {"i2c3"}; | 721 | static 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), |