* Re: [PATCH] spi: pxa2xx: Only claim CS GPIOs when the slave device is created
[not found] ` <90b3e14d-0077-9a25-9d90-ab340577af57-S0/GAf8tV78@public.gmane.org>
@ 2017-07-08 21:48 ` Andy Shevchenko
2017-07-09 9:30 ` Jan Kiszka
[not found] ` <CAHp75Vd8GRCwGp8eDFOL=dsgxCR+VqqUy+O50PEW=p99a8xAwQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2017-07-17 16:07 ` Applied "spi: pxa2xx: Only claim CS GPIOs when the slave device is created" to the spi tree Mark Brown
` (2 subsequent siblings)
3 siblings, 2 replies; 16+ messages in thread
From: Andy Shevchenko @ 2017-07-08 21:48 UTC (permalink / raw)
To: Jan Kiszka
Cc: Daniel Mack, Haojian Zhuang, Robert Jarzmik, Mark Brown,
linux-spi, Linux Kernel Mailing List, linux-arm-kernel
On Sat, Jul 8, 2017 at 11:41 AM, Jan Kiszka <jan.kiszka-S0/GAf8tV78@public.gmane.org> wrote:
> From: Jan Kiszka <jan.kiszka-kv7WeFo6aLtBDgjK7y7TUQ@public.gmane.org>
>
> Avoid hogging chip select GPIOs just because they are listed for the
> master. They might be mulitplexed and, if no slave device is attached,
> used for different purposes. Moreover, this strategy avoids having to
> allocate a cs_gpiods structure.
>
> Tested on the IOT2000 where the second SPI bus is connected to an
> Arduino-compatible connector and multiplexed between SPI, GPIO and PWM
> usage.
Can we first switch the driver to use GPIO descriptors instead of
plain integers?
>
> Signed-off-by: Jan Kiszka <jan.kiszka-kv7WeFo6aLtBDgjK7y7TUQ@public.gmane.org>
> ---
> drivers/spi/spi-pxa2xx.c | 59 +++++++++++++++++-------------------------------
> 1 file changed, 21 insertions(+), 38 deletions(-)
>
> diff --git a/drivers/spi/spi-pxa2xx.c b/drivers/spi/spi-pxa2xx.c
> index 38d053682892..be991266a6ce 100644
> --- a/drivers/spi/spi-pxa2xx.c
> +++ b/drivers/spi/spi-pxa2xx.c
> @@ -1213,21 +1213,33 @@ static int setup_cs(struct spi_device *spi, struct chip_data *chip,
> struct pxa2xx_spi_chip *chip_info)
> {
> struct driver_data *drv_data = spi_master_get_devdata(spi->master);
> + struct device *pdev = &drv_data->pdev->dev;
> + struct gpio_desc *gpiod;
> int err = 0;
> + int count;
>
> if (chip == NULL)
> return 0;
>
> - if (drv_data->cs_gpiods) {
> - struct gpio_desc *gpiod;
> + count = gpiod_count(pdev, "cs");
> + if (count > 0) {
> + if (spi->chip_select >= count)
> + return -EINVAL;
> +
> + gpiod = gpiod_get_index(pdev, "cs", spi->chip_select,
> + GPIOD_OUT_HIGH);
> + if (IS_ERR(gpiod)) {
> + /* Means use native chip select */
> + if (PTR_ERR(gpiod) == -ENOENT)
> + return 0;
>
> - gpiod = drv_data->cs_gpiods[spi->chip_select];
> - if (gpiod) {
> - chip->gpio_cs = desc_to_gpio(gpiod);
> - chip->gpio_cs_inverted = spi->mode & SPI_CS_HIGH;
> - gpiod_set_value(gpiod, chip->gpio_cs_inverted);
> + return PTR_ERR(gpiod);
> }
>
> + chip->gpio_cs = desc_to_gpio(gpiod);
> + chip->gpio_cs_inverted = spi->mode & SPI_CS_HIGH;
> + gpiod_set_value(gpiod, chip->gpio_cs_inverted);
> +
> return 0;
> }
>
> @@ -1415,8 +1427,7 @@ static void cleanup(struct spi_device *spi)
> if (!chip)
> return;
>
> - if (drv_data->ssp_type != CE4100_SSP && !drv_data->cs_gpiods &&
> - gpio_is_valid(chip->gpio_cs))
> + if (drv_data->ssp_type != CE4100_SSP && gpio_is_valid(chip->gpio_cs))
> gpio_free(chip->gpio_cs);
>
> kfree(chip);
> @@ -1752,38 +1763,10 @@ static int pxa2xx_spi_probe(struct platform_device *pdev)
> master->num_chipselect = platform_info->num_chipselect;
>
> count = gpiod_count(&pdev->dev, "cs");
> - if (count > 0) {
> - int i;
> -
> + if (count > 0)
> master->num_chipselect = max_t(int, count,
> master->num_chipselect);
>
> - drv_data->cs_gpiods = devm_kcalloc(&pdev->dev,
> - master->num_chipselect, sizeof(struct gpio_desc *),
> - GFP_KERNEL);
> - if (!drv_data->cs_gpiods) {
> - status = -ENOMEM;
> - goto out_error_clock_enabled;
> - }
> -
> - for (i = 0; i < master->num_chipselect; i++) {
> - struct gpio_desc *gpiod;
> -
> - gpiod = devm_gpiod_get_index(dev, "cs", i,
> - GPIOD_OUT_HIGH);
> - if (IS_ERR(gpiod)) {
> - /* Means use native chip select */
> - if (PTR_ERR(gpiod) == -ENOENT)
> - continue;
> -
> - status = (int)PTR_ERR(gpiod);
> - goto out_error_clock_enabled;
> - } else {
> - drv_data->cs_gpiods[i] = gpiod;
> - }
> - }
> - }
> -
> tasklet_init(&drv_data->pump_transfers, pump_transfers,
> (unsigned long)drv_data);
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-spi" in
> the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
With Best Regards,
Andy Shevchenko
--
To unsubscribe from this list: send the line "unsubscribe linux-spi" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] spi: pxa2xx: Only claim CS GPIOs when the slave device is created
2017-07-08 21:48 ` Andy Shevchenko
@ 2017-07-09 9:30 ` Jan Kiszka
[not found] ` <1677d448-4cdd-363f-34a6-152c61a06c0e-S0/GAf8tV78@public.gmane.org>
[not found] ` <CAHp75Vd8GRCwGp8eDFOL=dsgxCR+VqqUy+O50PEW=p99a8xAwQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
1 sibling, 1 reply; 16+ messages in thread
From: Jan Kiszka @ 2017-07-09 9:30 UTC (permalink / raw)
To: Andy Shevchenko
Cc: Linux Kernel Mailing List, Haojian Zhuang, linux-spi, Mark Brown,
linux-arm-kernel, Robert Jarzmik, Daniel Mack
[-- Attachment #1.1.1: Type: text/plain, Size: 5159 bytes --]
On 2017-07-08 23:48, Andy Shevchenko wrote:
> On Sat, Jul 8, 2017 at 11:41 AM, Jan Kiszka <jan.kiszka@web.de> wrote:
>> From: Jan Kiszka <jan.kiszka@siemens.com>
>>
>> Avoid hogging chip select GPIOs just because they are listed for the
>> master. They might be mulitplexed and, if no slave device is attached,
>> used for different purposes. Moreover, this strategy avoids having to
>> allocate a cs_gpiods structure.
>>
>> Tested on the IOT2000 where the second SPI bus is connected to an
>> Arduino-compatible connector and multiplexed between SPI, GPIO and PWM
>> usage.
>
> Can we first switch the driver to use GPIO descriptors instead of
> plain integers?
-ENOPARSE
>
>>
>> Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
>> ---
>> drivers/spi/spi-pxa2xx.c | 59 +++++++++++++++++-------------------------------
>> 1 file changed, 21 insertions(+), 38 deletions(-)
>>
>> diff --git a/drivers/spi/spi-pxa2xx.c b/drivers/spi/spi-pxa2xx.c
>> index 38d053682892..be991266a6ce 100644
>> --- a/drivers/spi/spi-pxa2xx.c
>> +++ b/drivers/spi/spi-pxa2xx.c
>> @@ -1213,21 +1213,33 @@ static int setup_cs(struct spi_device *spi, struct chip_data *chip,
>> struct pxa2xx_spi_chip *chip_info)
>> {
>> struct driver_data *drv_data = spi_master_get_devdata(spi->master);
>> + struct device *pdev = &drv_data->pdev->dev;
>> + struct gpio_desc *gpiod;
>> int err = 0;
>> + int count;
>>
>> if (chip == NULL)
>> return 0;
>>
>> - if (drv_data->cs_gpiods) {
>> - struct gpio_desc *gpiod;
>> + count = gpiod_count(pdev, "cs");
>> + if (count > 0) {
>> + if (spi->chip_select >= count)
>> + return -EINVAL;
>> +
>> + gpiod = gpiod_get_index(pdev, "cs", spi->chip_select,
>> + GPIOD_OUT_HIGH);
>> + if (IS_ERR(gpiod)) {
>> + /* Means use native chip select */
>> + if (PTR_ERR(gpiod) == -ENOENT)
>> + return 0;
>>
>> - gpiod = drv_data->cs_gpiods[spi->chip_select];
>> - if (gpiod) {
>> - chip->gpio_cs = desc_to_gpio(gpiod);
>> - chip->gpio_cs_inverted = spi->mode & SPI_CS_HIGH;
>> - gpiod_set_value(gpiod, chip->gpio_cs_inverted);
>> + return PTR_ERR(gpiod);
>> }
>>
>> + chip->gpio_cs = desc_to_gpio(gpiod);
>> + chip->gpio_cs_inverted = spi->mode & SPI_CS_HIGH;
>> + gpiod_set_value(gpiod, chip->gpio_cs_inverted);
>> +
>> return 0;
>> }
>>
>> @@ -1415,8 +1427,7 @@ static void cleanup(struct spi_device *spi)
>> if (!chip)
>> return;
>>
>> - if (drv_data->ssp_type != CE4100_SSP && !drv_data->cs_gpiods &&
>> - gpio_is_valid(chip->gpio_cs))
>> + if (drv_data->ssp_type != CE4100_SSP && gpio_is_valid(chip->gpio_cs))
>> gpio_free(chip->gpio_cs);
>>
>> kfree(chip);
>> @@ -1752,38 +1763,10 @@ static int pxa2xx_spi_probe(struct platform_device *pdev)
>> master->num_chipselect = platform_info->num_chipselect;
>>
>> count = gpiod_count(&pdev->dev, "cs");
>> - if (count > 0) {
>> - int i;
>> -
>> + if (count > 0)
>> master->num_chipselect = max_t(int, count,
>> master->num_chipselect);
>>
>> - drv_data->cs_gpiods = devm_kcalloc(&pdev->dev,
>> - master->num_chipselect, sizeof(struct gpio_desc *),
>> - GFP_KERNEL);
>> - if (!drv_data->cs_gpiods) {
>> - status = -ENOMEM;
>> - goto out_error_clock_enabled;
>> - }
>> -
>> - for (i = 0; i < master->num_chipselect; i++) {
>> - struct gpio_desc *gpiod;
>> -
>> - gpiod = devm_gpiod_get_index(dev, "cs", i,
>> - GPIOD_OUT_HIGH);
>> - if (IS_ERR(gpiod)) {
>> - /* Means use native chip select */
>> - if (PTR_ERR(gpiod) == -ENOENT)
>> - continue;
>> -
>> - status = (int)PTR_ERR(gpiod);
>> - goto out_error_clock_enabled;
>> - } else {
>> - drv_data->cs_gpiods[i] = gpiod;
>> - }
>> - }
>> - }
>> -
>> tasklet_init(&drv_data->pump_transfers, pump_transfers,
>> (unsigned long)drv_data);
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe linux-spi" in
>> the body of a message to majordomo@vger.kernel.org
>> More majordomo info at http://vger.kernel.org/majordomo-info.html
>
>
>
[-- Attachment #1.2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 181 bytes --]
[-- Attachment #2: Type: text/plain, Size: 176 bytes --]
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
^ permalink raw reply [flat|nested] 16+ messages in thread
[parent not found: <CAHp75Vd8GRCwGp8eDFOL=dsgxCR+VqqUy+O50PEW=p99a8xAwQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>]
* Re: [PATCH] spi: pxa2xx: Only claim CS GPIOs when the slave device is created
[not found] ` <CAHp75Vd8GRCwGp8eDFOL=dsgxCR+VqqUy+O50PEW=p99a8xAwQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
@ 2017-07-10 12:09 ` Mark Brown
2017-07-10 17:31 ` Jan Kiszka
0 siblings, 1 reply; 16+ messages in thread
From: Mark Brown @ 2017-07-10 12:09 UTC (permalink / raw)
To: Andy Shevchenko
Cc: Jan Kiszka, Daniel Mack, Haojian Zhuang, Robert Jarzmik,
linux-spi, Linux Kernel Mailing List, linux-arm-kernel
[-- Attachment #1: Type: text/plain, Size: 582 bytes --]
On Sun, Jul 09, 2017 at 12:48:10AM +0300, Andy Shevchenko wrote:
> On Sat, Jul 8, 2017 at 11:41 AM, Jan Kiszka <jan.kiszka-S0/GAf8tV78@public.gmane.org> wrote:
> > Tested on the IOT2000 where the second SPI bus is connected to an
> > Arduino-compatible connector and multiplexed between SPI, GPIO and PWM
> > usage.
> Can we first switch the driver to use GPIO descriptors instead of
> plain integers?
Only if you also convert the SPI core to use descriptors, Chris Packham
was looking at that but he needed update the ep93xx drivers among others
and getting reviewers was hard.
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 488 bytes --]
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] spi: pxa2xx: Only claim CS GPIOs when the slave device is created
2017-07-10 12:09 ` Mark Brown
@ 2017-07-10 17:31 ` Jan Kiszka
0 siblings, 0 replies; 16+ messages in thread
From: Jan Kiszka @ 2017-07-10 17:31 UTC (permalink / raw)
To: Mark Brown, Andy Shevchenko
Cc: Linux Kernel Mailing List, Haojian Zhuang, linux-spi, Daniel Mack,
Robert Jarzmik, linux-arm-kernel
[-- Attachment #1.1.1: Type: text/plain, Size: 1111 bytes --]
On 2017-07-10 14:09, Mark Brown wrote:
> On Sun, Jul 09, 2017 at 12:48:10AM +0300, Andy Shevchenko wrote:
>> On Sat, Jul 8, 2017 at 11:41 AM, Jan Kiszka <jan.kiszka@web.de> wrote:
>
>>> Tested on the IOT2000 where the second SPI bus is connected to an
>>> Arduino-compatible connector and multiplexed between SPI, GPIO and PWM
>>> usage.
>
>> Can we first switch the driver to use GPIO descriptors instead of
>> plain integers?
>
> Only if you also convert the SPI core to use descriptors, Chris Packham
> was looking at that but he needed update the ep93xx drivers among others
> and getting reviewers was hard.
>
IIUC, we can't convert completely due to some legacy boards providing
their CS lines as integers. But even then, a few more API usages can be
converted.
While looking into this, I noticed that this patch violated the formal
rule to never release a GPIO with the old API when it was requested with
the new one. That's at least stated in the docs, even though gpio_free
is equivalent to gpiod_put. Fixed that already, but I need to find some
time to retest.
Jan
[-- Attachment #1.2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 181 bytes --]
[-- Attachment #2: Type: text/plain, Size: 176 bytes --]
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
^ permalink raw reply [flat|nested] 16+ messages in thread
* Applied "spi: pxa2xx: Only claim CS GPIOs when the slave device is created" to the spi tree
[not found] ` <90b3e14d-0077-9a25-9d90-ab340577af57-S0/GAf8tV78@public.gmane.org>
2017-07-08 21:48 ` Andy Shevchenko
@ 2017-07-17 16:07 ` Mark Brown
2017-07-24 10:44 ` [PATCH] spi: pxa2xx: Only claim CS GPIOs when the slave device is created Andy Shevchenko
2017-07-24 13:03 ` Andy Shevchenko
3 siblings, 0 replies; 16+ messages in thread
From: Mark Brown @ 2017-07-17 16:07 UTC (permalink / raw)
To: Jan Kiszka
Cc: Mark Brown, Daniel Mack, Haojian Zhuang, Robert Jarzmik,
Mark Brown, linux-spi-u79uwXL29TY76Z2rM5mHXA,
Linux Kernel Mailing List, linux-arm-kernel,
linux-spi-u79uwXL29TY76Z2rM5mHXA
The patch
spi: pxa2xx: Only claim CS GPIOs when the slave device is created
has been applied to the spi tree at
git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi.git
All being well this means that it will be integrated into the linux-next
tree (usually sometime in the next 24 hours) and sent to Linus during
the next merge window (or sooner if it is a bug fix), however if
problems are discovered then the patch may be dropped or reverted.
You may get further e-mails resulting from automated or manual testing
and review of the tree, please engage with people reporting problems and
send followup patches addressing any issues that are reported if needed.
If any updates are required or you are submitting further changes they
should be sent as incremental updates against current git, existing
patches will not be replaced.
Please add any relevant lists and maintainers to the CCs when replying
to this mail.
Thanks,
Mark
>From 676a4e3bab445d53fca4756865e2c0e2a87c38d6 Mon Sep 17 00:00:00 2001
From: Jan Kiszka <jan.kiszka-kv7WeFo6aLtBDgjK7y7TUQ@public.gmane.org>
Date: Sat, 8 Jul 2017 10:41:18 +0200
Subject: [PATCH] spi: pxa2xx: Only claim CS GPIOs when the slave device is
created
Avoid hogging chip select GPIOs just because they are listed for the
master. They might be mulitplexed and, if no slave device is attached,
used for different purposes. Moreover, this strategy avoids having to
allocate a cs_gpiods structure.
Tested on the IOT2000 where the second SPI bus is connected to an
Arduino-compatible connector and multiplexed between SPI, GPIO and PWM
usage.
Signed-off-by: Jan Kiszka <jan.kiszka-kv7WeFo6aLtBDgjK7y7TUQ@public.gmane.org>
Signed-off-by: Mark Brown <broonie-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
---
drivers/spi/spi-pxa2xx.c | 59 +++++++++++++++++-------------------------------
1 file changed, 21 insertions(+), 38 deletions(-)
diff --git a/drivers/spi/spi-pxa2xx.c b/drivers/spi/spi-pxa2xx.c
index 38d053682892..be991266a6ce 100644
--- a/drivers/spi/spi-pxa2xx.c
+++ b/drivers/spi/spi-pxa2xx.c
@@ -1213,21 +1213,33 @@ static int setup_cs(struct spi_device *spi, struct chip_data *chip,
struct pxa2xx_spi_chip *chip_info)
{
struct driver_data *drv_data = spi_master_get_devdata(spi->master);
+ struct device *pdev = &drv_data->pdev->dev;
+ struct gpio_desc *gpiod;
int err = 0;
+ int count;
if (chip == NULL)
return 0;
- if (drv_data->cs_gpiods) {
- struct gpio_desc *gpiod;
+ count = gpiod_count(pdev, "cs");
+ if (count > 0) {
+ if (spi->chip_select >= count)
+ return -EINVAL;
+
+ gpiod = gpiod_get_index(pdev, "cs", spi->chip_select,
+ GPIOD_OUT_HIGH);
+ if (IS_ERR(gpiod)) {
+ /* Means use native chip select */
+ if (PTR_ERR(gpiod) == -ENOENT)
+ return 0;
- gpiod = drv_data->cs_gpiods[spi->chip_select];
- if (gpiod) {
- chip->gpio_cs = desc_to_gpio(gpiod);
- chip->gpio_cs_inverted = spi->mode & SPI_CS_HIGH;
- gpiod_set_value(gpiod, chip->gpio_cs_inverted);
+ return PTR_ERR(gpiod);
}
+ chip->gpio_cs = desc_to_gpio(gpiod);
+ chip->gpio_cs_inverted = spi->mode & SPI_CS_HIGH;
+ gpiod_set_value(gpiod, chip->gpio_cs_inverted);
+
return 0;
}
@@ -1415,8 +1427,7 @@ static void cleanup(struct spi_device *spi)
if (!chip)
return;
- if (drv_data->ssp_type != CE4100_SSP && !drv_data->cs_gpiods &&
- gpio_is_valid(chip->gpio_cs))
+ if (drv_data->ssp_type != CE4100_SSP && gpio_is_valid(chip->gpio_cs))
gpio_free(chip->gpio_cs);
kfree(chip);
@@ -1752,38 +1763,10 @@ static int pxa2xx_spi_probe(struct platform_device *pdev)
master->num_chipselect = platform_info->num_chipselect;
count = gpiod_count(&pdev->dev, "cs");
- if (count > 0) {
- int i;
-
+ if (count > 0)
master->num_chipselect = max_t(int, count,
master->num_chipselect);
- drv_data->cs_gpiods = devm_kcalloc(&pdev->dev,
- master->num_chipselect, sizeof(struct gpio_desc *),
- GFP_KERNEL);
- if (!drv_data->cs_gpiods) {
- status = -ENOMEM;
- goto out_error_clock_enabled;
- }
-
- for (i = 0; i < master->num_chipselect; i++) {
- struct gpio_desc *gpiod;
-
- gpiod = devm_gpiod_get_index(dev, "cs", i,
- GPIOD_OUT_HIGH);
- if (IS_ERR(gpiod)) {
- /* Means use native chip select */
- if (PTR_ERR(gpiod) == -ENOENT)
- continue;
-
- status = (int)PTR_ERR(gpiod);
- goto out_error_clock_enabled;
- } else {
- drv_data->cs_gpiods[i] = gpiod;
- }
- }
- }
-
tasklet_init(&drv_data->pump_transfers, pump_transfers,
(unsigned long)drv_data);
--
2.13.2
--
To unsubscribe from this list: send the line "unsubscribe linux-spi" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply related [flat|nested] 16+ messages in thread
* Re: [PATCH] spi: pxa2xx: Only claim CS GPIOs when the slave device is created
[not found] ` <90b3e14d-0077-9a25-9d90-ab340577af57-S0/GAf8tV78@public.gmane.org>
2017-07-08 21:48 ` Andy Shevchenko
2017-07-17 16:07 ` Applied "spi: pxa2xx: Only claim CS GPIOs when the slave device is created" to the spi tree Mark Brown
@ 2017-07-24 10:44 ` Andy Shevchenko
[not found] ` <CAHp75VfpJzOdhMyZoMGnC4CQc5kGxq1k-__dpmVAOaxaD04w6Q-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2017-07-24 13:03 ` Andy Shevchenko
3 siblings, 1 reply; 16+ messages in thread
From: Andy Shevchenko @ 2017-07-24 10:44 UTC (permalink / raw)
To: Jan Kiszka
Cc: Daniel Mack, Haojian Zhuang, Robert Jarzmik, Mark Brown,
linux-spi, Linux Kernel Mailing List, linux-arm-kernel
+Cc: Mika
On Sat, Jul 8, 2017 at 11:41 AM, Jan Kiszka <jan.kiszka-S0/GAf8tV78@public.gmane.org> wrote:
> From: Jan Kiszka <jan.kiszka-kv7WeFo6aLtBDgjK7y7TUQ@public.gmane.org>
>
> Avoid hogging chip select GPIOs just because they are listed for the
> master. They might be mulitplexed and, if no slave device is attached,
> used for different purposes. Moreover, this strategy avoids having to
> allocate a cs_gpiods structure.
>
> Tested on the IOT2000 where the second SPI bus is connected to an
> Arduino-compatible connector and multiplexed between SPI, GPIO and PWM
> usage.
>
This breaks all systems which are using _DSD.
While I'm looking for fix, I get feeling that the approach itself is not right,
So, for now I would vote for immediate revert and then rethink what we
can do here.
> Signed-off-by: Jan Kiszka <jan.kiszka-kv7WeFo6aLtBDgjK7y7TUQ@public.gmane.org>
> ---
> drivers/spi/spi-pxa2xx.c | 59 +++++++++++++++++-------------------------------
> 1 file changed, 21 insertions(+), 38 deletions(-)
>
> diff --git a/drivers/spi/spi-pxa2xx.c b/drivers/spi/spi-pxa2xx.c
> index 38d053682892..be991266a6ce 100644
> --- a/drivers/spi/spi-pxa2xx.c
> +++ b/drivers/spi/spi-pxa2xx.c
> @@ -1213,21 +1213,33 @@ static int setup_cs(struct spi_device *spi, struct chip_data *chip,
> struct pxa2xx_spi_chip *chip_info)
> {
> struct driver_data *drv_data = spi_master_get_devdata(spi->master);
> + struct device *pdev = &drv_data->pdev->dev;
> + struct gpio_desc *gpiod;
> int err = 0;
> + int count;
>
> if (chip == NULL)
> return 0;
>
> - if (drv_data->cs_gpiods) {
> - struct gpio_desc *gpiod;
> + count = gpiod_count(pdev, "cs");
> + if (count > 0) {
> + if (spi->chip_select >= count)
> + return -EINVAL;
> +
> + gpiod = gpiod_get_index(pdev, "cs", spi->chip_select,
> + GPIOD_OUT_HIGH);
> + if (IS_ERR(gpiod)) {
> + /* Means use native chip select */
> + if (PTR_ERR(gpiod) == -ENOENT)
> + return 0;
>
> - gpiod = drv_data->cs_gpiods[spi->chip_select];
> - if (gpiod) {
> - chip->gpio_cs = desc_to_gpio(gpiod);
> - chip->gpio_cs_inverted = spi->mode & SPI_CS_HIGH;
> - gpiod_set_value(gpiod, chip->gpio_cs_inverted);
> + return PTR_ERR(gpiod);
> }
>
> + chip->gpio_cs = desc_to_gpio(gpiod);
> + chip->gpio_cs_inverted = spi->mode & SPI_CS_HIGH;
> + gpiod_set_value(gpiod, chip->gpio_cs_inverted);
> +
> return 0;
> }
>
> @@ -1415,8 +1427,7 @@ static void cleanup(struct spi_device *spi)
> if (!chip)
> return;
>
> - if (drv_data->ssp_type != CE4100_SSP && !drv_data->cs_gpiods &&
> - gpio_is_valid(chip->gpio_cs))
> + if (drv_data->ssp_type != CE4100_SSP && gpio_is_valid(chip->gpio_cs))
> gpio_free(chip->gpio_cs);
>
> kfree(chip);
> @@ -1752,38 +1763,10 @@ static int pxa2xx_spi_probe(struct platform_device *pdev)
> master->num_chipselect = platform_info->num_chipselect;
>
> count = gpiod_count(&pdev->dev, "cs");
> - if (count > 0) {
> - int i;
> -
> + if (count > 0)
> master->num_chipselect = max_t(int, count,
> master->num_chipselect);
>
> - drv_data->cs_gpiods = devm_kcalloc(&pdev->dev,
> - master->num_chipselect, sizeof(struct gpio_desc *),
> - GFP_KERNEL);
> - if (!drv_data->cs_gpiods) {
> - status = -ENOMEM;
> - goto out_error_clock_enabled;
> - }
> -
> - for (i = 0; i < master->num_chipselect; i++) {
> - struct gpio_desc *gpiod;
> -
> - gpiod = devm_gpiod_get_index(dev, "cs", i,
> - GPIOD_OUT_HIGH);
> - if (IS_ERR(gpiod)) {
> - /* Means use native chip select */
> - if (PTR_ERR(gpiod) == -ENOENT)
> - continue;
> -
> - status = (int)PTR_ERR(gpiod);
> - goto out_error_clock_enabled;
> - } else {
> - drv_data->cs_gpiods[i] = gpiod;
> - }
> - }
> - }
> -
> tasklet_init(&drv_data->pump_transfers, pump_transfers,
> (unsigned long)drv_data);
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-spi" in
> the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
With Best Regards,
Andy Shevchenko
--
To unsubscribe from this list: send the line "unsubscribe linux-spi" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] spi: pxa2xx: Only claim CS GPIOs when the slave device is created
[not found] ` <90b3e14d-0077-9a25-9d90-ab340577af57-S0/GAf8tV78@public.gmane.org>
` (2 preceding siblings ...)
2017-07-24 10:44 ` [PATCH] spi: pxa2xx: Only claim CS GPIOs when the slave device is created Andy Shevchenko
@ 2017-07-24 13:03 ` Andy Shevchenko
[not found] ` <CAHp75VfL8RK57sxKH4UVQ0-u9gGnJ-DaqOKYcq7DrdsFhpecwQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
3 siblings, 1 reply; 16+ messages in thread
From: Andy Shevchenko @ 2017-07-24 13:03 UTC (permalink / raw)
To: Jan Kiszka, Mika Westerberg
Cc: Daniel Mack, Haojian Zhuang, Robert Jarzmik, Mark Brown,
linux-spi, Linux Kernel Mailing List, linux-arm-kernel
+Cc: Mika (for real this time)
On Sat, Jul 8, 2017 at 11:41 AM, Jan Kiszka <jan.kiszka-S0/GAf8tV78@public.gmane.org> wrote:
> From: Jan Kiszka <jan.kiszka-kv7WeFo6aLtBDgjK7y7TUQ@public.gmane.org>
>
> Avoid hogging chip select GPIOs just because they are listed for the
> master. They might be mulitplexed and, if no slave device is attached,
> used for different purposes. Moreover, this strategy avoids having to
> allocate a cs_gpiods structure.
>
> Tested on the IOT2000 where the second SPI bus is connected to an
> Arduino-compatible connector and multiplexed between SPI, GPIO and PWM
> usage.
>
> Signed-off-by: Jan Kiszka <jan.kiszka-kv7WeFo6aLtBDgjK7y7TUQ@public.gmane.org>
> ---
> drivers/spi/spi-pxa2xx.c | 59 +++++++++++++++++-------------------------------
> 1 file changed, 21 insertions(+), 38 deletions(-)
>
> diff --git a/drivers/spi/spi-pxa2xx.c b/drivers/spi/spi-pxa2xx.c
> index 38d053682892..be991266a6ce 100644
> --- a/drivers/spi/spi-pxa2xx.c
> +++ b/drivers/spi/spi-pxa2xx.c
> @@ -1213,21 +1213,33 @@ static int setup_cs(struct spi_device *spi, struct chip_data *chip,
> struct pxa2xx_spi_chip *chip_info)
> {
> struct driver_data *drv_data = spi_master_get_devdata(spi->master);
> + struct device *pdev = &drv_data->pdev->dev;
> + struct gpio_desc *gpiod;
> int err = 0;
> + int count;
>
> if (chip == NULL)
> return 0;
>
> - if (drv_data->cs_gpiods) {
> - struct gpio_desc *gpiod;
> + count = gpiod_count(pdev, "cs");
> + if (count > 0) {
> + if (spi->chip_select >= count)
> + return -EINVAL;
> +
> + gpiod = gpiod_get_index(pdev, "cs", spi->chip_select,
> + GPIOD_OUT_HIGH);
> + if (IS_ERR(gpiod)) {
> + /* Means use native chip select */
> + if (PTR_ERR(gpiod) == -ENOENT)
> + return 0;
>
> - gpiod = drv_data->cs_gpiods[spi->chip_select];
> - if (gpiod) {
> - chip->gpio_cs = desc_to_gpio(gpiod);
> - chip->gpio_cs_inverted = spi->mode & SPI_CS_HIGH;
> - gpiod_set_value(gpiod, chip->gpio_cs_inverted);
> + return PTR_ERR(gpiod);
> }
>
> + chip->gpio_cs = desc_to_gpio(gpiod);
> + chip->gpio_cs_inverted = spi->mode & SPI_CS_HIGH;
> + gpiod_set_value(gpiod, chip->gpio_cs_inverted);
> +
> return 0;
> }
>
> @@ -1415,8 +1427,7 @@ static void cleanup(struct spi_device *spi)
> if (!chip)
> return;
>
> - if (drv_data->ssp_type != CE4100_SSP && !drv_data->cs_gpiods &&
> - gpio_is_valid(chip->gpio_cs))
> + if (drv_data->ssp_type != CE4100_SSP && gpio_is_valid(chip->gpio_cs))
> gpio_free(chip->gpio_cs);
>
> kfree(chip);
> @@ -1752,38 +1763,10 @@ static int pxa2xx_spi_probe(struct platform_device *pdev)
> master->num_chipselect = platform_info->num_chipselect;
>
> count = gpiod_count(&pdev->dev, "cs");
> - if (count > 0) {
> - int i;
> -
> + if (count > 0)
> master->num_chipselect = max_t(int, count,
> master->num_chipselect);
>
> - drv_data->cs_gpiods = devm_kcalloc(&pdev->dev,
> - master->num_chipselect, sizeof(struct gpio_desc *),
> - GFP_KERNEL);
> - if (!drv_data->cs_gpiods) {
> - status = -ENOMEM;
> - goto out_error_clock_enabled;
> - }
> -
> - for (i = 0; i < master->num_chipselect; i++) {
> - struct gpio_desc *gpiod;
> -
> - gpiod = devm_gpiod_get_index(dev, "cs", i,
> - GPIOD_OUT_HIGH);
> - if (IS_ERR(gpiod)) {
> - /* Means use native chip select */
> - if (PTR_ERR(gpiod) == -ENOENT)
> - continue;
> -
> - status = (int)PTR_ERR(gpiod);
> - goto out_error_clock_enabled;
> - } else {
> - drv_data->cs_gpiods[i] = gpiod;
> - }
> - }
> - }
> -
> tasklet_init(&drv_data->pump_transfers, pump_transfers,
> (unsigned long)drv_data);
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-spi" in
> the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
With Best Regards,
Andy Shevchenko
--
To unsubscribe from this list: send the line "unsubscribe linux-spi" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 16+ messages in thread