Received: by 2002:a25:e7d8:0:0:0:0:0 with SMTP id e207csp1451398ybh; Fri, 13 Mar 2020 01:18:22 -0700 (PDT) X-Google-Smtp-Source: ADFU+vtSnTcI5WVIQEViQ3gfvaZXslqPpypBOPz74vuvCdbCDp8T30rH3m1rDFAEuZBhEbnALb4B X-Received: by 2002:a05:6808:d7:: with SMTP id t23mr6004221oic.69.1584087501900; Fri, 13 Mar 2020 01:18:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584087501; cv=none; d=google.com; s=arc-20160816; b=g+EGcYGCB/AjKpbLAmxt9KKyw8VPN8P/HF2tsbWXJr3E4TlDyxdMgBthkfT1O3Kqgc ZhTVIp5rbT/OUIg4t5+GNixvIyk935Xr4u3JzG4PLOaN5EtJx8sVJszx32q731CcGyRj fAXbX3Ma8nwlBBa0kX8F/qG6EJJvDYopS2sM3JpsyTGWZmKNE+Tn5B2iB7W+PHCDAPlg V31f/c3zX7m8Zg23GD5UrPkNzo/fdqjYBAnEPMMcSbzcfJ3f0pgDMf9xs1P8ZJoL86/3 ldL4B7xx0P8z0Flb5iDWu8mxsiSF9fcJAV7n/3dWVJ/8bnQeQ9gdFvtuTZuDTJuNeg6R asbQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:dkim-signature; bh=SLdw2vgatE17/Hia3A70cAESnROgW6CNX2mOqTF12SM=; b=mRaEmKcTgOBw1fLNlMhA/ada4Oy7UeqWcnhOHHPbpYbd2OTvXRqMCYn+eqCvIaoQPX enjci7pl+jidXgbolYJh/8YcD4OZp6FpGwEJZKm+ddErrKVF+EQ3qEDNd+dqo7ucjsXV Q8fXceNGz+iJ4tKpC1jKStM3Wluj9XN6eFE1G67RltIigFdM7riDHuXKQQOcMu4FAEP5 nXCFbEuzNutCFSTExTkSNA6S+VlhARnxrdfnj4AdnLttG5bVkcj+g4WrRry1eLaSWvIz z9vU60vxheeoE0Paa6H7KyYh5fR2H6Jxp2msao1/Ugl8uL4cDF3rgrXLC0t8cUaEZj4m h/Gw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=nOJFgzAk; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h125si3811331oia.253.2020.03.13.01.18.02; Fri, 13 Mar 2020 01:18:21 -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; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=nOJFgzAk; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726530AbgCMIRh (ORCPT + 99 others); Fri, 13 Mar 2020 04:17:37 -0400 Received: from fllv0015.ext.ti.com ([198.47.19.141]:42626 "EHLO fllv0015.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726365AbgCMIRh (ORCPT ); Fri, 13 Mar 2020 04:17:37 -0400 Received: from fllv0035.itg.ti.com ([10.64.41.0]) by fllv0015.ext.ti.com (8.15.2/8.15.2) with ESMTP id 02D8Haqu121340; Fri, 13 Mar 2020 03:17:36 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1584087456; bh=SLdw2vgatE17/Hia3A70cAESnROgW6CNX2mOqTF12SM=; h=From:To:CC:Subject:Date:In-Reply-To:References; b=nOJFgzAkOcHQ/fEB/bz7udQ3WZmpHEFZsU8ZLSPf70SFYGayzmFYSGFAlkF86X/91 QMPFQ9ksEk/52tHFftEfLeD4alQK3q1WYtdj3AXLRi0Kzopc2Th8po6diiEN2pICAr 87JeStPPMEm68U1gCpQTGGUBWcBNAEHkTiP9zaTY= Received: from DFLE114.ent.ti.com (dfle114.ent.ti.com [10.64.6.35]) by fllv0035.itg.ti.com (8.15.2/8.15.2) with ESMTP id 02D8HaYx020647; Fri, 13 Mar 2020 03:17:36 -0500 Received: from DFLE100.ent.ti.com (10.64.6.21) by DFLE114.ent.ti.com (10.64.6.35) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1847.3; Fri, 13 Mar 2020 03:17:36 -0500 Received: from localhost.localdomain (10.64.41.19) by DFLE100.ent.ti.com (10.64.6.21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1847.3 via Frontend Transport; Fri, 13 Mar 2020 03:17:35 -0500 Received: from sokoban.bb.dnainternet.fi (ileax41-snat.itg.ti.com [10.172.224.153]) by localhost.localdomain (8.15.2/8.15.2) with ESMTP id 02D8HQlZ097835; Fri, 13 Mar 2020 03:17:34 -0500 From: Tero Kristo To: , , CC: , , , , Tero Kristo Subject: [PATCHv8 03/15] remoteproc/omap: Add a sanity check for DSP boot address alignment Date: Fri, 13 Mar 2020 10:17:06 +0200 Message-ID: <20200313081718.30612-4-t-kristo@ti.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200313081718.30612-1-t-kristo@ti.com> References: <20200313081718.30612-1-t-kristo@ti.com> MIME-Version: 1.0 Content-Type: text/plain X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Suman Anna The DSP remote processors on OMAP SoCs require a boot register to be programmed with a boot address, and this boot address needs to be on a 1KB boundary. The current code is simply masking the boot address appropriately without performing any sanity checks before releasing the resets. An unaligned boot address results in an undefined execution behavior and can result in various bus errors like MMU Faults or L3 NoC errors. Such errors are hard to debug and can be easily avoided by adding a sanity check for the alignment before booting a DSP remote processor. Signed-off-by: Suman Anna Signed-off-by: Tero Kristo Reviewed-by: Bjorn Andersson Reviewed-by: Andrew F. Davis Acked-by: Mathieu Poirier --- v8: - Fixed return value of omap_rproc_write_dsp_boot_addr to properly return the status of the regmap write drivers/remoteproc/omap_remoteproc.c | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/drivers/remoteproc/omap_remoteproc.c b/drivers/remoteproc/omap_remoteproc.c index d47d5ded651a..2020d4e3264d 100644 --- a/drivers/remoteproc/omap_remoteproc.c +++ b/drivers/remoteproc/omap_remoteproc.c @@ -121,14 +121,23 @@ static void omap_rproc_kick(struct rproc *rproc, int vqid) * @rproc: handle of a remote processor * * Set boot address for a supported DSP remote processor. + * + * Return: 0 on success, or -EINVAL if boot address is not aligned properly */ -static void omap_rproc_write_dsp_boot_addr(struct rproc *rproc) +static int omap_rproc_write_dsp_boot_addr(struct rproc *rproc) { + struct device *dev = rproc->dev.parent; struct omap_rproc *oproc = rproc->priv; struct omap_rproc_boot_data *bdata = oproc->boot_data; u32 offset = bdata->boot_reg; - regmap_write(bdata->syscon, offset, rproc->bootaddr); + if (rproc->bootaddr & (SZ_1K - 1)) { + dev_err(dev, "invalid boot address 0x%x, must be aligned on a 1KB boundary\n", + rproc->bootaddr); + return -EINVAL; + } + + return regmap_write(bdata->syscon, offset, rproc->bootaddr); } /* @@ -145,8 +154,11 @@ static int omap_rproc_start(struct rproc *rproc) int ret; struct mbox_client *client = &oproc->client; - if (oproc->boot_data) - omap_rproc_write_dsp_boot_addr(rproc); + if (oproc->boot_data) { + ret = omap_rproc_write_dsp_boot_addr(rproc); + if (ret) + return ret; + } client->dev = dev; client->tx_done = NULL; -- 2.17.1 -- Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki