Received: by 2002:a05:6a10:a841:0:0:0:0 with SMTP id d1csp85358pxy; Tue, 20 Apr 2021 13:15:43 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy/4GQEZS0LI/1k2GWaEdqomABAKpFbG71uW/gB8ledbrZHgS8iWzSbg2Bxzu68W8BpqWH2 X-Received: by 2002:a62:1c0f:0:b029:25f:ba3c:9cc0 with SMTP id c15-20020a621c0f0000b029025fba3c9cc0mr11525670pfc.56.1618949743007; Tue, 20 Apr 2021 13:15:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618949742; cv=none; d=google.com; s=arc-20160816; b=uOrievkFnqkHVZ/Rmv5xv58sjBqQoSonUs6i+t8D5UQv2XgK48hx0kDV30F2/Kqjh9 f64BIauMmGDBaaU4foMQlj1YAXJEaSD/0bizD+i/G3QLTbTTq0XVRpFHT/VfrK+JMuI6 r7x29UUMd4RN6ERBcO+Ll94rsLL1tS2wkiaaiftcRwXRcuoHf6haV42dz7iXJWoHDuqf N9svOigSiZ+4FE/tYLcYaVvq+WYfiS652mBJU4q+NnnupLiF/MNqOLKSlNNCzcshIWRG FJQ7lTZLADZeXgnipqZUr71te6v1/kI2BVV0Y60jeUDM7m/v/SDOfBhsb6fWhc0qInWn nHsA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=1agkcJndQTmYSgxVSkfvxBlGoG29GS+1hi+mtCQvy/Y=; b=XaQ/5YWVnTKyEAFBmBvSuSnjQFcWWYIkP2fGDDh5Us9J+/JEj6YaoBPlpVg5OWOHrl KIGYmTm7aJ8WtoYU6h+PGssL9yvbe6AqCniSOK3jhCnJhmtS6Nb7vc/DTrGuoZ5UGYb8 1jjv+1e6JORIuCJ1T2mD88OrCiHhYtYqLN2XKq/PeafZ1V8yqsV7NNGl7xyvyBdASZun OtIsRT33gutK6h00lsEiXavgzMNutvkqDnR6vuy/tEnm3B5biz8L31q4UQwGY3cMRCKS w2s6qymPo/ePT+7PvOPYUk0OQuaHttN3j6kSS4SF03P1TeUg7YzqtQnARkYWJOKK5T8K CN5A== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o12si100879pgf.375.2021.04.20.13.15.30; Tue, 20 Apr 2021 13:15: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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233891AbhDTUNl (ORCPT + 99 others); Tue, 20 Apr 2021 16:13:41 -0400 Received: from jabberwock.ucw.cz ([46.255.230.98]:40030 "EHLO jabberwock.ucw.cz" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233619AbhDTUNk (ORCPT ); Tue, 20 Apr 2021 16:13:40 -0400 Received: by jabberwock.ucw.cz (Postfix, from userid 1017) id 215411C0B80; Tue, 20 Apr 2021 22:13:06 +0200 (CEST) Date: Tue, 20 Apr 2021 22:13:05 +0200 From: Pavel Machek To: Greg Kroah-Hartman Cc: linux-kernel@vger.kernel.org, stable@vger.kernel.org, Sanjay Kumar , Dave Jiang , Vinod Koul , Sasha Levin Subject: Re: [PATCH 5.11 007/122] dmaengine: idxd: Fix clobbering of SWERR overflow bit on writeback Message-ID: <20210420201305.GA9942@duo.ucw.cz> References: <20210419130530.166331793@linuxfoundation.org> <20210419130530.423797059@linuxfoundation.org> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="SLDf9lqlvOQaIe6s" Content-Disposition: inline In-Reply-To: <20210419130530.423797059@linuxfoundation.org> User-Agent: Mutt/1.10.1 (2018-07-13) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --SLDf9lqlvOQaIe6s Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable Hi! > Current code blindly writes over the SWERR and the OVERFLOW bits. Write > back the bits actually read instead so the driver avoids clobbering the > OVERFLOW bit that comes after the register is read. I believe this is incorrect. Changelog explains that we need to preserve bits in the register... > diff --git a/drivers/dma/idxd/irq.c b/drivers/dma/idxd/irq.c > index a60ca11a5784..f1463fc58112 100644 > --- a/drivers/dma/idxd/irq.c > +++ b/drivers/dma/idxd/irq.c > @@ -124,7 +124,9 @@ static int process_misc_interrupts(struct idxd_device= *idxd, u32 cause) > for (i =3D 0; i < 4; i++) > idxd->sw_err.bits[i] =3D ioread64(idxd->reg_base + > IDXD_SWERR_OFFSET + i * sizeof(u64)); > - iowrite64(IDXD_SWERR_ACK, idxd->reg_base + IDXD_SWERR_OFFSET); > + > + iowrite64(idxd->sw_err.bits[0] & IDXD_SWERR_ACK, > + idxd->reg_base + IDXD_SWERR_OFFSET); =2E..but that is not what the code does. I suspect it should be=20 > + iowrite64(idxd->sw_err.bits[0] | IDXD_SWERR_ACK, > + idxd->reg_base + IDXD_SWERR_OFFSET); Best regards, Pavel --=20 http://www.livejournal.com/~pavelmachek --SLDf9lqlvOQaIe6s Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iF0EABECAB0WIQRPfPO7r0eAhk010v0w5/Bqldv68gUCYH810QAKCRAw5/Bqldv6 8kEaAJ4hgBh3lQTBYyaOPBaM2scS2Bs/ywCdEQL6iQn+iCdKaJJGKFHqVLsaNVk= =Z9jg -----END PGP SIGNATURE----- --SLDf9lqlvOQaIe6s--