Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp3449398imm; Tue, 29 May 2018 07:27:49 -0700 (PDT) X-Google-Smtp-Source: AB8JxZreOHxjsPAZkHIUVPL/gsBU2yvYWmgYNL111cV0HGRfpd9DMg/+iw6z8KCbzv9+SB//Pn1T X-Received: by 2002:a17:902:6847:: with SMTP id f7-v6mr18179778pln.173.1527604069761; Tue, 29 May 2018 07:27:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527604069; cv=none; d=google.com; s=arc-20160816; b=ctDZGyaihB84boRKspV0AL2HCkxjUolmGsHrmB8rXTnqh2mUCv5kkytN5I9wzgKGe0 K3DHvhLQdRiWBBxPVL9A953M/37XljSlLFEoxwztWFXuFDH2RHAr3hhD/YT9NsFeLJF0 ruZX02y2AoCWTwS0hE+YCw1GDeGymR0mIKOp3/oZ2USOUVEaw/dyvqmG0FP4QePa43Zu cbmGoegVcUTXdJeuiAreIAGiH4nYpi0VfRNsMc0Z9HqlVCPtUTK3DX7kZYuDIDESL/Xy 5UDpL5+48PD/4Wc5V+XiVwU4k0pyPyL9V4JoPpwvRre77RUwgv+CRiWmssrYX/0izp2X AwEQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=MGrgfflRbxBTooD4SUiN4gkXCwNJ6wCtphwVAJaxJks=; b=W7HtkAg6mZT5lXE2AQdkHnbVFNRJzBk3dhBUdahOEvhufoIrrAmqmrMy1L0eTKuBWm QiHiDSXGGMFyovJV7dXp//BNlsjd6Uefhqs1I1SuUa2IUh0btTViemINcq7LmSMJE6DX HNoNPW0a+KxeAAZwtxOM/pcGRQtLAs2vJoVq+5M6O5Ko/xc9ctrasJ54AjKR4bqkmcdd cql8mA/OOEqR99FyKWzvlHKNa0TnJPek219hXcUBZTYUD8/BEKQqJ4wIrbfh4UxhB2HL bgY88Wr6jnvTzyzAX6K9WKctLzofK3O4MWpXbrGdV1zBSo/gfN44jHenT9eaXqadv7Tp JbZQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 128-v6si25819355pgb.176.2018.05.29.07.27.36; Tue, 29 May 2018 07:27:49 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S935244AbeE2O0c (ORCPT + 99 others); Tue, 29 May 2018 10:26:32 -0400 Received: from smtp4.ccs.ornl.gov ([160.91.203.40]:38208 "EHLO smtp4.ccs.ornl.gov" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S934917AbeE2OW1 (ORCPT ); Tue, 29 May 2018 10:22:27 -0400 Received: from star.ccs.ornl.gov (star.ccs.ornl.gov [160.91.202.134]) by smtp4.ccs.ornl.gov (Postfix) with ESMTP id E21F410052C7; Tue, 29 May 2018 10:22:06 -0400 (EDT) Received: by star.ccs.ornl.gov (Postfix, from userid 2004) id E01152C1; Tue, 29 May 2018 10:22:06 -0400 (EDT) From: James Simmons To: Greg Kroah-Hartman , devel@driverdev.osuosl.org, Andreas Dilger , Oleg Drokin , NeilBrown Cc: Linux Kernel Mailing List , Lustre Development List , Amir Shehata , James Simmons Subject: [PATCH v2 12/25] staging: lustre: libcfs: invert error handling for cfs_cpt_table_print Date: Tue, 29 May 2018 10:21:52 -0400 Message-Id: <1527603725-30560-13-git-send-email-jsimmons@infradead.org> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1527603725-30560-1-git-send-email-jsimmons@infradead.org> References: <1527603725-30560-1-git-send-email-jsimmons@infradead.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Amir Shehata Instead of setting rc to -EFBIG for several cases in the loop lets just go to the out label on error which returns -E2BIG directly. Signed-off-by: Amir Shehata Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-7734 Reviewed-on: http://review.whamcloud.com/18916 Reviewed-by: Olaf Weber Reviewed-by: Doug Oucharek Signed-off-by: James Simmons --- Changelog: v1) New patch to replace several patches. Went crazy for the one change per patch approach. drivers/staging/lustre/lnet/libcfs/libcfs_cpu.c | 25 ++++++++++--------------- 1 file changed, 10 insertions(+), 15 deletions(-) diff --git a/drivers/staging/lustre/lnet/libcfs/libcfs_cpu.c b/drivers/staging/lustre/lnet/libcfs/libcfs_cpu.c index 9ff9fe9..bf41ba3 100644 --- a/drivers/staging/lustre/lnet/libcfs/libcfs_cpu.c +++ b/drivers/staging/lustre/lnet/libcfs/libcfs_cpu.c @@ -190,29 +190,26 @@ struct cfs_cpt_table * cfs_cpt_table_print(struct cfs_cpt_table *cptab, char *buf, int len) { char *tmp = buf; - int rc = 0; + int rc; int i; int j; for (i = 0; i < cptab->ctb_nparts; i++) { - if (len > 0) { - rc = snprintf(tmp, len, "%d\t:", i); - len -= rc; - } + if (len <= 0) + goto out; + + rc = snprintf(tmp, len, "%d\t:", i); + len -= rc; - if (len <= 0) { - rc = -EFBIG; + if (len <= 0) goto out; - } tmp += rc; for_each_cpu(j, cptab->ctb_parts[i].cpt_cpumask) { rc = snprintf(tmp, len, "%d ", j); len -= rc; - if (len <= 0) { - rc = -EFBIG; + if (len <= 0) goto out; - } tmp += rc; } @@ -221,11 +218,9 @@ struct cfs_cpt_table * len--; } - out: - if (rc < 0) - return rc; - return tmp - buf; +out: + return -E2BIG; } EXPORT_SYMBOL(cfs_cpt_table_print); -- 1.8.3.1