[alsa-devel] Fwd: [PATCH 1/1] SPI : spi-pxa2xx : fix spi init of WM510205 codec via ACPI (resend)
Mika Westerberg
mika.westerberg at linux.intel.com
Wed Aug 19 15:43:28 CEST 2015
On Wed, Aug 19, 2015 at 12:29:08PM +0200, Christian Hartmann wrote:
> Hi
>
> >> There is acpi_fwnode_handle() in include/acpi/acpi_bus.h. However, if
> >> you have Linux device available you should really use devm_gpio_*
> >> functions instead.
>
> ok, after some changes I got it compiled, but there seems another
> mistake (by me?), it does not find the GPIOs yet.
>
...
> [ 5.891255] arizona spi-WM510205:00: GPIO lookup for consumer ldoena
> [ 5.891263] arizona spi-WM510205:00: using ACPI for GPIO lookup
> [ 5.891269] acpi WM510205:00: GPIO: looking up ldoena-gpios
> [ 5.891274] acpi WM510205:00: GPIO: looking up ldoena-gpio
> [ 5.891279] acpi WM510205:00: GPIO: looking up 0 in _CRS
> [ 5.891324] gpio-342 (reset): gpiod_request: status -16
> [ 5.891330] arizona spi-WM510205:00: Failed to get ldoena line: -16
It returns -EBUSY so is the GPIO already requested?
> [ 5.891335] acpi WM510205:00: GPIO: looking up 0 in _CRS
> [ 5.891409] arizona spi-WM510205:00: arizona_of_get_core_pdata
> (ACPI) using irq_gpio GPIO = 146
> [ 5.891415] arizona spi-WM510205:00: arizona_of_get_core_pdata
> (ACPI) using ldoena GPIO = 23
> [ 5.891421] arizona spi-WM510205:00: arizona_of_get_core_pdata
> (ACPI) using reset GPIO = -184850384
> [ 5.891425] arizona spi-WM510205:00: arizona_of_get_core_pdata for 1
> [ 5.891430] arizona spi-WM510205:00: regcache_cache_only for 1 set
> [ 5.891434] arizona spi-WM510205:00: added wm5102_core_supplies for 1
> [ 5.894845] rfkill_gpio: probe of LNV4752:00 failed with error -16
> [ 5.906587] LDO1: Failed to request enable GPIO23: -517
> [ 5.906673] arizona spi-WM510205:00: Failed to register LDO1 supply: -517
> [ 5.923633] spi-WM510205:00 supply AVDD not found, using dummy regulator
> [ 5.923687] spi-WM510205:00 supply DBVDD1 not found, using dummy regulator
> [ 5.923718] spi-WM510205:00 supply DCVDD not found, using dummy regulator
> [ 5.923751] ------------[ cut here ]------------
> [ 5.923763] WARNING: CPU: 2 PID: 474 at drivers/gpio/gpiolib.c:86
> gpio_to_desc+0xbb/0xd0()
>
> in arizona-spi I try to map these GPIOs, which I want to get in
> arizona-core: arizona_dev_init
>
> diff --git a/drivers/mfd/arizona-spi.c b/drivers/mfd/arizona-spi.c
> index 1e845f6..52872a0 100644
> --- a/drivers/mfd/arizona-spi.c
> +++ b/drivers/mfd/arizona-spi.c
> @@ -18,28 +18,58 @@
> #include <linux/slab.h>
> #include <linux/spi/spi.h>
> #include <linux/of.h>
> +#include <linux/acpi.h>
>
> #include <linux/mfd/arizona/core.h>
>
> #include "arizona.h"
>
> +const struct acpi_gpio_params reset_gpio = { 1, 0, false};
> +const struct acpi_gpio_params ldoena_gpio = { 2, 0, false};
> +
> +const struct acpi_gpio_mapping arizona_acpi_gpios[] = {
> + { "reset_gpio", &reset_gpio, 1,},
> + { "ldoena_gpio", &ldoena_gpio, 1},
The correct names are "reset-gpios" and "ldoena-gpios". If you call
reset = devm_gpiod_get_optional(arizona->dev, "reset", GPIOD_OUT_LOW);
GPIO core will look for "reset-gpios" and then "reset-gpio" not
"reset_gpio" so it will not find the mapping.
More information about the Alsa-devel
mailing list