[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-Id: <1206341503819410@web4g.yandex.ru>
Date: Sun, 27 Aug 2017 10:36:50 +0300
From: Evgeniy Polyakov <zbr@...emap.net>
To: Chen Lin <chen.lin5@....com.cn>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>
Cc: "jiang.biao2@....com.cn" <jiang.biao2@....com.cn>
Subject: Re: [PATCH v2] w1:fix byteorder of W1_READ_ROM id under big-endian cpu
Hi Chen
19.07.2017, 10:58, "Chen Lin" <chen.lin5@....com.cn>:
> The byteorder of para rn(W1_READ_ROM id) pass to w1_slave_found must
> be the same with the byterorder defined in struct w1_reg_num.
>
> The rn read from 'rv = w1_read_block(dev, (u8 *)&rn, 8)' is a byte
> serial and not cpu endian relative, it need to change to cpu endian
> before passed to w1_slave_found.
But w1_reg_num has a different layout for be/le systems, isn't it enough?
> Signed-off-by: Chen Lin <chen.lin5@....com.cn>
> Reviewed-by: Jiang Biao <jiang.biao2@....com.cn>
> ---
> Forgot the description in v1.
>
> ---
> drivers/w1/w1.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/drivers/w1/w1.c b/drivers/w1/w1.c
> index 95ea7e6..c531545 100644
> --- a/drivers/w1/w1.c
> +++ b/drivers/w1/w1.c
> @@ -979,7 +979,7 @@ void w1_search(struct w1_master *dev, u8 search_type, w1_slave_found_callback cb
> mutex_unlock(&dev->bus_mutex);
>
> if (rv == 8 && rn)
> - cb(dev, rn);
> + cb(dev, le64_to_cpu(rn));
>
> break;
> }
> --
> 1.8.3.1
Powered by blists - more mailing lists