Received: by 10.213.65.68 with SMTP id h4csp539115imn; Tue, 13 Mar 2018 12:18:14 -0700 (PDT) X-Google-Smtp-Source: AG47ELtuzXvdewPH9t2Ab9jJPnLEw6YyvRaPsrSEXf+l92w9MGjiPwrthVA+MUthaDk7XoJMPifc X-Received: by 2002:a17:902:7291:: with SMTP id d17-v6mr89896pll.65.1520968694681; Tue, 13 Mar 2018 12:18:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1520968694; cv=none; d=google.com; s=arc-20160816; b=eQvBcHyJ7mi5H5/0OwJYYd/3I4kFXEI+L5rQjjpFVwW9hljTBTG+m6lxm7Kqnx6AKd uumVbfvh9l/5i3E1l2bndhi9L1qbiR4NOWiC3Q67cKY45aGsQKCXXpyHKnFwAaqtISUg Qq1pLocAiBPkXVOS5pasVpxHl/RZi4Gm1XVtTZ0OjYQwCTx+Sks3T64BIMR3UswPNiAl exWEQHp0Kqf6QXTVpHPrDMnkmJWR6F322r8e4pe+/Z4kryB2093L2BiHyUJ0Z3TgyJ8J wJmsaJkjQVkX4zNJVWqaQGqWn2GkKnk5XWxm9oK7bLlObUxA61GowlHgirzQS/KITlbx Kcgg== 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 :content-language:mime-version:user-agent:date:message-id:subject :from:cc:to:arc-authentication-results; bh=uQIf1s+UeCYeaQRzRhtC7wMXdCR+GhDnGJ60Xw2In7w=; b=Gz9p+4UdnnyB3w0u7KncQLD+S3f387H5CdhVYFTqZVeOeG34aeumPaQWC4KJ4ftbgu 9VeAqnFRm6vHR1ahAB6ng4CgbGUjYDv7pel7Nv2c8VOpVLmoudax7Rh2JIHP50aR2G77 lMaVY68/iW7t4h6u24Ie/aefQpnWqCcu6ARGjmIMdLmuKUHdSHj/7TjnaWlcRWfSWr8O PahhCxFqZPyufSSvNWMetUzaolgKC9pA/8ngv6oOnfyyR3b0feye4vrNroFr3XC6rVoD 9QSzVVixWAFkQ2DOryvtftZCGtS6hibznwHRXcoXkxkSnUBkYiuorfzeCQ70jfq1vcbs pd9Q== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=QUARANTINE sp=NONE dis=NONE) header.from=sourceforge.net Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e8si544744pgn.116.2018.03.13.12.17.58; Tue, 13 Mar 2018 12:18:14 -0700 (PDT) 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; 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; dmarc=fail (p=QUARANTINE sp=NONE dis=NONE) header.from=sourceforge.net Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752616AbeCMTQ6 (ORCPT + 99 others); Tue, 13 Mar 2018 15:16:58 -0400 Received: from mout.web.de ([212.227.17.11]:33983 "EHLO mout.web.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751997AbeCMTQz (ORCPT ); Tue, 13 Mar 2018 15:16:55 -0400 Received: from [192.168.1.2] ([77.181.227.194]) by smtp.web.de (mrweb101 [213.165.67.124]) with ESMTPSA (Nemesis) id 0LwYwF-1eZklE1gch-018GIP; Tue, 13 Mar 2018 20:16:31 +0100 To: linux-iio@vger.kernel.org, Hartmut Knaack , Jonathan Cameron , Lars-Peter Clausen , Michael Hennerich , Peter Meerwald-Stadler Cc: LKML , kernel-janitors@vger.kernel.org From: SF Markus Elfring Subject: [PATCH] iio/adc/ad7291: Improve unlocking of a mutex in ad7291_read_raw() Message-ID: Date: Tue, 13 Mar 2018 20:16:27 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 7bit X-Provags-ID: V03:K0:IftT0/FB8vm1TNcxmuG/gpWMqlg9vvVG5y84y9DhSi6JQf575c6 eX6OEU/hhzElt2Q2zJl3KQpuiEucjtEEkY4lWOIpDTog+pAL4vJ++qCF+S52NTry1E7LzKl qVEVEAdvC/sm1y/Wy3sJtk0Uy1AUaYrqaUs615D3DZj5Av7pG6smtoHqLpo54ySQirNbwBI 67n+pv6GVvNx0azcwdd9g== X-UI-Out-Filterresults: notjunk:1;V01:K0:/xEKgIh2J4A=:0iU/9GmaEazpIr+/SK6a9T tGi6jUZpBsCRrqNbt+wXHnoEIMP5pi7fowyRZGU80IuMlexwaHot9aPRPpNxhILRCrNJTarci /D0wfXg55AIMrk3JO8dgdvGvFULkH0xTrkWNv+U+OZ9uk9Wwwp7Q55JfHL5qNQaqfRDWfII9f yoiLWb9Ppv3Y4WqapbTnbCZmpkqKNY+BeS+jHdfxA05rRwji+/w6CdilyL6pSRuz08DM71hJn Xt2zF11XigLLZB4xiyUy+6FtOc6Y88hEEb6nZhB2q/qcicZ3IO8abrmjskgrTUZ7J/W+4wbjD dUTgazSggptxNiyaerUEHnAIwey+1yGq+fx2ypvbtK8LSuouc20xYHPuC+P/cTBnj/3Ruidt7 VAgXwKxcSQ5wCZpSNSyNiNmgxn6P6z/+IQw4BNUxl9XVq6TyOADTbUr6ZkId5cGRqDw3OtQ8O zW4jTOLvimMAE51NEvJx0qMZXHlCRXYi1NKnQwXsDvLi4C6N6EzxZbLDKfVRGUuFq5R68iLTN /xFa+XxVgOw3/K0s93InNnzF0HBPuKKpc/ZyiKlM/JdeKyL4PWOI12uwsFkzeda7fdubJUGNn dXN+84RzVV/L2L6PlM/odm3QAAS1oytx14Gb/ifEY5PfEo2yF860cWrE+BySmqadwG5ZnZeX1 CZH6256NkTJNst+HvMOHhzAwfPJcTnUGPo89DiDf3rX7KgO3TCsAybpsgOEh4nWKi8/n2w5tX PDT+E+dNazotlI9iGk8qc7Nwiimg1M587dD1BodcaZv4ce0Yp/O3FF+0JEu5cZt0trxjRGWS2 THCHutOR4WL5vo9CFyWlnfItd/Thxl5FY8Qwif10eptyrC0Ad4= Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Markus Elfring Date: Tue, 13 Mar 2018 20:08:40 +0100 * Add a jump target so that a call of the function "mutex_unlock" is stored only once in this function implementation. * Replace three calls by goto statements. This issue was detected by using the Coccinelle software. Signed-off-by: Markus Elfring --- drivers/iio/adc/ad7291.c | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/drivers/iio/adc/ad7291.c b/drivers/iio/adc/ad7291.c index a862b5d8fb4b..b2c3d4c79909 100644 --- a/drivers/iio/adc/ad7291.c +++ b/drivers/iio/adc/ad7291.c @@ -335,27 +335,27 @@ static int ad7291_read_raw(struct iio_dev *indio_dev, mutex_lock(&chip->state_lock); /* If in autocycle mode drop through */ if (chip->command & AD7291_AUTOCYCLE) { - mutex_unlock(&chip->state_lock); - return -EBUSY; + ret = -EBUSY; + goto unlock; } /* Enable this channel alone */ regval = chip->command & (~AD7291_VOLTAGE_MASK); regval |= BIT(15 - chan->channel); ret = ad7291_i2c_write(chip, AD7291_COMMAND, regval); - if (ret < 0) { - mutex_unlock(&chip->state_lock); - return ret; - } + if (ret < 0) + goto unlock; + /* Read voltage */ ret = i2c_smbus_read_word_swapped(chip->client, AD7291_VOLTAGE); - if (ret < 0) { - mutex_unlock(&chip->state_lock); - return ret; - } + if (ret < 0) + goto unlock; + *val = ret & AD7291_VALUE_MASK; + ret = IIO_VAL_INT; +unlock: mutex_unlock(&chip->state_lock); - return IIO_VAL_INT; + return ret; case IIO_TEMP: /* Assumes tsense bit of command register always set */ ret = i2c_smbus_read_word_swapped(chip->client, -- 2.16.2