u-boot.lists.denx.de archive mirror
 help / color / mirror / Atom feed
From: Heiko Schocher <hs@denx.de>
To: u-boot@lists.denx.de
Subject: [U-Boot] [Patch V3] i2c: mxc: add a condition in case the parameter is NULL
Date: Fri, 18 Dec 2015 11:24:25 +0100	[thread overview]
Message-ID: <5673DED9.4090500@denx.de> (raw)
In-Reply-To: <1450431481-45235-1-git-send-email-Qianyu.Gong@freescale.com>

Hello Gong Qianyu,

added Stefano Babic to cc as he is the imx maintainer.

Am 18.12.2015 um 10:38 schrieb Gong Qianyu:
> This could avoid executing the code that only applies to i.MX platforms.
>
> The bus_i2c_init() is called before relocation and will assgin value
> to a static variable. If U-Boot is then still running in a flash
> device, it's theoretically not allowed to write data to flash without
> an erasing operation. For i.MX platforms, the U-Boot is always running
> in DDR.
>
> Actually it causes asynchronous error when the ARM64 system error
> report is enabled and the flash write protect is set.
>
> Signed-off-by: Gong Qianyu <Qianyu.Gong@freescale.com>
> ---
> V3:
>   - Sorry..Remove an unrelated line in other file.
>
>   drivers/i2c/mxc_i2c.c | 12 ++++++++++--
>   1 file changed, 10 insertions(+), 2 deletions(-)

Ok, from my side, but it would be better to switch your board(s)
to support DM and get rid of this old stuff from this driver.

Reviewed-by: Heiko Schocher <hs@denx.de>

bye,
Heiko
>
> diff --git a/drivers/i2c/mxc_i2c.c b/drivers/i2c/mxc_i2c.c
> index fa4c82f..b2d15c9 100644
> --- a/drivers/i2c/mxc_i2c.c
> +++ b/drivers/i2c/mxc_i2c.c
> @@ -581,8 +581,16 @@ void bus_i2c_init(int index, int speed, int unused,
>   		return;
>   	}
>
> -	mxc_i2c_buses[index].idle_bus_fn = idle_bus_fn;
> -	mxc_i2c_buses[index].idle_bus_data = idle_bus_data;
> +	/*
> +	 * Warning: Be careful to allow the assignment to a static
> +	 * variable here. This function could be called while U-Boot is
> +	 * still running in flash memory. So such assignment is equal
> +	 * to write data to flash without erasing.
> +	 */
> +	if (idle_bus_fn)
> +		mxc_i2c_buses[index].idle_bus_fn = idle_bus_fn;
> +	if (idle_bus_data)
> +		mxc_i2c_buses[index].idle_bus_data = idle_bus_data;
>
>   	ret = enable_i2c_clk(1, index);
>   	if (ret < 0) {
>

-- 
DENX Software Engineering GmbH,      Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany

  reply	other threads:[~2015-12-18 10:24 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-12-18  9:38 [U-Boot] [Patch V3] i2c: mxc: add a condition in case the parameter is NULL Gong Qianyu
2015-12-18 10:24 ` Heiko Schocher [this message]
2015-12-21  5:41   ` Qianyu Gong
2015-12-30  9:27     ` Qianyu Gong
2016-01-03 15:02 ` Stefano Babic

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=5673DED9.4090500@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;
as well as URLs for NNTP newsgroup(s).