From: David Kershner Date: Tue, 28 Mar 2017 13:34:51 +0000 (-0400) Subject: staging: unisys: visorbus: don't ignore visorchannel_read error X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=711c67f4ecc81a8b1ebf26844c5874888078ed46;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git staging: unisys: visorbus: don't ignore visorchannel_read error Don't override the visorchannel_read_error, just return the error that it generates. Signed-off-by: David Kershner Reviewed-by: Reviewed-by: Tim Sell Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/staging/unisys/visorbus/visorbus_main.c b/drivers/staging/unisys/visorbus/visorbus_main.c index f5b637ccf1cd..af9bf2453b44 100644 --- a/drivers/staging/unisys/visorbus/visorbus_main.c +++ b/drivers/staging/unisys/visorbus/visorbus_main.c @@ -691,6 +691,8 @@ static int get_vbus_header_info(struct visorchannel *chan, struct spar_vbus_headerinfo *hdr_info) { + int err; + if (!spar_check_channel(visorchannel_get_header(chan), spar_vbus_channel_protocol_uuid, "vbus", @@ -699,10 +701,11 @@ get_vbus_header_info(struct visorchannel *chan, SPAR_VBUS_CHANNEL_PROTOCOL_SIGNATURE)) return -EINVAL; - if (visorchannel_read(chan, sizeof(struct channel_header), hdr_info, - sizeof(*hdr_info)) < 0) { - return -EIO; - } + err = visorchannel_read(chan, sizeof(struct channel_header), hdr_info, + sizeof(*hdr_info)); + if (err < 0) + return err; + if (hdr_info->struct_bytes < sizeof(struct spar_vbus_headerinfo)) return -EINVAL;