rpmsg: qcom_smd: Correct return value for O_NONBLOCK
authorBjorn Andersson <bjorn.andersson@linaro.org>
Fri, 2 Dec 2016 00:59:55 +0000 (16:59 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 12 Jan 2017 10:39:31 +0000 (11:39 +0100)
commit 1d74e7ed5dc1903ac081574a9b6aa94e7ba4ad45 upstream.

qcom_smd_send() should return -EAGAIN for non-blocking channels with
insufficient space, so that we can propagate this event to user space.

Fixes: 53e2822e56c7 ("rpmsg: Introduce Qualcomm SMD backend")
Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/rpmsg/qcom_smd.c

index 06fef2b4c81408f3e4e1bb1c91949f82e6afa58b..1d4770c02e57e2c0b0eda4c5b6313c8f69dae4f2 100644 (file)
@@ -739,7 +739,7 @@ static int __qcom_smd_send(struct qcom_smd_channel *channel, const void *data,
 
        while (qcom_smd_get_tx_avail(channel) < tlen) {
                if (!wait) {
-                       ret = -ENOMEM;
+                       ret = -EAGAIN;
                        goto out;
                }