| From faae9b03b7da87c425cbbf00e5d78f1ba613a8ca Mon Sep 17 00:00:00 2001 |
| From: Takeshi Kihara <takeshi.kihara.df@renesas.com> |
| Date: Wed, 16 Mar 2016 11:44:19 +0900 |
| Subject: [PATCH 096/299] pinctrl: sh-pfc: r8a7796: Add EtherAVB pins, groups |
| and functions |
| |
| This patch adds AVB_LINK, AVB_MAGIC, AVB_PHY_INT, AVB_MDC, AVB_AVTP_PPS, |
| AVB_AVTP_MATCH, AVB_AVTP_CAPTURE pins, groups and functions to R8A7796 |
| SoC. |
| |
| Signed-off-by: Takeshi Kihara <takeshi.kihara.df@renesas.com> |
| Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be> |
| (cherry picked from commit 9c99a63ec74f34f7afef6a475a89062caf14bd86) |
| Signed-off-by: Simon Horman <horms+renesas@verge.net.au> |
| --- |
| drivers/pinctrl/sh-pfc/pfc-r8a7796.c | 87 +++++++++++++++++++++++++++++++++++ |
| 1 file changed, 87 insertions(+) |
| |
| --- a/drivers/pinctrl/sh-pfc/pfc-r8a7796.c |
| +++ b/drivers/pinctrl/sh-pfc/pfc-r8a7796.c |
| @@ -1490,6 +1490,71 @@ static const struct sh_pfc_pin pinmux_pi |
| PINMUX_GPIO_GP_ALL(), |
| }; |
| |
| +/* - EtherAVB --------------------------------------------------------------- */ |
| +static const unsigned int avb_link_pins[] = { |
| + /* AVB_LINK */ |
| + RCAR_GP_PIN(2, 12), |
| +}; |
| +static const unsigned int avb_link_mux[] = { |
| + AVB_LINK_MARK, |
| +}; |
| +static const unsigned int avb_magic_pins[] = { |
| + /* AVB_MAGIC_ */ |
| + RCAR_GP_PIN(2, 10), |
| +}; |
| +static const unsigned int avb_magic_mux[] = { |
| + AVB_MAGIC_MARK, |
| +}; |
| +static const unsigned int avb_phy_int_pins[] = { |
| + /* AVB_PHY_INT */ |
| + RCAR_GP_PIN(2, 11), |
| +}; |
| +static const unsigned int avb_phy_int_mux[] = { |
| + AVB_PHY_INT_MARK, |
| +}; |
| +static const unsigned int avb_mdc_pins[] = { |
| + /* AVB_MDC */ |
| + RCAR_GP_PIN(2, 9), |
| +}; |
| +static const unsigned int avb_mdc_mux[] = { |
| + AVB_MDC_MARK, |
| +}; |
| +static const unsigned int avb_avtp_pps_pins[] = { |
| + /* AVB_AVTP_PPS */ |
| + RCAR_GP_PIN(2, 6), |
| +}; |
| +static const unsigned int avb_avtp_pps_mux[] = { |
| + AVB_AVTP_PPS_MARK, |
| +}; |
| +static const unsigned int avb_avtp_match_a_pins[] = { |
| + /* AVB_AVTP_MATCH_A */ |
| + RCAR_GP_PIN(2, 13), |
| +}; |
| +static const unsigned int avb_avtp_match_a_mux[] = { |
| + AVB_AVTP_MATCH_A_MARK, |
| +}; |
| +static const unsigned int avb_avtp_capture_a_pins[] = { |
| + /* AVB_AVTP_CAPTURE_A */ |
| + RCAR_GP_PIN(2, 14), |
| +}; |
| +static const unsigned int avb_avtp_capture_a_mux[] = { |
| + AVB_AVTP_CAPTURE_A_MARK, |
| +}; |
| +static const unsigned int avb_avtp_match_b_pins[] = { |
| + /* AVB_AVTP_MATCH_B */ |
| + RCAR_GP_PIN(1, 8), |
| +}; |
| +static const unsigned int avb_avtp_match_b_mux[] = { |
| + AVB_AVTP_MATCH_B_MARK, |
| +}; |
| +static const unsigned int avb_avtp_capture_b_pins[] = { |
| + /* AVB_AVTP_CAPTURE_B */ |
| + RCAR_GP_PIN(1, 11), |
| +}; |
| +static const unsigned int avb_avtp_capture_b_mux[] = { |
| + AVB_AVTP_CAPTURE_B_MARK, |
| +}; |
| + |
| /* - DRIF0 --------------------------------------------------------------- */ |
| static const unsigned int drif0_ctrl_a_pins[] = { |
| /* CLK, SYNC */ |
| @@ -2178,6 +2243,15 @@ static const unsigned int sdhi3_ds_mux[] |
| }; |
| |
| static const struct sh_pfc_pin_group pinmux_groups[] = { |
| + SH_PFC_PIN_GROUP(avb_link), |
| + SH_PFC_PIN_GROUP(avb_magic), |
| + SH_PFC_PIN_GROUP(avb_phy_int), |
| + SH_PFC_PIN_GROUP(avb_mdc), |
| + SH_PFC_PIN_GROUP(avb_avtp_pps), |
| + SH_PFC_PIN_GROUP(avb_avtp_match_a), |
| + SH_PFC_PIN_GROUP(avb_avtp_capture_a), |
| + SH_PFC_PIN_GROUP(avb_avtp_match_b), |
| + SH_PFC_PIN_GROUP(avb_avtp_capture_b), |
| SH_PFC_PIN_GROUP(drif0_ctrl_a), |
| SH_PFC_PIN_GROUP(drif0_data0_a), |
| SH_PFC_PIN_GROUP(drif0_data1_a), |
| @@ -2272,6 +2346,18 @@ static const struct sh_pfc_pin_group pin |
| SH_PFC_PIN_GROUP(sdhi3_ds), |
| }; |
| |
| +static const char * const avb_groups[] = { |
| + "avb_link", |
| + "avb_magic", |
| + "avb_phy_int", |
| + "avb_mdc", |
| + "avb_avtp_pps", |
| + "avb_avtp_match_a", |
| + "avb_avtp_capture_a", |
| + "avb_avtp_match_b", |
| + "avb_avtp_capture_b", |
| +}; |
| + |
| static const char * const drif0_groups[] = { |
| "drif0_ctrl_a", |
| "drif0_data0_a", |
| @@ -2419,6 +2505,7 @@ static const char * const sdhi3_groups[] |
| }; |
| |
| static const struct sh_pfc_function pinmux_functions[] = { |
| + SH_PFC_FUNCTION(avb), |
| SH_PFC_FUNCTION(drif0), |
| SH_PFC_FUNCTION(drif1), |
| SH_PFC_FUNCTION(drif2), |