Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp698588pxj; Wed, 2 Jun 2021 09:11:42 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy8XbkESXF699g1EJ7umUoI/z3tonsavzsCxkb2q4g5dPVovdYjvqKkP+OUSkgNTh06E2EE X-Received: by 2002:a05:6402:26ce:: with SMTP id x14mr3725506edd.104.1622650302112; Wed, 02 Jun 2021 09:11:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622650302; cv=none; d=google.com; s=arc-20160816; b=AaFx2tzYOxmmQNCk1AsW1iCyvreH9CWw3eEEpREEvi1Gh4F9p+aRNTKdGbSVSlo2Gy w1juzC3jDckXtvB7HyAZe30txHatVQ5IEfZSOC4AuTAhbTeu4w1cMv2c0PVl2Oi9O0Kr CHtzqwH8AY0hvIdlFvQcx7xqfmvL1LZ7NYIHEpGC3+PQUVPDllIBM4bzjNiPX3P8WkHR kv56+G6bV+xMFc6TFKbIAhwgUYJLnDmZWbt2I+MJPaUfj3OiO15NgbwMv5XTeAm9Wx23 599hXNKt3tYfXspl3lVBt2mlbylSmVEvHI4W1zaJsAQ1ODg720kOtyRHxzWBBfAyEsfe +3pA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=00FJaG50XVybrLxTgaOirYOyRTShfFO1O2a+od/tNDw=; b=JAkzqo7v1WUPY+2XojgqVgbnp37lSrcg1dznvU/9ey1Jt3OADEMRAwvqKkdaH3iGI8 LsdWENi9KHtO815IK89FoKKmmzGFbz20hRX//q2XzIyJrExpbK+QCIeYEfaFfSvLVEmk LfXRgsscVj+B0RyqHxHo0d0DtmL61EZ751yQDc7oCV9secb+pI+9/ofavlMpeqrmEkzx tOX/hTjDpQ0NmZx7W8DSuN0PPszZhziJN/LbKZGtKPxWNprZhQoOxTI5F/LIrAojlk8z x8x+zc/AobFY7VmeJnLM5jREIUfGnPh2ZSs8doga8gQaMY2MpXbSE7IhJDvPE5SqiIEz j1rg== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id c11si280316edy.550.2021.06.02.09.11.18; Wed, 02 Jun 2021 09:11:42 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229916AbhFBQKn (ORCPT + 99 others); Wed, 2 Jun 2021 12:10:43 -0400 Received: from foss.arm.com ([217.140.110.172]:48786 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229607AbhFBQKn (ORCPT ); Wed, 2 Jun 2021 12:10:43 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id DC5F012FC; Wed, 2 Jun 2021 09:08:59 -0700 (PDT) Received: from bogus (unknown [10.57.72.241]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 7E5D13F73D; Wed, 2 Jun 2021 09:08:57 -0700 (PDT) Date: Wed, 2 Jun 2021 17:08:53 +0100 From: Sudeep Holla To: Cristian Marussi Cc: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, james.quinlan@broadcom.com, Jonathan.Cameron@Huawei.com, f.fainelli@gmail.com, etienne.carriere@linaro.org, Sudeep Holla , vincent.guittot@linaro.org, souvik.chakravarty@arm.com Subject: Re: [PATCH v2 1/5] firmware: arm_scmi: reset_rx_to_maxsz during async commands Message-ID: <20210602160853.mui3xdr7v4cmmwn2@bogus> References: <20210601102421.26581-1-cristian.marussi@arm.com> <20210601102421.26581-2-cristian.marussi@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210601102421.26581-2-cristian.marussi@arm.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jun 01, 2021 at 11:24:17AM +0100, Cristian Marussi wrote: > During an async commands execution the rx buffer len is at first set to > max_msg_sz when the synchronous part of the command is first sent; once > the synchronous part completes the transport layer waits for the delayed > response which will be processed using the same xfer descriptor initially > allocated, but synchronous response received at the end of the xfer will > have shrunk the rx buffer len to the effective payload response length. > > Raise the rx buffer length again to max_msg_sz while waiting for the > delayed response, while adding an informational error message. > > Fixes: 58ecdf03dbb9 ("firmware: arm_scmi: Add support for asynchronous commands and delayed response") > Signed-off-by: Cristian Marussi > --- > drivers/firmware/arm_scmi/driver.c | 12 ++++++++++-- > 1 file changed, 10 insertions(+), 2 deletions(-) > > diff --git a/drivers/firmware/arm_scmi/driver.c b/drivers/firmware/arm_scmi/driver.c > index 66eb3f0e5daf..75141b90ae53 100644 > --- a/drivers/firmware/arm_scmi/driver.c > +++ b/drivers/firmware/arm_scmi/driver.c > @@ -513,8 +513,16 @@ static int do_xfer_with_response(const struct scmi_protocol_handle *ph, > xfer->async_done = &async_response; > > ret = do_xfer(ph, xfer); > - if (!ret && !wait_for_completion_timeout(xfer->async_done, timeout)) > - ret = -ETIMEDOUT; > + if (!ret) { > + /* rx.len would have been shrunk in the sync do_xfer above */ > + reset_rx_to_maxsz(ph, xfer); Won't this race with delayed response notification ? I think so, let me know if not and how. Can't we have this before we fetch the response into xfer ? -- Regards, Sudeep