Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp654288imu; Fri, 4 Jan 2019 04:49:11 -0800 (PST) X-Google-Smtp-Source: ALg8bN72ARd5wOKjHu/GPa4DjehL9vA33zHnqXJzu73DzV/jMxSF4eWEZN2mAMeMJ89GfLjL04oo X-Received: by 2002:a63:88c7:: with SMTP id l190mr47685836pgd.110.1546606151860; Fri, 04 Jan 2019 04:49:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546606151; cv=none; d=google.com; s=arc-20160816; b=U5ObaHUzPvBpkMtIM6ieTqfHL182jO1y7o6TbidLA3oGrGpW1cRaJPfRju+OYErtYL QJemtmVte+Z7Az/9VGdAK7K85JVOBMpFKwiLYeI4Crn/NGvidTnndGdhP2RGPrSSMzUu 43I3p+YLZseJ96UYRXJ15Pw9CgbGf8LIURt3s4JilDGB2oCsnEsZVsj+/QRfdjhS4Y24 cjdaWjymJ37of46/+fq4rP+Q76cFe1Ji1Egdd5KnJco5WrUnv6yxOp5QJYrI8x+j1geH ehw+SYXcCO2T6RTjJ91oM4CifDTiwfTgrcz+1Q9sutDimow7B39t7znPVOgEZ6a0tfoY HBZA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=dw9NjoFYhvf6M4Vz2GwYclwDkvyBXFnP8DEQI0aGMjY=; b=zM0k7x0A8LbCrPUcqflq5oDMS3asPclm9nKoWrQzuK4kyDaICxPOoDOta1M8hYYqQS uHXkrRTTTLEC3MjX2Y3Hvdm1YKO74IA9s9GddGtfIOzev+WTbu3YpNcQkjEOShsS92j4 v2r7Eqp6pSSWdsVo85tw72wZMwGpquHs9eMEUgYj4EkK/q8iQW+IeHtWRaxPCtbQ6/Jv 5Xq9PgK2l4ojeZmK3I5HCgaE/ZNrN6MjKE5yraYFpfm/+2p/L3GYk6io68KqbIQaohnp yMtx6/LfgkW+Vbl2WCQ8LKZ3UbIPIwR6KIArlGMNwYAP3aF0iM+1hG/ilNQMec29Qqxf 7KSA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t4si2134899pgb.97.2019.01.04.04.48.54; Fri, 04 Jan 2019 04:49:11 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728018AbfADLVq (ORCPT + 99 others); Fri, 4 Jan 2019 06:21:46 -0500 Received: from mx2.suse.de ([195.135.220.15]:52408 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727625AbfADLVq (ORCPT ); Fri, 4 Jan 2019 06:21:46 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay1.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id 1F256AE65; Fri, 4 Jan 2019 11:21:44 +0000 (UTC) From: =?UTF-8?q?Andreas=20F=C3=A4rber?= To: linux-lpwan@lists.infradead.org, linux-serial@vger.kernel.org Cc: linux-usb@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Johan Hovold , Rob Herring , =?UTF-8?q?Andreas=20F=C3=A4rber?= , "David S. Miller" , netdev@vger.kernel.org Subject: [PATCH lora-next 2/5] net: lora: sx130x: Prepare storing driver-specific data Date: Fri, 4 Jan 2019 12:21:28 +0100 Message-Id: <20190104112131.14451-3-afaerber@suse.de> X-Mailer: git-send-email 2.16.4 In-Reply-To: <20190104112131.14451-1-afaerber@suse.de> References: <20190104112131.14451-1-afaerber@suse.de> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Some drivers (e.g., serdev) may need to access private data not part of the core sx130x_priv, which is inaccessible to other source files. As the sx130x core expects to obtain the net_device from the dev's drvdata, we can't reuse that in derived drivers and need a new field plus helpers. Signed-off-by: Andreas Färber --- drivers/net/lora/sx130x.c | 19 +++++++++++++++++++ include/linux/lora/sx130x.h | 2 ++ 2 files changed, 21 insertions(+) diff --git a/drivers/net/lora/sx130x.c b/drivers/net/lora/sx130x.c index 840052955874..978c921ca5ec 100644 --- a/drivers/net/lora/sx130x.c +++ b/drivers/net/lora/sx130x.c @@ -58,6 +58,7 @@ struct sx130x_priv { struct regmap *regmap; struct regmap_field *regmap_fields[ARRAY_SIZE(sx130x_regmap_fields)]; struct mutex io_lock; + void *drvdata; }; struct regmap *sx130x_get_regmap(struct device *dev) @@ -68,6 +69,24 @@ struct regmap *sx130x_get_regmap(struct device *dev) return priv->regmap; } +void sx130x_set_drvdata(struct device *dev, void *drvdata) +{ + struct net_device *netdev = dev_get_drvdata(dev); + struct sx130x_priv *priv = netdev_priv(netdev); + + priv->drvdata = drvdata; +} +EXPORT_SYMBOL_GPL(sx130x_set_drvdata); + +void *sx130x_get_drvdata(struct device *dev) +{ + struct net_device *netdev = dev_get_drvdata(dev); + struct sx130x_priv *priv = netdev_priv(netdev); + + return priv->drvdata; +} +EXPORT_SYMBOL_GPL(sx130x_get_drvdata); + void sx130x_io_lock(struct device *dev) { struct net_device *netdev = dev_get_drvdata(dev); diff --git a/include/linux/lora/sx130x.h b/include/linux/lora/sx130x.h index d6f027ef283f..85b088ec77b8 100644 --- a/include/linux/lora/sx130x.h +++ b/include/linux/lora/sx130x.h @@ -14,6 +14,8 @@ #include extern const struct regmap_config sx130x_regmap_config; +void sx130x_set_drvdata(struct device *dev, void *drvdata); +void *sx130x_get_drvdata(struct device *dev); int sx130x_early_probe(struct regmap *regmap, struct gpio_desc *rst); int sx130x_probe(struct device *dev); int sx130x_remove(struct device *dev); -- 2.16.4