From: Lee Jones <lee.jones@linaro.org>
To: Linus Walleij <linus.walleij@linaro.org>
Cc: linux-gpio@vger.kernel.org,
"Alexandre Courbot" <acourbot@nvidia.com>,
"Haavard Skinnemoen" <hskinnemoen@gmail.com>,
"Hans-Christian Egtvedt" <egtvedt@samfundet.no>,
"Rafał Miłecki" <zajec5@gmail.com>,
"Jiri Kosina" <jikos@kernel.org>,
"Dmitry Torokhov" <dmitry.torokhov@gmail.com>,
"Richard Purdie" <rpurdie@rpsys.net>,
"Jacek Anaszewski" <j.anaszewski@samsung.com>,
"Mauro Carvalho Chehab" <mchehab@osg.samsung.com>,
"Alek Du" <alek.du@intel.com>,
"Greg Kroah-Hartman" <gregkh@linuxfoundation.org>,
"Jaroslav Kysela" <perex@perex.cz>,
"Takashi Iwai" <tiwai@suse.com>
Subject: Re: [PATCH] gpio: change member .dev to .parent
Date: Wed, 4 Nov 2015 17:13:00 +0000 [thread overview]
Message-ID: <20151104171300.GJ3503@x1> (raw)
In-Reply-To: <1446629475-31754-1-git-send-email-linus.walleij@linaro.org>
On Wed, 04 Nov 2015, Linus Walleij wrote:
> The name .dev in a struct is normally reserved for a struct device
> that is let us say a superclass to the thing described by the struct.
> struct gpio_chip stands out by confusingly using a struct device *dev
> to point to the parent device (such as a platform_device) that
> represents the hardware. As we want to give gpio_chip:s real devices,
> this is not working. We need to rename this member to parent.
>
> This was done by two coccinelle scripts, I guess it is possible to
> combine them into one, but I don't know such stuff. They look like
> this:
>
> @@
> struct gpio_chip *var;
> @@
> -var->dev
> +var->parent
>
> and:
>
> @@
> struct gpio_chip var;
> @@
> -var.dev
> +var.parent
>
> This patch hits all over the place, but I *strongly* prefer this
> solution to any piecemal approaches that just exercise patch
> mechanics all over the place. It mainly hits drivers/gpio and
> drivers/pinctrl which is my own backyard anyway.
>
> Cc: Haavard Skinnemoen <hskinnemoen@gmail.com>
> Cc: Hans-Christian Egtvedt <egtvedt@samfundet.no>
> Cc: Rafał Miłecki <zajec5@gmail.com>
> Cc: Jiri Kosina <jikos@kernel.org>
> Cc: Dmitry Torokhov <dmitry.torokhov@gmail.com>
> Cc: Richard Purdie <rpurdie@rpsys.net>
> Cc: Jacek Anaszewski <j.anaszewski@samsung.com>
> Cc: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
> Cc: Lee Jones <lee.jones@linaro.org>
> Cc: Alek Du <alek.du@intel.com>
> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
> Cc: Jaroslav Kysela <perex@perex.cz>
> Cc: Takashi Iwai <tiwai@suse.com>
> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
> ---
> Other subsystem maintainers: please ACK this. I want to merge this
> big patch in the beginning of -rc1. I can create an immutable branch
> or tag if you think it will cause you problems, so you can pull it
> in.
> ---
[...]
> drivers/mfd/dm355evm_msp.c | 2 +-
> drivers/mfd/htc-egpio.c | 2 +-
> drivers/mfd/htc-i2cpld.c | 4 +--
> drivers/mfd/tps65010.c | 2 +-
[...]
> 120 files changed, 265 insertions(+), 252 deletions(-)
[...]
> diff --git a/drivers/mfd/dm355evm_msp.c b/drivers/mfd/dm355evm_msp.c
> index 4c826f78acd0..bc90efe01b59 100644
> --- a/drivers/mfd/dm355evm_msp.c
> +++ b/drivers/mfd/dm355evm_msp.c
> @@ -259,7 +259,7 @@ static int add_children(struct i2c_client *client)
> int i;
>
> /* GPIO-ish stuff */
> - dm355evm_msp_gpio.dev = &client->dev;
> + dm355evm_msp_gpio.parent = &client->dev;
> status = gpiochip_add(&dm355evm_msp_gpio);
> if (status < 0)
> return status;
> diff --git a/drivers/mfd/htc-egpio.c b/drivers/mfd/htc-egpio.c
> index 6ccaf90d98fd..eca19d637785 100644
> --- a/drivers/mfd/htc-egpio.c
> +++ b/drivers/mfd/htc-egpio.c
> @@ -321,7 +321,7 @@ static int __init egpio_probe(struct platform_device *pdev)
> ei->chip[i].dev = &(pdev->dev);
> chip = &(ei->chip[i].chip);
> chip->label = "htc-egpio";
> - chip->dev = &pdev->dev;
> + chip->parent = &pdev->dev;
Are you buggering up my tabbing, or is this a Gitisum?
I'm sure it is. Anyway:
Acked-by: Lee Jones <lee.jones@linaro.org>
.. use it wisely. ;)
> chip->owner = THIS_MODULE;
> chip->get = egpio_get;
> chip->set = egpio_set;
> diff --git a/drivers/mfd/htc-i2cpld.c b/drivers/mfd/htc-i2cpld.c
> index 1bd5b042c8b3..a36f6a5a308b 100644
> --- a/drivers/mfd/htc-i2cpld.c
> +++ b/drivers/mfd/htc-i2cpld.c
> @@ -430,7 +430,7 @@ static int htcpld_register_chip_gpio(
> /* Setup the GPIO chips */
> gpio_chip = &(chip->chip_out);
> gpio_chip->label = "htcpld-out";
> - gpio_chip->dev = dev;
> + gpio_chip->parent = dev;
> gpio_chip->owner = THIS_MODULE;
> gpio_chip->get = htcpld_chip_get;
> gpio_chip->set = htcpld_chip_set;
> @@ -441,7 +441,7 @@ static int htcpld_register_chip_gpio(
>
> gpio_chip = &(chip->chip_in);
> gpio_chip->label = "htcpld-in";
> - gpio_chip->dev = dev;
> + gpio_chip->parent = dev;
> gpio_chip->owner = THIS_MODULE;
> gpio_chip->get = htcpld_chip_get;
> gpio_chip->set = NULL;
> diff --git a/drivers/mfd/tps65010.c b/drivers/mfd/tps65010.c
> index 448f0a182dc4..b96847491277 100644
> --- a/drivers/mfd/tps65010.c
> +++ b/drivers/mfd/tps65010.c
> @@ -638,7 +638,7 @@ static int tps65010_probe(struct i2c_client *client,
> tps->outmask = board->outmask;
>
> tps->chip.label = client->name;
> - tps->chip.dev = &client->dev;
> + tps->chip.parent = &client->dev;
> tps->chip.owner = THIS_MODULE;
>
> tps->chip.set = tps65010_gpio_set;
[...]
--
Lee Jones
Linaro STMicroelectronics Landing Team Lead
Linaro.org │ Open source software for ARM SoCs
Follow Linaro: Facebook | Twitter | Blog
--
To unsubscribe from this list: send the line "unsubscribe linux-gpio" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2015-11-04 17:13 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-11-04 9:31 [PATCH] gpio: change member .dev to .parent Linus Walleij
2015-11-04 9:33 ` Jiri Kosina
2015-11-04 9:54 ` Hans-Christian Noren Egtvedt
2015-11-04 13:26 ` Jacek Anaszewski
2015-11-04 17:13 ` Lee Jones [this message]
2015-11-05 10:01 ` Linus Walleij
2015-11-04 17:13 ` Greg Kroah-Hartman
2015-11-05 18:08 ` Dmitry Torokhov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20151104171300.GJ3503@x1 \
--to=lee.jones@linaro.org \
--cc=acourbot@nvidia.com \
--cc=alek.du@intel.com \
--cc=dmitry.torokhov@gmail.com \
--cc=egtvedt@samfundet.no \
--cc=gregkh@linuxfoundation.org \
--cc=hskinnemoen@gmail.com \
--cc=j.anaszewski@samsung.com \
--cc=jikos@kernel.org \
--cc=linus.walleij@linaro.org \
--cc=linux-gpio@vger.kernel.org \
--cc=mchehab@osg.samsung.com \
--cc=perex@perex.cz \
--cc=rpurdie@rpsys.net \
--cc=tiwai@suse.com \
--cc=zajec5@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).