From: Heiko Schocher <hs@denx.de>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH] i2c: at91: Add missing probe function to device driver
Date: Mon, 7 Aug 2017 09:17:31 +0200 [thread overview]
Message-ID: <5988140B.2070202@denx.de> (raw)
In-Reply-To: <20170731015627.16293-1-wenyou.yang@microchip.com>
Hello Wenyou,
Am 31.07.2017 um 03:56 schrieb Wenyou Yang:
> Add missing probe function to the device driver to active a device.
>
> Signed-off-by: Wenyou Yang <wenyou.yang@microchip.com>
> ---
>
> drivers/i2c/at91_i2c.c | 26 ++++++++++++++++++++++++--
> 1 file changed, 24 insertions(+), 2 deletions(-)
Reviewed-by: Heiko Schocher <hs@denx.de>
bye,
Heiko
>
> diff --git a/drivers/i2c/at91_i2c.c b/drivers/i2c/at91_i2c.c
> index b7298cf774..d394044f80 100644
> --- a/drivers/i2c/at91_i2c.c
> +++ b/drivers/i2c/at91_i2c.c
> @@ -199,7 +199,7 @@ static int at91_i2c_enable_clk(struct udevice *dev)
> return 0;
> }
>
> -static int at91_i2c_probe(struct udevice *dev, uint chip, uint chip_flags)
> +static int at91_i2c_probe_chip(struct udevice *dev, uint chip, uint chip_flags)
> {
> struct at91_i2c_bus *bus = dev_get_priv(dev);
> struct at91_i2c_regs *reg = bus->regs;
> @@ -254,11 +254,32 @@ static int at91_i2c_ofdata_to_platdata(struct udevice *dev)
>
> static const struct dm_i2c_ops at91_i2c_ops = {
> .xfer = at91_i2c_xfer,
> - .probe_chip = at91_i2c_probe,
> + .probe_chip = at91_i2c_probe_chip,
> .set_bus_speed = at91_i2c_set_bus_speed,
> .get_bus_speed = at91_i2c_get_bus_speed,
> };
>
> +static int at91_i2c_probe(struct udevice *dev)
> +{
> + struct at91_i2c_bus *bus = dev_get_priv(dev);
> + struct at91_i2c_regs *reg = bus->regs;
> + int ret;
> +
> + ret = at91_i2c_enable_clk(dev);
> + if (ret)
> + return ret;
> +
> + writel(TWI_CR_SWRST, ®->cr);
> +
> + at91_calc_i2c_clock(dev, bus->clock_frequency);
> +
> + writel(bus->cwgr_val, ®->cwgr);
> + writel(TWI_CR_MSEN, ®->cr);
> + writel(TWI_CR_SVDIS, ®->cr);
> +
> + return 0;
> +}
> +
> static const struct at91_i2c_pdata at91rm9200_config = {
> .clk_max_div = 5,
> .clk_offset = 3,
> @@ -315,6 +336,7 @@ U_BOOT_DRIVER(i2c_at91) = {
> .name = "i2c_at91",
> .id = UCLASS_I2C,
> .of_match = at91_i2c_ids,
> + .probe = at91_i2c_probe,
> .ofdata_to_platdata = at91_i2c_ofdata_to_platdata,
> .per_child_auto_alloc_size = sizeof(struct dm_i2c_chip),
> .priv_auto_alloc_size = sizeof(struct at91_i2c_bus),
>
--
DENX Software Engineering GmbH, Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
next prev parent reply other threads:[~2017-08-07 7:17 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-07-31 1:56 [U-Boot] [PATCH] i2c: at91: Add missing probe function to device driver Wenyou Yang
2017-08-07 7:17 ` Heiko Schocher [this message]
2017-08-10 10:08 ` Heiko Schocher
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=5988140B.2070202@denx.de \
--to=hs@denx.de \
--cc=u-boot@lists.denx.de \
/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