Re: [PATCH v1 2/2] drm/bridge/synopsys: dsi: Add a warning msg on dsi read operations

From: Philippe CORNU
Date: Wed Jan 24 2018 - 08:22:49 EST


Hi Brian,


On 01/23/2018 10:28 PM, Brian Norris wrote:
> Hi Philippe,
>
> I see you sent this out already today, while I only just responded
> (late) to your questions about it... oh well :)
>

I got a short period to clean-up and adds features to this driver (1.31
ip version + maybe the read feature), sorry to have not wait a single
day more.

> On Tue, Jan 23, 2018 at 6:26 AM, Philippe Cornu <philippe.cornu@xxxxxx> wrote:
>> The DCS/GENERIC DSI read feature is not yet implemented so it
>> is important to warn the host_transfer() caller in case of
>> read operation requests.
>>
>> Signed-off-by: Philippe Cornu <philippe.cornu@xxxxxx>
>> ---
>> drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c | 9 ++++++++-
>> 1 file changed, 8 insertions(+), 1 deletion(-)
>>
>> diff --git a/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c b/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c
>> index 096cf5e5bb30..e46ddff8601c 100644
>> --- a/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c
>> +++ b/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c
>> @@ -417,7 +417,14 @@ static ssize_t dw_mipi_dsi_host_transfer(struct mipi_dsi_host *host,
>> if (ret)
>> return ret;
>>
>> - nb_bytes = packet.size;
>> + if (msg->rx_buf && msg->rx_len > 0) {
>
> It feels like you should do this check *before* you start writing
> anything. It's possible to have a combination TX/RX command, and it
> would be counterintuitive to only do half the operation then return
> with an argument error.
>

Many thanks for your review.

I agree with your comments.

Well, my patch is not good at all because it contains a small part of
the read feature I am writing... but it is not the purpose of this patch.

No excuse, sorry guys for making you waste time.

I will re-write a new patch 100% decorrelated from a possible future
read feature.

I could also wait until I have a working read feature but as it could
take some times, I prefer warning users asap.

>> + /* TODO dw drv improvements: implement read feature */
>> + dev_warn(dsi->dev, "read operations not yet implemented\n");
>> + return -EPERM;
>
> I'm not sure -EPERM is right. Feels like -EINVAL, -ENOSYS, or
> -EOPNOTSUPP. I think -ENOSYS actually has been abused somewhat, so
> maybe one of the other two.
>

not easy to pick the right one. I will use -EINVAL.

>> +
>
> Spurious blank line?
>
thanks

>> + } else {
>> + nb_bytes = packet.size;
>> + }
>
> You don't actually need to put this sort of thing in the 'else' case.
> The other branch is an error-handling case, which definitely 'return's
> early, and it's pretty standard coding style to avoid indenting the
> "good" path like this.
>
> Brian
>

The else part is linked to my "read feature" too, sorry for that. I will
do it simpler in next version.

Thank you,
Philippe :-)

>>
>> return nb_bytes;
>> }
>> --
>> 2.15.1
>>