From: Jean Delvare <khali-PUYAD+kWke1g9hUCZPvPmw@public.gmane.org>
To: Ben Dooks <ben-linux-elnMNo+KYs3YtjvyW6yDsg@public.gmane.org>
Cc: i2c-GZX6beZjE8VD60Wz+7aTrA@public.gmane.org
Subject: Re: i2c: Documentation: fix device matching description
Date: Tue, 3 Jun 2008 19:20:12 +0200 [thread overview]
Message-ID: <20080603192012.5e489ee0@hyperion.delvare> (raw)
In-Reply-To: <20080603164711.843849539-elnMNo+KYs3pIgCt6eIbzw@public.gmane.org>
Hi Ben,
On Tue, 03 Jun 2008 17:47:12 +0100, Ben Dooks wrote:
> The matching process described for new style clients in
> Documentation/i2c/writing-clients is classed as out-of-date
> as it requires the presence of an .id_table entry in the
> driver's i2c_driver entry.
>
> Signed-off-by: Ben Dooks <ben-linux-elnMNo+KYs3YtjvyW6yDsg@public.gmane.org>
>
> Index: linux-2.6.26-rc4-quilt3/Documentation/i2c/writing-clients
> ===================================================================
> --- linux-2.6.26-rc4-quilt3.orig/Documentation/i2c/writing-clients 2008-06-03 17:31:39.000000000 +0100
> +++ linux-2.6.26-rc4-quilt3/Documentation/i2c/writing-clients 2008-06-03 17:37:29.000000000 +0100
> @@ -25,12 +25,23 @@ routines, and should be zero-initialized
> provide. A client structure holds device-specific information like the
> driver model device node, and its I2C address.
>
> +/* iff driver uses driver model ("new style") binding model: */
> +
> +static struct i2c_device_id foo_idtable[] = {
> + { "foo", my_id_for_foo },
> + { "bar", my_id_for_bar },
> + { }
> +};
> +
> +MODULE_DEVICE_TABLE(i2c, foo_idtable);
> +
> static struct i2c_driver foo_driver = {
> .driver = {
> .name = "foo",
> },
>
> /* iff driver uses driver model ("new style") binding model: */
> + .id_table = foo_ids,
> .probe = foo_probe,
> .remove = foo_remove,
>
> @@ -173,10 +184,15 @@ handle may be used during foo_probe().
> (zero not a negative status code) it may save the handle and use it until
> foo_remove() returns. That binding model is used by most Linux drivers.
>
> -Drivers match devices when i2c_client.driver_name and the driver name are
> -the same; this approach is used in several other busses that don't have
> -device typing support in the hardware. The driver and module name should
> -match, so hotplug/coldplug mechanisms will modprobe the driver.
> +Drivers match devices when an entry in the id_table[x].name and the
Strange sentence construct.
> +device name are the same; this approach is used in several other busses
> +that don't have device typing support in the hardware. The driver and
> +module name should match, so hotplug/coldplug mechanisms will modprobe
> +the driver.
This needs some rework. "that don't have device typing support in the
hardware" no longer applies, and in fact the whole sentence might go
away: we do exactly the same as all other subsystems now, so no need to
justify ourselves. And the driver and module names no longer have to
match, as the hotplug happens based on device names (in the id table)
and not the driver name.
> +
> +The id argument to the probe function will be the id_table entry matched
> +during the probe, so that a device can support more than one flavour of
> +similar device.
>
>
> Device Creation (Standard driver model)
>
--
Jean Delvare
_______________________________________________
i2c mailing list
i2c-GZX6beZjE8VD60Wz+7aTrA@public.gmane.org
http://lists.lm-sensors.org/mailman/listinfo/i2c
next prev parent reply other threads:[~2008-06-03 17:20 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-06-03 16:47 i2c: Documentation: fix device matching description Ben Dooks
[not found] ` <20080603164711.843849539-elnMNo+KYs3pIgCt6eIbzw@public.gmane.org>
2008-06-03 17:20 ` Jean Delvare [this message]
-- strict thread matches above, loose matches on Subject: below --
2008-06-03 17:26 Ben Dooks
[not found] ` <20080603172603.246034423-elnMNo+KYs3pIgCt6eIbzw@public.gmane.org>
2008-06-03 17:28 ` Ben Dooks
[not found] ` <20080603172857.GC8391-elnMNo+KYs3pIgCt6eIbzw@public.gmane.org>
2008-06-04 11:12 ` Jean Delvare
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=20080603192012.5e489ee0@hyperion.delvare \
--to=khali-puyad+kwke1g9huczpvpmw@public.gmane.org \
--cc=ben-linux-elnMNo+KYs3YtjvyW6yDsg@public.gmane.org \
--cc=i2c-GZX6beZjE8VD60Wz+7aTrA@public.gmane.org \
/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