Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp6031235ybc; Wed, 27 Nov 2019 13:44:24 -0800 (PST) X-Google-Smtp-Source: APXvYqyBFXq+DZoyIVNaAvtAc2Whh2tE7ARTKkHObj0Qw0w1Ve6+me65zTWhCNIhEVy253DFOTWk X-Received: by 2002:a05:6402:7d8:: with SMTP id u24mr36059639edy.238.1574891064143; Wed, 27 Nov 2019 13:44:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574891064; cv=none; d=google.com; s=arc-20160816; b=MVZqYGMzlkhgRbAvpGlyUs7roSI4AlKrhLVcO3FidwgtFNDVg3XcAoPEOOYR74AmnM PQVkMrL+sg4M0Z+Cfc/OOGryHTKjiezlgHfF/fov9eQGvpKK6wyaN/g2cah3wHGjCwaq yGsVO+Ys99dz7/cOBgOTmmgV1zkq8LMjYaL22GzhCMVLvfrF61XMbc7fADpWv/7zCN5h PgkyK2UlqjUIqEQP6ezbqRKkoWp1L2zhr91UhJjVkTKmiEBwWzvjP9DQOUCJJNDldhbO OL3+D/CZ0/gDrkGUEDX0lfvhUr2t9x7UPRSXmnDJdJlv6MuWtMdGAEHHi7smKUu6BdDM g1og== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=gXe+o23gpIp5NjOhBZZKDgvWem385xzjQU/1IxkHy1Q=; b=iOLE1L4pWiL3pG3YysIPJCsv5KXYS7Wy9Ydw6Kb2tYQ9oppAJwUeQQVap39Ea8UW5W 0cEAYghTRrxQriNSYjM/UKHvIP8kSDkYMJTk+P7iZR+cC3GYMHB1hBG4sI4SHxCXERqE ZXJfDdRc3n5wiXmtFv1YmPDtQLbJOlfxNQ76RxYNo6uGZhp4Ntd96fASZTiAILUrzJ6T GcchzWUdjsFdR7BE9T+EyDJRVYhdYfzDLREcCfdOVWbO93e5GsLTSUNPEpu1/NaSm14y MBdDbTpQXfVvcMG66WcIdG0fZ/WF8k7Rr9jqGDu+wANiaRFf2d3ITRnc2TSFreFkYYwl 0HEA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=FIvQiTdi; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p17si11012057edm.269.2019.11.27.13.44.00; Wed, 27 Nov 2019 13:44:24 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=FIvQiTdi; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727722AbfK0UlH (ORCPT + 99 others); Wed, 27 Nov 2019 15:41:07 -0500 Received: from mail.kernel.org ([198.145.29.99]:46004 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729123AbfK0UlE (ORCPT ); Wed, 27 Nov 2019 15:41:04 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 61D8621787; Wed, 27 Nov 2019 20:41:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1574887263; bh=qpOfe/n+XafqdA3bd277vvX9ZgxGKO9nKXTsAQ4Xcxc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=FIvQiTdiw0n+8J+79ByihWggdYBKtTRRaJdBqdBXXslMlSyRW+rNKc0cXjDkyID1x D7W5gXQnBap+8QZi0mhQ1K7lb6C3dl/aaCOQf5mc02XitCVqTb032Rw3p3fxKCwtE/ sUmv4Xj6y4riUmrD6sxjcKZ0CriJXh+froKNl3gQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Mattias Jacobsson <2pi@mok.nu>, Sasha Levin Subject: [PATCH 4.9 043/151] USB: misc: appledisplay: fix backlight update_status return code Date: Wed, 27 Nov 2019 21:30:26 +0100 Message-Id: <20191127203027.261800350@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191127203000.773542911@linuxfoundation.org> References: <20191127203000.773542911@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Mattias Jacobsson <2pi@mok.nu> [ Upstream commit 090158555ff8d194a98616034100b16697dd80d0 ] Upon success the update_status handler returns a positive number corresponding to the number of bytes transferred by usb_control_msg. However the return code of the update_status handler should indicate if an error occurred(negative) or how many bytes of the user's input to sysfs that was consumed. Return code zero indicates all bytes were consumed. The bug can for example result in the update_status handler being called twice, the second time with only the "unconsumed" part of the user's input to sysfs. Effectively setting an incorrect brightness. Change the update_status handler to return zero for all successful transactions and forward usb_control_msg's error code upon failure. Signed-off-by: Mattias Jacobsson <2pi@mok.nu> Signed-off-by: Greg Kroah-Hartman Signed-off-by: Sasha Levin --- drivers/usb/misc/appledisplay.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/drivers/usb/misc/appledisplay.c b/drivers/usb/misc/appledisplay.c index b8092bcf89a29..140af7754c1e6 100644 --- a/drivers/usb/misc/appledisplay.c +++ b/drivers/usb/misc/appledisplay.c @@ -160,8 +160,11 @@ static int appledisplay_bl_update_status(struct backlight_device *bd) pdata->msgdata, 2, ACD_USB_TIMEOUT); mutex_unlock(&pdata->sysfslock); - - return retval; + + if (retval < 0) + return retval; + else + return 0; } static int appledisplay_bl_get_brightness(struct backlight_device *bd) -- 2.20.1