Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp170847pxb; Mon, 13 Sep 2021 16:11:06 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwXPEIWylSde1FtqhZCuiZFolEGO+Y0D8TnhEb7zT+mSyFDUCqbI7iFWWgqm3Wij1YHUnNU X-Received: by 2002:aa7:d582:: with SMTP id r2mr13584204edq.324.1631574666668; Mon, 13 Sep 2021 16:11:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631574666; cv=none; d=google.com; s=arc-20160816; b=ey6O+3ydg0JRiavQFl2XO7BF3G+U7wIiLmfFdWxLsFKc5o5ZEGhq14GBcJpKelnc9j a+x7AiC1rjaM0Tf8Tepy+RSNrd62EzAeFlJTDlwO0QYRo3e1nAKEtoX44b++eO3zhMsZ vvfSxqKyxYSRTTO6NF0euexViwPuTegicQw4tgDy8rR3tnmTnkFNEC5/F+7tBT9wL5y/ vZktcaRhvQK7mcKG1PAlONA12NQzYpLvBeen4JVdPSKfaC+6GjdHI+9hKzahmZ1WICKZ 3LQ4GmwBJqHdIQX61E9DmwOr8aZ7jWWP6h4jgM+cvz1SjlUK8WRedNNet5KTr1hIyqvm y/lA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=YnT5KUZyywVC1OYqCipC5UVcoWzzyPy6dPk9wFLz+II=; b=DAO8V729ANGB5rG3TTKTGK66yH53kd8OIHxG41rIz4Na556dJu2S9ydk5Ti0oKZj8R hEP/dL49u/eIirZN6amKk1NUnXfNykWrhviMwLfEdC5oOP6s5xdq5zrW+8vWGV19p9An Rvnhhw3HepB9SGJN+kci09JxErNEJALYO71fcsIqsM/cGL7GR0jc5zpC7j3AOwym28n3 arExSD0OA1ih8uawcViE3g07kJY4xmotzp5GRKRUXVLRHYvNdgHu2OpchIfPzBAWgXO0 7MypgG3QHDtoR3NdrFsi6M0dT66RQpPuJf1kFrn74AjcPa7LVGiDMNQ7hyINqOJ+d0cr XPng== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=WPpzahhJ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 4si8316319ejj.133.2021.09.13.16.10.42; Mon, 13 Sep 2021 16:11:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=WPpzahhJ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1346747AbhIMOja (ORCPT + 99 others); Mon, 13 Sep 2021 10:39:30 -0400 Received: from mail.kernel.org ([198.145.29.99]:53786 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1344574AbhIMOdw (ORCPT ); Mon, 13 Sep 2021 10:33:52 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 7C1B661BB1; Mon, 13 Sep 2021 13:52:44 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1631541165; bh=x0NJmNBpyU3laTS5E8kyiwcrKoQ/viyrT+AH9vqMvzI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=WPpzahhJFOiiZd9grtevEk2CQgj1KmmIXpPf/AiCGR+RTEE9a+aOHByPry8LGYK3D n/HOmwMeX02+2X6nHNsitMTuV48mrcRs3P/2Pc4zf0s3cIbH/4bEfrE1m0mtdzryCr 4YjAKgwUlm98PR7+n6E4hJnxdZAul7vpX0Vva9NE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Syed Nayyar Waris , William Breathitt Gray , Jonathan Cameron , Sasha Levin Subject: [PATCH 5.14 189/334] counter: 104-quad-8: Return error when invalid mode during ceiling_write Date: Mon, 13 Sep 2021 15:14:03 +0200 Message-Id: <20210913131119.743797713@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210913131113.390368911@linuxfoundation.org> References: <20210913131113.390368911@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: William Breathitt Gray [ Upstream commit 728246e8f7269ecd35a2c6e6795323e6d8f48db7 ] The 104-QUAD-8 only has two count modes where a ceiling value makes sense: Range Limit and Modulo-N. Outside of these two modes, setting a ceiling value is an invalid operation -- so let's report it as such by returning -EINVAL. Fixes: fc069262261c ("counter: 104-quad-8: Add lock guards - generic interface") Acked-by: Syed Nayyar Waris Signed-off-by: William Breathitt Gray Link: https://lore.kernel.org/r/a2147f022829b66839a1db5530a7fada47856847.1627990337.git.vilhelm.gray@gmail.com Signed-off-by: Jonathan Cameron Signed-off-by: Sasha Levin --- drivers/counter/104-quad-8.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/drivers/counter/104-quad-8.c b/drivers/counter/104-quad-8.c index 09a9a77cce06..81f9642777fb 100644 --- a/drivers/counter/104-quad-8.c +++ b/drivers/counter/104-quad-8.c @@ -715,12 +715,13 @@ static ssize_t quad8_count_ceiling_write(struct counter_device *counter, case 1: case 3: quad8_preset_register_set(priv, count->id, ceiling); - break; + mutex_unlock(&priv->lock); + return len; } mutex_unlock(&priv->lock); - return len; + return -EINVAL; } static ssize_t quad8_count_preset_enable_read(struct counter_device *counter, -- 2.30.2