Re: [PATCH v2 3/8] pinctrl: samsung: Add support for pad retention control for Exynos5433 SoCs
Hi Krzysztof, On 2017-01-27 19:02, Krzysztof Kozlowski wrote: On Thu, Jan 26, 2017 at 09:48:11PM +0200, Krzysztof Kozlowski wrote: On Thu, Jan 26, 2017 at 09:33:49AM +0100, Marek Szyprowski wrote: This patch adds support for retention control for Exynos5433 SoCs. Three groups of pins has been defined for retention control: common shared group for ALIVE, CPIF, eSE, FINGER, IMEM, NFC, PERIC, TOUCH pin banks and separate control for FSYS and AUD pin banks, for which PMU retention registers match whole banks. Signed-off-by: Marek Szyprowski--- drivers/pinctrl/samsung/pinctrl-exynos.c| 58 + include/linux/soc/samsung/exynos-regs-pmu.h | 16 I already have some non-conflicting changes to exynos-regs-pmu.h in my branch. Now I want to add some more which will create conflicts. How about splitting the header to separate patch, so I will take it to my exynos-pmu branch? Okay, I will split this into 2 patches. Best regards -- Marek Szyprowski, PhD Samsung R Institute Poland
Re: [PATCH v2 3/8] pinctrl: samsung: Add support for pad retention control for Exynos5433 SoCs
Hi Krzysztof, On 2017-01-27 19:02, Krzysztof Kozlowski wrote: On Thu, Jan 26, 2017 at 09:48:11PM +0200, Krzysztof Kozlowski wrote: On Thu, Jan 26, 2017 at 09:33:49AM +0100, Marek Szyprowski wrote: This patch adds support for retention control for Exynos5433 SoCs. Three groups of pins has been defined for retention control: common shared group for ALIVE, CPIF, eSE, FINGER, IMEM, NFC, PERIC, TOUCH pin banks and separate control for FSYS and AUD pin banks, for which PMU retention registers match whole banks. Signed-off-by: Marek Szyprowski --- drivers/pinctrl/samsung/pinctrl-exynos.c| 58 + include/linux/soc/samsung/exynos-regs-pmu.h | 16 I already have some non-conflicting changes to exynos-regs-pmu.h in my branch. Now I want to add some more which will create conflicts. How about splitting the header to separate patch, so I will take it to my exynos-pmu branch? Okay, I will split this into 2 patches. Best regards -- Marek Szyprowski, PhD Samsung R Institute Poland
Re: [PATCH v2 3/8] pinctrl: samsung: Add support for pad retention control for Exynos5433 SoCs
On Thu, Jan 26, 2017 at 09:48:11PM +0200, Krzysztof Kozlowski wrote: > On Thu, Jan 26, 2017 at 09:33:49AM +0100, Marek Szyprowski wrote: > > This patch adds support for retention control for Exynos5433 SoCs. Three > > groups of pins has been defined for retention control: common shared group > > for ALIVE, CPIF, eSE, FINGER, IMEM, NFC, PERIC, TOUCH pin banks and > > separate control for FSYS and AUD pin banks, for which PMU retention > > registers match whole banks. > > > > Signed-off-by: Marek Szyprowski> > --- > > drivers/pinctrl/samsung/pinctrl-exynos.c| 58 > > + > > include/linux/soc/samsung/exynos-regs-pmu.h | 16 I already have some non-conflicting changes to exynos-regs-pmu.h in my branch. Now I want to add some more which will create conflicts. How about splitting the header to separate patch, so I will take it to my exynos-pmu branch? Best regards, Krzysztof
Re: [PATCH v2 3/8] pinctrl: samsung: Add support for pad retention control for Exynos5433 SoCs
On Thu, Jan 26, 2017 at 09:48:11PM +0200, Krzysztof Kozlowski wrote: > On Thu, Jan 26, 2017 at 09:33:49AM +0100, Marek Szyprowski wrote: > > This patch adds support for retention control for Exynos5433 SoCs. Three > > groups of pins has been defined for retention control: common shared group > > for ALIVE, CPIF, eSE, FINGER, IMEM, NFC, PERIC, TOUCH pin banks and > > separate control for FSYS and AUD pin banks, for which PMU retention > > registers match whole banks. > > > > Signed-off-by: Marek Szyprowski > > --- > > drivers/pinctrl/samsung/pinctrl-exynos.c| 58 > > + > > include/linux/soc/samsung/exynos-regs-pmu.h | 16 I already have some non-conflicting changes to exynos-regs-pmu.h in my branch. Now I want to add some more which will create conflicts. How about splitting the header to separate patch, so I will take it to my exynos-pmu branch? Best regards, Krzysztof
Re: [PATCH v2 3/8] pinctrl: samsung: Add support for pad retention control for Exynos5433 SoCs
On Thu, Jan 26, 2017 at 09:33:49AM +0100, Marek Szyprowski wrote: > This patch adds support for retention control for Exynos5433 SoCs. Three > groups of pins has been defined for retention control: common shared group > for ALIVE, CPIF, eSE, FINGER, IMEM, NFC, PERIC, TOUCH pin banks and > separate control for FSYS and AUD pin banks, for which PMU retention > registers match whole banks. > > Signed-off-by: Marek Szyprowski> --- > drivers/pinctrl/samsung/pinctrl-exynos.c| 58 > + > include/linux/soc/samsung/exynos-regs-pmu.h | 16 > 2 files changed, 74 insertions(+) > Reviewed-by: Krzysztof Kozlowski Best regards, Krzysztof
Re: [PATCH v2 3/8] pinctrl: samsung: Add support for pad retention control for Exynos5433 SoCs
On Thu, Jan 26, 2017 at 09:33:49AM +0100, Marek Szyprowski wrote: > This patch adds support for retention control for Exynos5433 SoCs. Three > groups of pins has been defined for retention control: common shared group > for ALIVE, CPIF, eSE, FINGER, IMEM, NFC, PERIC, TOUCH pin banks and > separate control for FSYS and AUD pin banks, for which PMU retention > registers match whole banks. > > Signed-off-by: Marek Szyprowski > --- > drivers/pinctrl/samsung/pinctrl-exynos.c| 58 > + > include/linux/soc/samsung/exynos-regs-pmu.h | 16 > 2 files changed, 74 insertions(+) > Reviewed-by: Krzysztof Kozlowski Best regards, Krzysztof
Re: [PATCH v2 3/8] pinctrl: samsung: Add support for pad retention control for Exynos5433 SoCs
On Thu, Jan 26, 2017 at 09:33:49AM +0100, Marek Szyprowski wrote: > This patch adds support for retention control for Exynos5433 SoCs. Three > groups of pins has been defined for retention control: common shared group > for ALIVE, CPIF, eSE, FINGER, IMEM, NFC, PERIC, TOUCH pin banks and > separate control for FSYS and AUD pin banks, for which PMU retention > registers match whole banks. > > Signed-off-by: Marek Szyprowski> --- > drivers/pinctrl/samsung/pinctrl-exynos.c| 58 > + > include/linux/soc/samsung/exynos-regs-pmu.h | 16 > 2 files changed, 74 insertions(+) > .eint_gpio_init = exynos_eint_gpio_init, Reviewed-by: Krzysztof Kozlowski Best regards, Krzysztof
Re: [PATCH v2 3/8] pinctrl: samsung: Add support for pad retention control for Exynos5433 SoCs
On Thu, Jan 26, 2017 at 09:33:49AM +0100, Marek Szyprowski wrote: > This patch adds support for retention control for Exynos5433 SoCs. Three > groups of pins has been defined for retention control: common shared group > for ALIVE, CPIF, eSE, FINGER, IMEM, NFC, PERIC, TOUCH pin banks and > separate control for FSYS and AUD pin banks, for which PMU retention > registers match whole banks. > > Signed-off-by: Marek Szyprowski > --- > drivers/pinctrl/samsung/pinctrl-exynos.c| 58 > + > include/linux/soc/samsung/exynos-regs-pmu.h | 16 > 2 files changed, 74 insertions(+) > .eint_gpio_init = exynos_eint_gpio_init, Reviewed-by: Krzysztof Kozlowski Best regards, Krzysztof
[PATCH v2 3/8] pinctrl: samsung: Add support for pad retention control for Exynos5433 SoCs
This patch adds support for retention control for Exynos5433 SoCs. Three groups of pins has been defined for retention control: common shared group for ALIVE, CPIF, eSE, FINGER, IMEM, NFC, PERIC, TOUCH pin banks and separate control for FSYS and AUD pin banks, for which PMU retention registers match whole banks. Signed-off-by: Marek Szyprowski--- drivers/pinctrl/samsung/pinctrl-exynos.c| 58 + include/linux/soc/samsung/exynos-regs-pmu.h | 16 2 files changed, 74 insertions(+) diff --git a/drivers/pinctrl/samsung/pinctrl-exynos.c b/drivers/pinctrl/samsung/pinctrl-exynos.c index fa3802970570..7b0e6cc35e04 100644 --- a/drivers/pinctrl/samsung/pinctrl-exynos.c +++ b/drivers/pinctrl/samsung/pinctrl-exynos.c @@ -1551,6 +1551,54 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) EXYNOS5433_PIN_BANK_EINTG(3, 0x000, "gpj1", 0x00), }; +/* PMU pin retention groups registers for Exynos5433 (without audio & fsys) */ +static const u32 exynos5433_retention_regs[] = { + EXYNOS5433_PAD_RETENTION_TOP_OPTION, + EXYNOS5433_PAD_RETENTION_UART_OPTION, + EXYNOS5433_PAD_RETENTION_EBIA_OPTION, + EXYNOS5433_PAD_RETENTION_EBIB_OPTION, + EXYNOS5433_PAD_RETENTION_SPI_OPTION, + EXYNOS5433_PAD_RETENTION_MIF_OPTION, + EXYNOS5433_PAD_RETENTION_USBXTI_OPTION, + EXYNOS5433_PAD_RETENTION_BOOTLDO_OPTION, + EXYNOS5433_PAD_RETENTION_UFS_OPTION, + EXYNOS5433_PAD_RETENTION_FSYSGENIO_OPTION, +}; + +static const struct samsung_retention_data exynos5433_retention_data __initconst = { + .regs= exynos5433_retention_regs, + .nr_regs = ARRAY_SIZE(exynos5433_retention_regs), + .value = EXYNOS_WAKEUP_FROM_LOWPWR, + .refcnt = _shared_retention_refcnt, + .init= exynos_retention_init, +}; + +/* PMU retention control for audio pins can be tied to audio pin bank */ +static const u32 exynos5433_audio_retention_regs[] = { + EXYNOS5433_PAD_RETENTION_AUD_OPTION, +}; + +static const struct samsung_retention_data exynos5433_audio_retention_data __initconst = { + .regs= exynos5433_audio_retention_regs, + .nr_regs = ARRAY_SIZE(exynos5433_audio_retention_regs), + .value = EXYNOS_WAKEUP_FROM_LOWPWR, + .init= exynos_retention_init, +}; + +/* PMU retention control for mmc pins can be tied to fsys pin bank */ +static const u32 exynos5433_fsys_retention_regs[] = { + EXYNOS5433_PAD_RETENTION_MMC0_OPTION, + EXYNOS5433_PAD_RETENTION_MMC1_OPTION, + EXYNOS5433_PAD_RETENTION_MMC2_OPTION, +}; + +static const struct samsung_retention_data exynos5433_fsys_retention_data __initconst = { + .regs= exynos5433_fsys_retention_regs, + .nr_regs = ARRAY_SIZE(exynos5433_fsys_retention_regs), + .value = EXYNOS_WAKEUP_FROM_LOWPWR, + .init= exynos_retention_init, +}; + /* * Samsung pinctrl driver data for Exynos5433 SoC. Exynos5433 SoC includes * ten gpio/pin-mux/pinconfig controllers. @@ -1564,6 +1612,7 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) .suspend= exynos_pinctrl_suspend, .resume = exynos_pinctrl_resume, .nr_ext_resources = 1, + .retention_data = _retention_data, }, { /* pin-controller instance 1 data */ .pin_banks = exynos5433_pin_banks1, @@ -1571,6 +1620,7 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) .eint_gpio_init = exynos_eint_gpio_init, .suspend= exynos_pinctrl_suspend, .resume = exynos_pinctrl_resume, + .retention_data = _audio_retention_data, }, { /* pin-controller instance 2 data */ .pin_banks = exynos5433_pin_banks2, @@ -1578,6 +1628,7 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) .eint_gpio_init = exynos_eint_gpio_init, .suspend= exynos_pinctrl_suspend, .resume = exynos_pinctrl_resume, + .retention_data = _retention_data, }, { /* pin-controller instance 3 data */ .pin_banks = exynos5433_pin_banks3, @@ -1585,6 +1636,7 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) .eint_gpio_init = exynos_eint_gpio_init, .suspend= exynos_pinctrl_suspend, .resume = exynos_pinctrl_resume, + .retention_data = _retention_data, }, { /* pin-controller instance 4 data */ .pin_banks = exynos5433_pin_banks4, @@ -1592,6 +1644,7 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) .eint_gpio_init =
[PATCH v2 3/8] pinctrl: samsung: Add support for pad retention control for Exynos5433 SoCs
This patch adds support for retention control for Exynos5433 SoCs. Three groups of pins has been defined for retention control: common shared group for ALIVE, CPIF, eSE, FINGER, IMEM, NFC, PERIC, TOUCH pin banks and separate control for FSYS and AUD pin banks, for which PMU retention registers match whole banks. Signed-off-by: Marek Szyprowski --- drivers/pinctrl/samsung/pinctrl-exynos.c| 58 + include/linux/soc/samsung/exynos-regs-pmu.h | 16 2 files changed, 74 insertions(+) diff --git a/drivers/pinctrl/samsung/pinctrl-exynos.c b/drivers/pinctrl/samsung/pinctrl-exynos.c index fa3802970570..7b0e6cc35e04 100644 --- a/drivers/pinctrl/samsung/pinctrl-exynos.c +++ b/drivers/pinctrl/samsung/pinctrl-exynos.c @@ -1551,6 +1551,54 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) EXYNOS5433_PIN_BANK_EINTG(3, 0x000, "gpj1", 0x00), }; +/* PMU pin retention groups registers for Exynos5433 (without audio & fsys) */ +static const u32 exynos5433_retention_regs[] = { + EXYNOS5433_PAD_RETENTION_TOP_OPTION, + EXYNOS5433_PAD_RETENTION_UART_OPTION, + EXYNOS5433_PAD_RETENTION_EBIA_OPTION, + EXYNOS5433_PAD_RETENTION_EBIB_OPTION, + EXYNOS5433_PAD_RETENTION_SPI_OPTION, + EXYNOS5433_PAD_RETENTION_MIF_OPTION, + EXYNOS5433_PAD_RETENTION_USBXTI_OPTION, + EXYNOS5433_PAD_RETENTION_BOOTLDO_OPTION, + EXYNOS5433_PAD_RETENTION_UFS_OPTION, + EXYNOS5433_PAD_RETENTION_FSYSGENIO_OPTION, +}; + +static const struct samsung_retention_data exynos5433_retention_data __initconst = { + .regs= exynos5433_retention_regs, + .nr_regs = ARRAY_SIZE(exynos5433_retention_regs), + .value = EXYNOS_WAKEUP_FROM_LOWPWR, + .refcnt = _shared_retention_refcnt, + .init= exynos_retention_init, +}; + +/* PMU retention control for audio pins can be tied to audio pin bank */ +static const u32 exynos5433_audio_retention_regs[] = { + EXYNOS5433_PAD_RETENTION_AUD_OPTION, +}; + +static const struct samsung_retention_data exynos5433_audio_retention_data __initconst = { + .regs= exynos5433_audio_retention_regs, + .nr_regs = ARRAY_SIZE(exynos5433_audio_retention_regs), + .value = EXYNOS_WAKEUP_FROM_LOWPWR, + .init= exynos_retention_init, +}; + +/* PMU retention control for mmc pins can be tied to fsys pin bank */ +static const u32 exynos5433_fsys_retention_regs[] = { + EXYNOS5433_PAD_RETENTION_MMC0_OPTION, + EXYNOS5433_PAD_RETENTION_MMC1_OPTION, + EXYNOS5433_PAD_RETENTION_MMC2_OPTION, +}; + +static const struct samsung_retention_data exynos5433_fsys_retention_data __initconst = { + .regs= exynos5433_fsys_retention_regs, + .nr_regs = ARRAY_SIZE(exynos5433_fsys_retention_regs), + .value = EXYNOS_WAKEUP_FROM_LOWPWR, + .init= exynos_retention_init, +}; + /* * Samsung pinctrl driver data for Exynos5433 SoC. Exynos5433 SoC includes * ten gpio/pin-mux/pinconfig controllers. @@ -1564,6 +1612,7 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) .suspend= exynos_pinctrl_suspend, .resume = exynos_pinctrl_resume, .nr_ext_resources = 1, + .retention_data = _retention_data, }, { /* pin-controller instance 1 data */ .pin_banks = exynos5433_pin_banks1, @@ -1571,6 +1620,7 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) .eint_gpio_init = exynos_eint_gpio_init, .suspend= exynos_pinctrl_suspend, .resume = exynos_pinctrl_resume, + .retention_data = _audio_retention_data, }, { /* pin-controller instance 2 data */ .pin_banks = exynos5433_pin_banks2, @@ -1578,6 +1628,7 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) .eint_gpio_init = exynos_eint_gpio_init, .suspend= exynos_pinctrl_suspend, .resume = exynos_pinctrl_resume, + .retention_data = _retention_data, }, { /* pin-controller instance 3 data */ .pin_banks = exynos5433_pin_banks3, @@ -1585,6 +1636,7 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) .eint_gpio_init = exynos_eint_gpio_init, .suspend= exynos_pinctrl_suspend, .resume = exynos_pinctrl_resume, + .retention_data = _retention_data, }, { /* pin-controller instance 4 data */ .pin_banks = exynos5433_pin_banks4, @@ -1592,6 +1644,7 @@ static void exynos_retention_disable(struct samsung_pinctrl_drv_data *drvdata) .eint_gpio_init = exynos_eint_gpio_init,