From patchwork Sat May 13 09:47:26 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shameerali Kolothum Thodi X-Patchwork-Id: 99742 Delivered-To: patch@linaro.org Received: by 10.140.96.100 with SMTP id j91csp700132qge; Sat, 13 May 2017 02:52:05 -0700 (PDT) X-Received: by 10.98.34.22 with SMTP id i22mr7841916pfi.103.1494669125400; Sat, 13 May 2017 02:52:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1494669125; cv=none; d=google.com; s=arc-20160816; b=Gvd50BT+J6MgnN2f/H/KWsJbrGVXXsBTgO0qW4iLXILGPgX0rWjVO/E4rcj19WMWfZ a3Y29dmSRq9VHlqJRlXyVrXe0Hpv/M85qRz7UZN+Xm9Txoa/oC6xdqMoT4/zsgp/WQKM dX+t/pfzntiwGxNc+XmnoMgXkHkFrq9iFOP/Vdv6vAl+7KSKVyn6bw2/v0UAOhcOwVG5 klmj1S4RkHOU4CeuoKWa+6FsK9lbT/Qf5+reCbXRZyaYv06fnRovmufrRI9YdwAu8L6b POlCSwdwf9JP6aynloBjiIO8vTsrWM/2WTZPTbyEcJTl8l3dks5t0w4uetc+TaZS6IjE HfQA== 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:arc-authentication-results; bh=+bg9oKN4CfLrBSrVj4H6qoJsn8z643IisdZhlSDz3S8=; b=hJfjOsD7H3S97FxvgTlH6SiLyeyxsUT+Pt3UjisMIh+1tkl01wdYLkOWxIyfhGB3eR FT8vl3OeVdTNaCbmjq0xEWdbhPYFmGGmhdetBdafK/S+M3LBpzk56HbpGuE6C1NcKZwE 2VqaHDJQNLftmeI/devhe3xZjK5W6OSV4jFI9yyKGxjCPB19VZAjC+nL1xBKb3UlrcAO 4FZIUfPCBtO3nYDcr/zPtl2dQIDbinu3iqvBBMMioNVdmRBkXx2BK7ZmPuWLfW/cUOan DKAHUuspBbumiZoUQGabJrg2l9d97OrSH9f7z0uBI0IPOCem0bGPCA2QR5QWkzfZGRmW DyCw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-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 s184si5787295pfb.65.2017.05.13.02.52.05; Sat, 13 May 2017 02:52:05 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752240AbdEMJwB (ORCPT + 7 others); Sat, 13 May 2017 05:52:01 -0400 Received: from szxga03-in.huawei.com ([45.249.212.189]:5944 "EHLO szxga03-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751885AbdEMJwB (ORCPT ); Sat, 13 May 2017 05:52:01 -0400 Received: from 172.30.72.54 (EHLO DGGEML404-HUB.china.huawei.com) ([172.30.72.54]) by dggrg03-dlp.huawei.com (MOS 4.4.6-GA FastPath queued) with ESMTP id ANM88405; Sat, 13 May 2017 17:51:24 +0800 (CST) Received: from S00345302A-PC.china.huawei.com (10.47.91.84) by DGGEML404-HUB.china.huawei.com (10.3.17.39) with Microsoft SMTP Server id 14.3.301.0; Sat, 13 May 2017 17:50:56 +0800 From: shameer To: , , , , CC: , , , , , , , , , , shameer Subject: [RFC v1 2/7] iommu/arm-smmu-v3: Add erratum framework functions Date: Sat, 13 May 2017 10:47:26 +0100 Message-ID: <20170513094731.3676-3-shameerali.kolothum.thodi@huawei.com> X-Mailer: git-send-email 2.12.0.windows.1 In-Reply-To: <20170513094731.3676-1-shameerali.kolothum.thodi@huawei.com> References: <20170513094731.3676-1-shameerali.kolothum.thodi@huawei.com> MIME-Version: 1.0 X-Originating-IP: [10.47.91.84] X-CFilter-Loop: Reflected X-Mirapoint-Virus-RAPID-Raw: score=unknown(0), refid=str=0001.0A090204.5916D71C.011E, ss=1, re=0.000, recu=0.000, reip=0.000, cl=1, cld=1, fgs=0, ip=0.0.0.0, so=2014-11-16 11:51:01, dmn=2013-03-21 17:37:32 X-Mirapoint-Loop-Id: b23a9c723fbcb97cfe65d31edb629bd8 Sender: devicetree-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org This will provide a way to replace the existing skip_prefetch_cmd erratum using the new framework. Signed-off-by: shameer --- drivers/iommu/arm-smmu-v3.c | 58 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) -- 2.5.0 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html diff --git a/drivers/iommu/arm-smmu-v3.c b/drivers/iommu/arm-smmu-v3.c index a166590..f20d5d5 100644 --- a/drivers/iommu/arm-smmu-v3.c +++ b/drivers/iommu/arm-smmu-v3.c @@ -664,16 +664,72 @@ enum smmu_erratum_match_type { se_match_dt, }; +void erratum_skip_prefetch_cmd(struct arm_smmu_device *smmu, void *arg) +{ + smmu->options |= ARM_SMMU_OPT_SKIP_PREFETCH; +} + struct smmu_erratum_workaround { enum smmu_erratum_match_type match_type; const void *id; /* Indicate the Erratum ID */ const char *desc_str; + void (*enable)(struct arm_smmu_device *, void *); }; static const struct smmu_erratum_workaround smmu_workarounds[] = { }; +typedef bool (*se_match_fn_t)(const struct smmu_erratum_workaround *, + const void *); +static +bool smmu_check_dt_erratum(const struct smmu_erratum_workaround *wa, + const void *arg) +{ + const struct device_node *np = arg; + + return of_property_read_bool(np, wa->id); +} + +static void smmu_enable_errata(struct arm_smmu_device *smmu, + enum smmu_erratum_match_type type, + se_match_fn_t match_fn, + void *arg) +{ + const struct smmu_erratum_workaround *wa = smmu_workarounds; + + for (; wa->desc_str; wa++) { + if (wa->match_type != type) + continue; + + if (match_fn(wa, arg)) { + if (wa->enable) { + wa->enable(smmu, arg); + dev_info(smmu->dev, + "Enabling workaround for %s\n", + wa->desc_str); + } + } + } +} + + +static void smmu_check_workarounds(struct arm_smmu_device *smmu, + enum smmu_erratum_match_type type, + void *arg) +{ + se_match_fn_t match_fn = NULL; + + switch (type) { + case se_match_dt: + match_fn = smmu_check_dt_erratum; + break; + } + + smmu_enable_errata(smmu, type, match_fn, arg); + +} + static struct arm_smmu_domain *to_smmu_domain(struct iommu_domain *dom) { return container_of(dom, struct arm_smmu_domain, domain); @@ -2641,6 +2697,8 @@ static int arm_smmu_device_dt_probe(struct platform_device *pdev, parse_driver_options(smmu); + smmu_check_workarounds(smmu, se_match_dt, dev->of_node); + if (of_dma_is_coherent(dev->of_node)) smmu->features |= ARM_SMMU_FEAT_COHERENCY;