Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp280666yba; Fri, 12 Apr 2019 03:29:55 -0700 (PDT) X-Google-Smtp-Source: APXvYqxATORxvFvSA8J/imTPe0rA5NVKw9bQ+kR3JHplzIuJDLY1A5ixOGk09EZdcJo0CxrAXW41 X-Received: by 2002:a17:902:47c2:: with SMTP id d2mr55997935plh.277.1555064995522; Fri, 12 Apr 2019 03:29:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555064995; cv=none; d=google.com; s=arc-20160816; b=vsXc3mXrqf9fNQFOCwm3Y6aFKGq8By/z5zJea7vC8RQyLSjwEaXDWtH5zKuLvSgh98 9mVGsAQtN4Wk9MsyrZmu1x+24GEbym2WAJcQSpVWz/4m6xyYRgEkiwmkV0367zFqosZn RNt8eK5ad3YzUBfw/MclDegzdjDtXQnycQyU+zO6xfoVIYXuK9Mg/l7L9pPUXSsNQRvw YmpFKnlRnL4ViUYgnT1hcWQqB4rjgFlerhl85H2bf2Ay757GEkndpSIJgyyQJ8itp2BW K9zRYlqwKmwcO+efNeJiagdPw9lGZp1yyImmEOXQhp3gkDbNboUojgSWHRVCxW2YLJ3e zR2Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=hR3TUnL81mAK4TjBbDbJHygDbgagwUd1k/T2re2bRoo=; b=czELaTUjd9ls7m+yJLxpd/vBJjurwKcT1i+84RrlRd86imxquKpBRq2A/pHcreD12S qN3xC4xeN3UZJlp8pPntwgoXq7WWyU2D19e1z7GxAnW0BuSr0i//6LmSN5rfuJjXxj1M z51cxnYYWdRc2v+FxSu3oo4HknYhD4dEeY6XDYj25pJHnrH0j3bg8SdGESwQ0hkFj60S xpHsF9XEhxWadAPFdvFd5wlRqzBhXIEWVIuuTt1A7TGwxesz3p156gnTzrfGOxcFkvVV 5Km/I1uy0RHRBumNJ0KWmRCRPZR19bNJKPnunydyi8rmjeh0Bc0zpBibD0+DgS/MUM2Z W06w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=CmWLhvar; 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=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q3si10307960plb.176.2019.04.12.03.29.39; Fri, 12 Apr 2019 03:29:55 -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=@linaro.org header.s=google header.b=CmWLhvar; 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=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728046AbfDLK2S (ORCPT + 99 others); Fri, 12 Apr 2019 06:28:18 -0400 Received: from mail-oi1-f196.google.com ([209.85.167.196]:42148 "EHLO mail-oi1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727921AbfDLK2P (ORCPT ); Fri, 12 Apr 2019 06:28:15 -0400 Received: by mail-oi1-f196.google.com with SMTP id w139so7498323oie.9 for ; Fri, 12 Apr 2019 03:28:14 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=hR3TUnL81mAK4TjBbDbJHygDbgagwUd1k/T2re2bRoo=; b=CmWLhvarY9SHixmdYGQl2Gyeb1L2STJrd3Z6Gr8Fvt8MTyedN7RS3IKluCbjxX3/gC WQvcHtObjIH/qHQU1pY4hRPdaiQrxf43MAp2AXTiSambkMRjX18G/+AE+g9gFxXRGpf2 fYgVBiqNENKmjSNE67fbCod2RwiPOKIDTGOoSvsld6atkS0UDunyG3oOhxv0Q0X1er2v QrkcRprks8kzY8gjGsoS+3nUc1SYUfG9Sck4oGFK0jFOW4p/zd5gSvubnTjcApyTGfOO J+6YL8L1QvCqjSaLRUQezerJ8OChOnq6zFv/s2aNAGo6sUEMgb7HijlRrbrnRExiCyxq 2fQw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=hR3TUnL81mAK4TjBbDbJHygDbgagwUd1k/T2re2bRoo=; b=NJUW5yxUEBfa7OdmJF0dV7TOp6FrbiGXpfKjD0cx+i6qqSxHOVufnBzcniDFcONzMv DmzT32Z8MNtLqWy5xmFvtqHQ0L711iCu2xTJD7dXYjF//DoUcXTE5QxxdGyG7SbjiGiS tQvMVdV33AIXkeayfP2V2+w7t6iR0+Tj6tvYPx/iqJduhji97icE65JMjOAVeqj+SNYH wkr4Xb/pCNjZ4XVOOXJiTuSTzasF3/oQ/Kazonc9/wb9uS2YVK2PqRe6ObJkAmP74qqz obHtZFXNE/eIYZ2ATClycx+claD1nRO2GGPfsef7pX9aJVVctYzfX/5RrRYsV04LEHoD 4+fg== X-Gm-Message-State: APjAAAXrdTL17aRJMPJGmxS11zcYDJPCjT1DLv9Jz1+4PlN1U8rOJIuc yn6/Q9rZqzwhIkdU6z97ktoA+A== X-Received: by 2002:aca:304e:: with SMTP id w75mr10038613oiw.176.1555064894407; Fri, 12 Apr 2019 03:28:14 -0700 (PDT) Received: from localhost.localdomain (li808-42.members.linode.com. [104.237.132.42]) by smtp.gmail.com with ESMTPSA id 88sm17530692otj.3.2019.04.12.03.28.09 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 12 Apr 2019 03:28:13 -0700 (PDT) From: Leo Yan To: Mathieu Poirier , Suzuki K Poulose , Rob Herring , Mark Rutland , Alexander Shishkin , linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Leo Yan , Wanglai Shi Subject: [PATCH v5 4/4] coresight: funnel: Support static funnel Date: Fri, 12 Apr 2019 18:27:38 +0800 Message-Id: <20190412102738.12679-5-leo.yan@linaro.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190412102738.12679-1-leo.yan@linaro.org> References: <20190412102738.12679-1-leo.yan@linaro.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Since CoreSight hardware topology can use a 'hidden' funnel in the trace data path, this kind funnel doesn't have register for accessing and is used by default from hardware design perspective. Below is an example for related hardware topology: +------+ +------+ | cpu0 |->| ETM |-\ +------+ +------+ \-> +--------+ +-----+ ...... | Funnel |->| ETF |-\ Hidden funnel +------+ +------+ /-> +--------+ +-----+ \ | | cpu3 |->| ETM |-/ \ V +------+ +------+ \-> +--------+ | Funnel |-> ... +------+ +------+ /-> +--------+ | cpu4 |->| ETM |-\ / +------+ +------+ \-> +--------+ +-----+ / ...... | Funnel |->| ETF |-/ +------+ +------+ /-> +--------+ +-----+ | cpu7 |->| ETM |-/ +------+ +------+ The CoreSight funnel driver only supports dynamic funnel with registration register resource, thus it cannot support for the static funnel case and it's impossible to create trace data path for this case. This patch is to extend CoreSight funnel driver to support both for static funnel and dynamic funnel. For the dynamic funnel it reuses the code existed in the driver, for static funnel the driver will support device probe if without providing register resource and the driver skips registers accessing when detect the register base is NULL. Cc: Mathieu Poirier Cc: Suzuki K Poulose Cc: Wanglai Shi Suggested-by: Suzuki K Poulose Signed-off-by: Leo Yan Reviewed-by: Suzuki K Poulose --- .../hwtracing/coresight/coresight-funnel.c | 116 ++++++++++++++---- 1 file changed, 89 insertions(+), 27 deletions(-) diff --git a/drivers/hwtracing/coresight/coresight-funnel.c b/drivers/hwtracing/coresight/coresight-funnel.c index 927925151509..16b0c0e1e43a 100644 --- a/drivers/hwtracing/coresight/coresight-funnel.c +++ b/drivers/hwtracing/coresight/coresight-funnel.c @@ -12,6 +12,8 @@ #include #include #include +#include +#include #include #include #include @@ -43,7 +45,7 @@ struct funnel_drvdata { unsigned long priority; }; -static int funnel_enable_hw(struct funnel_drvdata *drvdata, int port) +static int dynamic_funnel_enable_hw(struct funnel_drvdata *drvdata, int port) { u32 functl; int rc = 0; @@ -71,17 +73,19 @@ static int funnel_enable_hw(struct funnel_drvdata *drvdata, int port) static int funnel_enable(struct coresight_device *csdev, int inport, int outport) { - int rc; + int rc = 0; struct funnel_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent); - rc = funnel_enable_hw(drvdata, inport); + if (drvdata->base) + rc = dynamic_funnel_enable_hw(drvdata, inport); if (!rc) dev_dbg(drvdata->dev, "FUNNEL inport %d enabled\n", inport); return rc; } -static void funnel_disable_hw(struct funnel_drvdata *drvdata, int inport) +static void dynamic_funnel_disable_hw(struct funnel_drvdata *drvdata, + int inport) { u32 functl; @@ -103,7 +107,8 @@ static void funnel_disable(struct coresight_device *csdev, int inport, { struct funnel_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent); - funnel_disable_hw(drvdata, inport); + if (drvdata->base) + dynamic_funnel_disable_hw(drvdata, inport); dev_dbg(drvdata->dev, "FUNNEL inport %d disabled\n", inport); } @@ -177,54 +182,70 @@ static struct attribute *coresight_funnel_attrs[] = { }; ATTRIBUTE_GROUPS(coresight_funnel); -static int funnel_probe(struct amba_device *adev, const struct amba_id *id) +static int funnel_probe(struct device *dev, struct resource *res) { int ret; void __iomem *base; - struct device *dev = &adev->dev; struct coresight_platform_data *pdata = NULL; struct funnel_drvdata *drvdata; - struct resource *res = &adev->res; struct coresight_desc desc = { 0 }; - struct device_node *np = adev->dev.of_node; + struct device_node *np = dev->of_node; if (np) { pdata = of_get_coresight_platform_data(dev, np); if (IS_ERR(pdata)) return PTR_ERR(pdata); - adev->dev.platform_data = pdata; + dev->platform_data = pdata; } + if (of_device_is_compatible(np, "arm,coresight-funnel")) + pr_warn_once("Uses OBSOLETE CoreSight funnel binding\n"); + drvdata = devm_kzalloc(dev, sizeof(*drvdata), GFP_KERNEL); if (!drvdata) return -ENOMEM; - drvdata->dev = &adev->dev; - drvdata->atclk = devm_clk_get(&adev->dev, "atclk"); /* optional */ + drvdata->dev = dev; + drvdata->atclk = devm_clk_get(dev, "atclk"); /* optional */ if (!IS_ERR(drvdata->atclk)) { ret = clk_prepare_enable(drvdata->atclk); if (ret) return ret; } - dev_set_drvdata(dev, drvdata); - /* Validity for the resource is already checked by the AMBA core */ - base = devm_ioremap_resource(dev, res); - if (IS_ERR(base)) - return PTR_ERR(base); + /* + * Map the device base for dynamic-funnel, which has been + * validated by AMBA core. + */ + if (res) { + base = devm_ioremap_resource(dev, res); + if (IS_ERR(base)) { + ret = PTR_ERR(base); + goto out_disable_clk; + } + drvdata->base = base; + desc.groups = coresight_funnel_groups; + } - drvdata->base = base; - pm_runtime_put(&adev->dev); + dev_set_drvdata(dev, drvdata); desc.type = CORESIGHT_DEV_TYPE_LINK; desc.subtype.link_subtype = CORESIGHT_DEV_SUBTYPE_LINK_MERG; desc.ops = &funnel_cs_ops; desc.pdata = pdata; desc.dev = dev; - desc.groups = coresight_funnel_groups; drvdata->csdev = coresight_register(&desc); + if (IS_ERR(drvdata->csdev)) { + ret = PTR_ERR(drvdata->csdev); + goto out_disable_clk; + } + + pm_runtime_put(dev); - return PTR_ERR_OR_ZERO(drvdata->csdev); +out_disable_clk: + if (ret && !IS_ERR_OR_NULL(drvdata->atclk)) + clk_disable_unprepare(drvdata->atclk); + return ret; } #ifdef CONFIG_PM @@ -253,7 +274,48 @@ static const struct dev_pm_ops funnel_dev_pm_ops = { SET_RUNTIME_PM_OPS(funnel_runtime_suspend, funnel_runtime_resume, NULL) }; -static const struct amba_id funnel_ids[] = { +static int static_funnel_probe(struct platform_device *pdev) +{ + int ret; + + pm_runtime_get_noresume(&pdev->dev); + pm_runtime_set_active(&pdev->dev); + pm_runtime_enable(&pdev->dev); + + /* Static funnel do not have programming base */ + ret = funnel_probe(&pdev->dev, NULL); + + if (ret) { + pm_runtime_put_noidle(&pdev->dev); + pm_runtime_disable(&pdev->dev); + } + + return ret; +} + +static const struct of_device_id static_funnel_match[] = { + {.compatible = "arm,coresight-static-funnel"}, + {} +}; + +static struct platform_driver static_funnel_driver = { + .probe = static_funnel_probe, + .driver = { + .name = "coresight-static-funnel", + .of_match_table = static_funnel_match, + .pm = &funnel_dev_pm_ops, + .suppress_bind_attrs = true, + }, +}; +builtin_platform_driver(static_funnel_driver); + +static int dynamic_funnel_probe(struct amba_device *adev, + const struct amba_id *id) +{ + return funnel_probe(&adev->dev, &adev->res); +} + +static const struct amba_id dynamic_funnel_ids[] = { { .id = 0x000bb908, .mask = 0x000fffff, @@ -266,14 +328,14 @@ static const struct amba_id funnel_ids[] = { { 0, 0}, }; -static struct amba_driver funnel_driver = { +static struct amba_driver dynamic_funnel_driver = { .drv = { - .name = "coresight-funnel", + .name = "coresight-dynamic-funnel", .owner = THIS_MODULE, .pm = &funnel_dev_pm_ops, .suppress_bind_attrs = true, }, - .probe = funnel_probe, - .id_table = funnel_ids, + .probe = dynamic_funnel_probe, + .id_table = dynamic_funnel_ids, }; -builtin_amba_driver(funnel_driver); +builtin_amba_driver(dynamic_funnel_driver); -- 2.17.1