Received: by 2002:ab2:3141:0:b0:1ed:23cc:44d1 with SMTP id i1csp191063lqg; Fri, 1 Mar 2024 02:09:05 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCXcG5oIGXquKDnmH1GV0luOUEo01lWqVZEEYYORbPYe5bRMhSk441iGxdZCOa4bRJXSJoHfD5ql4FL0nkbvcysQeIxbEGrvLKLhy5KPIw== X-Google-Smtp-Source: AGHT+IGbmziWco2Odv2CTFKBESQJl5lbObzDmjpU+IXJbH6qCSsdnMesgUiGFbed6dQTgCdxAzn7 X-Received: by 2002:a05:620a:563a:b0:787:ee99:ed68 with SMTP id vv26-20020a05620a563a00b00787ee99ed68mr1257909qkn.19.1709287745281; Fri, 01 Mar 2024 02:09:05 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1709287745; cv=pass; d=google.com; s=arc-20160816; b=RG8aK9TW7iI7Tum1jU5aHaH2sgT3kASHT+CACYq/lm3/1Omyv1L+jkl0lcPnJBTHEn QgKo62o+HJQ3AQiLIaXBiQ1NNe7cDPc145cx/4csIEmWCttl8V2hQLpPoBaT4PbEDDPJ 7C0q5if/3Y31Yb09aMkZwXwIcKTF82vuXu8ysc4nFX9gxOxaI/Z49QMUqqYOhMi7+2j5 3gkhLx4R22AxiKY/pLvaKfVbzqctZAz+njshhfcIAc3GuL4d+dO8XOJ72xDNRLIdmMA6 K6qGOnoXdJsQGYRMY6jPBS68lktdrbvigVpqg3hH9AfAFh3BcAvx1NcsFakRiCzRmY0f T3gQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=mime-version:list-unsubscribe:list-subscribe:list-id:precedence :user-agent:content-transfer-encoding:references:in-reply-to:date:cc :to:from:subject:message-id; bh=rTWf1LVHlLIpHTmNeBI0/GyDCi9OAHymj39qoI6T+AQ=; fh=wgniu3v607Ez9rusKwP0JFlBtDUJr0oEz2/a/ocaNJQ=; b=bdts77vNJ8xEXPF1Vp+BUxtAYRJ5xqBS4B/ZzyNRGFvs8t+54FXfVqV9pC/ShpmmS5 hPDuSEkz3vmnulf3p0v77ISdtIrWaHW3vJoxNrLDHuTzygfJ1hH0Ud0hG04E2uAQYPnt 1RwQMcMiIHaQme/GTXNg+W38JCEC4MKXr/03HrvqJ8L0n9psE2st3TRo9yKMPnz0PKZF QhL2xMsHLCDOq3jXWgnSntJD94As64xjBig19F9X8i1Tbe5WOH4XHKAiA4oounAeyf5R LJjJnYefYBGX4nK+2OSaHOg24blOfZ54768s3WD0w0qstk87U4C8mLtIxIyvq0tSTm14 hDQA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=pengutronix.de); spf=pass (google.com: domain of linux-kernel+bounces-88238-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-88238-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id m8-20020ae9e008000000b00787329ed629si3206427qkk.423.2024.03.01.02.09.05 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 01 Mar 2024 02:09:05 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-88238-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=pengutronix.de); spf=pass (google.com: domain of linux-kernel+bounces-88238-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-88238-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 078D91C223A2 for ; Fri, 1 Mar 2024 10:09:05 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 6919C6A8C8; Fri, 1 Mar 2024 10:09:00 +0000 (UTC) Received: from metis.whiteo.stw.pengutronix.de (metis.whiteo.stw.pengutronix.de [185.203.201.7]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 79530482C1 for ; Fri, 1 Mar 2024 10:08:58 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=185.203.201.7 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709287739; cv=none; b=hVfWH0gODu8g81pTf/SiW/I2+2KeD5GyzmvJvcwMxbF4V13ADRzAe71gIME5EsLwJaqRK0dlyjwvbBje5vZ9j2NGm0Fis2c2pBIuionNybBieR83A97kphfYhl2D3llx8HvH1uIzoFG/Ezq+ofRoiBf7A0priFLhJpk1EiV9S+Y= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709287739; c=relaxed/simple; bh=cfhI4adbzcjp8NkNHtD4wblqg/sRFVZlM616n37Agb0=; h=Message-ID:Subject:From:To:Cc:Date:In-Reply-To:References: Content-Type:MIME-Version; b=dNWtELLYycd2fOaZL8VZiclHA/mwlEQserEvwV52u58wwXEnUNHWgk/cOLfsVD8P+ydwQgcVhr4v+AzGBo87nEYIYrc88pheIOvsstNAWRx7nxPOrxdYdkyVlVLP/kYdETlu9VYRDBE7rsTDbChsyFCInzbfBObrppAz+NLthHw= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=pengutronix.de; spf=pass smtp.mailfrom=pengutronix.de; arc=none smtp.client-ip=185.203.201.7 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=pengutronix.de Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=pengutronix.de Received: from ptz.office.stw.pengutronix.de ([2a0a:edc0:0:900:1d::77] helo=[IPv6:::1]) by metis.whiteo.stw.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1rfzou-00053s-Tf; Fri, 01 Mar 2024 11:08:48 +0100 Message-ID: <2d65be7ae251221bd7524871e0cbf4b22d16a9f9.camel@pengutronix.de> Subject: Re: [PATCH] etnaviv: Restore some id values From: Lucas Stach To: Christian Gmeiner , Russell King , David Airlie , Daniel Vetter Cc: Christian Gmeiner , stable@vger.kernel.org, etnaviv@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Date: Fri, 01 Mar 2024 11:08:48 +0100 In-Reply-To: <20240229195532.7815-1-christian.gmeiner@gmail.com> References: <20240229195532.7815-1-christian.gmeiner@gmail.com> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable User-Agent: Evolution 3.48.4 (3.48.4-1.fc38) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-SA-Exim-Connect-IP: 2a0a:edc0:0:900:1d::77 X-SA-Exim-Mail-From: l.stach@pengutronix.de X-SA-Exim-Scanned: No (on metis.whiteo.stw.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Hi Christian, prefix for etnaviv kernel patches should be "drm/etnaviv: ..." Am Donnerstag, dem 29.02.2024 um 20:55 +0100 schrieb Christian Gmeiner: > From: Christian Gmeiner >=20 > The hwdb selection logic as a feature that allows it to mark some fields > as 'don't care'. If we match with such a field we memcpy(..) > the current etnaviv_chip_identity into ident. >=20 > This step can overwrite some id values read from the GPU with the > 'don't care' value. >=20 > Fix this issue by restoring the affected values after the memcpy(..). >=20 > As this is crucial for user space to know when this feature works as > expected increment the minor version too. Uh, right. Lying to userspace about the GPU identity doesn't seem like a good idea. >=20 > Fixes: 4078a1186dd3 ("drm/etnaviv: update hwdb selection logic") > Cc: stable@vger.kernel.org > Signed-off-by: Christian Gmeiner > --- > drivers/gpu/drm/etnaviv/etnaviv_drv.c | 2 +- > drivers/gpu/drm/etnaviv/etnaviv_hwdb.c | 14 ++++++++++++++ > 2 files changed, 15 insertions(+), 1 deletion(-) >=20 > diff --git a/drivers/gpu/drm/etnaviv/etnaviv_drv.c b/drivers/gpu/drm/etna= viv/etnaviv_drv.c > index 6228ce603248..9a2965741dab 100644 > --- a/drivers/gpu/drm/etnaviv/etnaviv_drv.c > +++ b/drivers/gpu/drm/etnaviv/etnaviv_drv.c > @@ -494,7 +494,7 @@ static const struct drm_driver etnaviv_drm_driver =3D= { > .desc =3D "etnaviv DRM", > .date =3D "20151214", > .major =3D 1, > - .minor =3D 3, > + .minor =3D 4, > }; > =20 > /* > diff --git a/drivers/gpu/drm/etnaviv/etnaviv_hwdb.c b/drivers/gpu/drm/etn= aviv/etnaviv_hwdb.c > index 67201242438b..1e38d66702f1 100644 > --- a/drivers/gpu/drm/etnaviv/etnaviv_hwdb.c > +++ b/drivers/gpu/drm/etnaviv/etnaviv_hwdb.c > @@ -265,6 +265,9 @@ static const struct etnaviv_chip_identity etnaviv_chi= p_identities[] =3D { > bool etnaviv_fill_identity_from_hwdb(struct etnaviv_gpu *gpu) > { > struct etnaviv_chip_identity *ident =3D &gpu->identity; > + const u32 product_id =3D ident->product_id; > + const u32 customer_id =3D ident->customer_id; > + const u32 eco_id =3D ident->eco_id; > int i; > =20 > for (i =3D 0; i < ARRAY_SIZE(etnaviv_chip_identities); i++) { > @@ -278,6 +281,17 @@ bool etnaviv_fill_identity_from_hwdb(struct etnaviv_= gpu *gpu) > etnaviv_chip_identities[i].eco_id =3D=3D ~0U)) { > memcpy(ident, &etnaviv_chip_identities[i], > sizeof(*ident)); > + > + /* Restore some id values if ~0U aka 'don't care' is used. */ > + if (etnaviv_chip_identities[i].product_id =3D=3D ~0U) You can drop all those if clauses. Either the hwdb value is an exact match and the value is the same or it's the don't care value and you want to restore it, so a simple unconditional assignment would make this a bit more compact. Regards, Lucas > + ident->product_id =3D product_id; > + > + if (etnaviv_chip_identities[i].customer_id =3D=3D ~0U) > + ident->customer_id =3D customer_id; > + > + if (etnaviv_chip_identities[i].eco_id =3D=3D ~0U) > + ident->eco_id =3D eco_id; > + > return true; > } > }