Received: by 2002:ac0:8c9a:0:0:0:0:0 with SMTP id r26csp4364907ima; Mon, 4 Feb 2019 15:18:14 -0800 (PST) X-Google-Smtp-Source: AHgI3IZeRPQhNch52/gjrf+ogVY421wy5mkB4KwN1czB4+DjFwVHeU+sPHV+P9B3H/3leYwUt/jt X-Received: by 2002:a63:e249:: with SMTP id y9mr1689798pgj.395.1549322294740; Mon, 04 Feb 2019 15:18:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549322294; cv=none; d=google.com; s=arc-20160816; b=EnbCiZTXX7J2EkNSxyAjaj0xpULJVvr/uMULFK/nkgtyJfVS45jZ6lficFja9n/hDF TukrCh3dB9SGYlRRPItUiWg40AYR0ddRRCdFwPKjNEl3dTlY0hfYqof3kj/oBAJqCeRY 0dnC1gubj92O4hJbL2U6lA/CSltyWiHfdU8CwHslDNbPZfaxGZZFTAsN57Sn0cuwubq6 oIaFwCbo63wv8/g5+aSbd2JstKO7KPommJgWz73zck3WUgrdTp8vmNEuRu6eznWZvw2i hGlHWZxGt6qHfTBAKhMWPH8TZo7YakrpizYyN/DY5rCuX9OJwfkNVb3m3tn2ri/xBdue VFzQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :message-id:in-reply-to:subject:cc:to:from:date:dkim-filter :dkim-signature; bh=XMJ6BiXNSnDlZAGeoVO4B3QPvI+zIZtIb54q/F4HDjg=; b=DHXifZDfAcmMa/zvxlHlD+Qq0vkHw4u59dUI5YHvvzpA3EeFDCRcjHtWQ/0Oi9GNv/ 5HzKQO57JXwFbO3zq4vWC55OndjF+SizZF7r2F+xGRQ800+HU1cPR/6HVFArvQyVFJ9d Nio8JXEdVX9DS4jOhtUZ3YjriJWCtQUyR0PWZi7xH3Gs90ysuyNTjNcJsogkfBOB1gNY ug7JfmDHbFdeCJVsYjrotANYXaCmlgD9pL0pOTBk08DMoPe6rOJeJ4/c2gAU5B3IiwSE TMJ5KOpO043jmqusn50oA8EMCW+kVmuGjPAXldZxEOcY3sXXFJjCX/GJ/GI8zJdvQmU2 zGEw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@fjfi.cvut.cz header.s=20151024 header.b=KMpDbuDg; 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 p1si1369065pld.353.2019.02.04.15.17.59; Mon, 04 Feb 2019 15:18:14 -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=@fjfi.cvut.cz header.s=20151024 header.b=KMpDbuDg; 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 S1728079AbfBDWoX (ORCPT + 99 others); Mon, 4 Feb 2019 17:44:23 -0500 Received: from mailgw1.fjfi.cvut.cz ([147.32.9.3]:50730 "EHLO mailgw1.fjfi.cvut.cz" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725942AbfBDWoX (ORCPT ); Mon, 4 Feb 2019 17:44:23 -0500 Received: from localhost (localhost [127.0.0.1]) by mailgw1.fjfi.cvut.cz (Postfix) with ESMTP id 520A2AAC03; Mon, 4 Feb 2019 23:44:21 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fjfi.cvut.cz; s=20151024; t=1549320261; i=@fjfi.cvut.cz; bh=XMJ6BiXNSnDlZAGeoVO4B3QPvI+zIZtIb54q/F4HDjg=; h=Date:From:To:cc:Subject:In-Reply-To:References; b=KMpDbuDgB2vaN2HB60ksTcsLlIwj721kF4kDmPsu3yrwuUI/T3+TEF6o/3JjJoooz IBWp/8mAqN0iWKmBgaofi41WKU3duOmeUww3YZj8j/pC4JKn5Cj7BnwNYu1HMYqNFU vwYdCL8yDZlM1amn6MYKZus4O+FIhsma7a3zTvB0= X-CTU-FNSPE-Virus-Scanned: amavisd-new at fjfi.cvut.cz Received: from mailgw1.fjfi.cvut.cz ([127.0.0.1]) by localhost (mailgw1.fjfi.cvut.cz [127.0.0.1]) (amavisd-new, port 10022) with ESMTP id FiRM-O8CFEgJ; Mon, 4 Feb 2019 23:44:18 +0100 (CET) Received: from linux.fjfi.cvut.cz (linux.fjfi.cvut.cz [147.32.5.111]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mailgw1.fjfi.cvut.cz (Postfix) with ESMTPS id 92FD3AA8BC; Mon, 4 Feb 2019 23:44:17 +0100 (CET) DKIM-Filter: OpenDKIM Filter v2.11.0 mailgw1.fjfi.cvut.cz 92FD3AA8BC Received: by linux.fjfi.cvut.cz (Postfix, from userid 1001) id E13926004E; Mon, 4 Feb 2019 23:44:16 +0100 (CET) Received: from localhost (localhost [127.0.0.1]) by linux.fjfi.cvut.cz (Postfix) with ESMTP id D6AE26004D; Mon, 4 Feb 2019 23:44:16 +0100 (CET) Date: Mon, 4 Feb 2019 23:44:16 +0100 (CET) From: David Kozub To: Christoph Hellwig cc: Jens Axboe , Jonathan Derrick , Scott Bauer , linux-block@vger.kernel.org, linux-kernel@vger.kernel.org, Jonas Rabenstein Subject: Re: [PATCH v4 15/16] block: sed-opal: don't repeat opal_discovery0 in each steps array In-Reply-To: <20190204150132.GM31132@infradead.org> Message-ID: References: <1549054223-12220-1-git-send-email-zub@linux.fjfi.cvut.cz> <1549054223-12220-16-git-send-email-zub@linux.fjfi.cvut.cz> <20190204150132.GM31132@infradead.org> User-Agent: Alpine 2.21 (LRH 202 2017-01-01) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 4 Feb 2019, Christoph Hellwig wrote: >> + /* first do a discovery0 */ >> + error = opal_discovery0_step(dev); >> >> + for (state = 0; !error && state < n_steps; state++) >> + error = execute_step(dev, &steps[state], state); >> + >> + /* >> + * For each OPAL command the first step in steps starts some sort of >> + * session. If an error occurred in the initial discovery0 or if an >> + * error occurred in the first step (and thus stopping the loop with >> + * state == 1) then there was an error before or during the attempt to >> + * start a session. Therefore we shouldn't attempt to terminate a >> + * session, as one has not yet been created. >> + */ >> + if (error && state > 1) >> + end_opal_session_error(dev); >> >> return error; > > The flow here is a little too condensed for my taste. Why not the > plain obvoious, if a little longer: > > error = error = opal_discovery0_step(dev); > if (error) > return error; > > for (state = 0; state < n_steps; state++) { > error = execute_step(dev, &steps[state], state); > if (error) > goto out_error; > } > > return 0; > > out_error: > if (state > 1) > end_opal_session_error(dev); > return error; No problem, I can use this version. But I think there is a minor issue - the same one I hit in my original change, just from the other direction: If the loop succeds for the 0-th element of steps, and then fails for the 1st element, then state equals 1 yet the session has been started, so we should close it. I think the condition in out_error should be if (state > 0). Best regards, David