Received: by 10.213.65.68 with SMTP id h4csp68312imn; Tue, 27 Mar 2018 16:42:03 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/0jGxPtU4v1SEW653ZNoNZdn6lJfyszpxNSozon1izYS0sYxIRX1TRssclfkDY/f7XWqjT X-Received: by 10.98.141.78 with SMTP id z75mr1027695pfd.174.1522194123574; Tue, 27 Mar 2018 16:42:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522194123; cv=none; d=google.com; s=arc-20160816; b=XWKBUtXL7fwjI18q2UCaL08r0NRNvH31PgCFSawh1lKOmR9ZP70ZrKMwBzyqu6f6ax fQKTk7l+0Nsdz9o4lFdrCjAUOEc0tC0eqApaKbtOFed4LG7fwyLjcmKet3eK+xdaKaWw pd5tQPFgF4U90gDDsWygIEK67BgPmuu3DjqY0xEP8L2Xhyo9UpLM3qAwWQPpOQOXkqMu qnfTAz5YnBuIdQKBAzP6Oykr5A/tzlym2dx2dNU+BzpmCwxjCDvHxtmWuwaNGoAZjbrp qYPE7oHvX07vtSpUGZRQSjDDHe2i+fk1Sunh8rSftHksSjXxWFm+akGaw5KVTrqtrmoS N6AQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=J6hhfOZoYNUcM81Ftn3VRCKq0dDtU8E98BSfzUI6FOM=; b=VQPQHjStJXHy9ELtqqmWw9tDGSYCBDx7ZyFybKwHSb8/qLaot+mJRQaiqLg7pwB2Mz WHJtY61mWpMDZFtqTp935oiVSeIYrXHpTKXcj/Z2Vk3QTbIqWyOvZEpzReggY89LtLW+ XPf7+rJ6suleRsg39c5k5Lj7C28jaV4RlLOcJuo1TuuaV10t+SYpRWfQa8KMPP806iSb mC/ofLjCFEYHyW0z5Nive7EEHGQ4g15PGL5TqlI/XrcmqZ1WLuZMKjM9upojuB2HoBB2 M0ZwR/tnucANdFd0B2ONy74zVBe/BzusGsOyhGNLuyh2J/NctovX1Iy1FlUIuFOmzAhF l7vg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=XmWlhhO3; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k75si1585177pgc.134.2018.03.27.16.41.48; Tue, 27 Mar 2018 16:42:03 -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=@gmail.com header.s=20161025 header.b=XmWlhhO3; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752367AbeC0Xku (ORCPT + 99 others); Tue, 27 Mar 2018 19:40:50 -0400 Received: from mail-qk0-f193.google.com ([209.85.220.193]:45909 "EHLO mail-qk0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751913AbeC0Xkt (ORCPT ); Tue, 27 Mar 2018 19:40:49 -0400 Received: by mail-qk0-f193.google.com with SMTP id s9so645059qke.12 for ; Tue, 27 Mar 2018 16:40:48 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=J6hhfOZoYNUcM81Ftn3VRCKq0dDtU8E98BSfzUI6FOM=; b=XmWlhhO30b63Vhx7589p8BrHbAtzFb9TtYX3amrvaxJXmtt1XV/uMzNXfYNq/FijNY kEw1+Ma+1lGhtk04cUnEA4HZCFYiooA8rGVY6ZBkgawz0yFBndiWNsxArPwi/i3OD5oB 5GMBVb46/Yg7T2Bnmjkys3Pgd//0DAjgy/sYYfZUjFAzW4OxwnqLy5A6UDAjAEtHGKMc +kUBYDSgUd3pxzs93hi0nwmxcP2kXLmQxzUt6FTtFIvIHW0PxHuIUsVDNJGJC7oW5SAH QIHM1lEVAGQ4QExDSKDdHWdwWWqb6s9U4dOPmcP+e6Z/6oxhwdmzBYLXrcy4WvciqVFs P1bA== 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; bh=J6hhfOZoYNUcM81Ftn3VRCKq0dDtU8E98BSfzUI6FOM=; b=izZCttYD+MhCbs4/VEJiTzE56CEirhUgKrvkxf79eyIe2lxW/mWmzjTa3zz1avxW9E WEjZgDNiPr0hD/aYTtIuNsAI26Kkyf/eEQPvbakk6PWAy3A5Wi8ddeySiPPpsKbxJMFr vwDtdYZIuUOYoim5aCZJmPpChqyuI/pRvBVxct22NTTsCiJNBcAZ1BeWwu+qPTdwYpED 3sPebTfchn2Sokg8ccL3Pj3lI6u88iWWgn0rTipIIFYlLkLRDeqzMlupVl2IRCcLa0rK nwo150Hm5njZHi6DP+iu2151V7ERNZpYZCwbsTNo+o/uwaz/h+wlXL6guIFbAPfLPFk/ N8yQ== X-Gm-Message-State: ALQs6tDjru7MCelf2BfKYxZAKYYDr7nRFH22V759kYtAmItEAppokPKU rEcdGyiA/lNbUye005VhR/E= X-Received: by 10.55.166.79 with SMTP id p76mr2085740qke.248.1522194048229; Tue, 27 Mar 2018 16:40:48 -0700 (PDT) Received: from fainelli-desktop.igp.broadcom.net ([192.19.223.250]) by smtp.gmail.com with ESMTPSA id i11sm1839330qtc.30.2018.03.27.16.40.46 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 27 Mar 2018 16:40:47 -0700 (PDT) From: Florian Fainelli To: linux-arm-kernel@lists.infradead.org Cc: Florian Fainelli , Markus Mayer , bcm-kernel-feedback-list@broadcom.com (maintainer:BROADCOM STB DPFE DRIVER), Brian Norris , Gregory Fong , linux-kernel@vger.kernel.org (open list) Subject: [PATCH] memory: brcmstb: dpfe: Remove need for dpfe_dev Date: Tue, 27 Mar 2018 16:40:38 -0700 Message-Id: <20180327234038.32241-1-f.fainelli@gmail.com> X-Mailer: git-send-email 2.14.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We can hook sysfs objects to the parent platform device that we are created from, no need to have a synthetic dpfe_dev just for that. This incidentally removes the need for having an index, since we are guaranteed to have an unique path in the sysfs hiearchy. Signed-off-by: Florian Fainelli --- drivers/memory/brcmstb_dpfe.c | 42 ++++++++++-------------------------------- 1 file changed, 10 insertions(+), 32 deletions(-) diff --git a/drivers/memory/brcmstb_dpfe.c b/drivers/memory/brcmstb_dpfe.c index 0a7bdbed3a6f..5f8d5aff6040 100644 --- a/drivers/memory/brcmstb_dpfe.c +++ b/drivers/memory/brcmstb_dpfe.c @@ -168,7 +168,6 @@ struct private_data { void __iomem *dmem; void __iomem *imem; struct device *dev; - unsigned int index; struct mutex lock; }; @@ -628,10 +627,8 @@ static int brcmstb_dpfe_probe(struct platform_device *pdev) { struct device *dev = &pdev->dev; struct private_data *priv; - struct device *dpfe_dev; struct init_data init; struct resource *res; - u32 index; int ret; priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL); @@ -641,11 +638,6 @@ static int brcmstb_dpfe_probe(struct platform_device *pdev) mutex_init(&priv->lock); platform_set_drvdata(pdev, priv); - /* Cell index is optional; default to 0 if not present. */ - ret = of_property_read_u32(dev->of_node, "cell-index", &index); - if (ret) - index = 0; - res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "dpfe-cpu"); priv->regs = devm_ioremap_resource(dev, res); if (IS_ERR(priv->regs)) { @@ -669,35 +661,20 @@ static int brcmstb_dpfe_probe(struct platform_device *pdev) ret = brcmstb_dpfe_download_firmware(pdev, &init); if (ret) - goto err; - - dpfe_dev = devm_kzalloc(dev, sizeof(*dpfe_dev), GFP_KERNEL); - if (!dpfe_dev) { - ret = -ENOMEM; - goto err; - } - - priv->dev = dpfe_dev; - priv->index = index; + return ret; - dpfe_dev->parent = dev; - dpfe_dev->groups = dpfe_groups; - dpfe_dev->of_node = dev->of_node; - dev_set_drvdata(dpfe_dev, priv); - dev_set_name(dpfe_dev, "dpfe%u", index); + ret = sysfs_create_groups(&pdev->dev.kobj, dpfe_groups); + if (!ret) + dev_info(dev, "registered.\n"); - ret = device_register(dpfe_dev); - if (ret) - goto err; + return ret; +} - dev_info(dev, "registered.\n"); +static int brcmstb_dpfe_remove(struct platform_device *pdev) +{ + sysfs_remove_groups(&pdev->dev.kobj, dpfe_groups); return 0; - -err: - dev_err(dev, "failed to initialize -- error %d\n", ret); - - return ret; } static const struct of_device_id brcmstb_dpfe_of_match[] = { @@ -712,6 +689,7 @@ static struct platform_driver brcmstb_dpfe_driver = { .of_match_table = brcmstb_dpfe_of_match, }, .probe = brcmstb_dpfe_probe, + .remove = brcmstb_dpfe_remove, .resume = brcmstb_dpfe_resume, }; -- 2.14.1