From patchwork Tue Oct 18 11:27:33 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Stefan Wahren X-Patchwork-Id: 683646 X-Patchwork-Delegate: davem@davemloft.net Return-Path: X-Original-To: patchwork-incoming@ozlabs.org Delivered-To: patchwork-incoming@ozlabs.org Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by ozlabs.org (Postfix) with ESMTP id 3sytBv1M6kz9ryn for ; Tue, 18 Oct 2016 22:29:27 +1100 (AEDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1760256AbcJRL3I (ORCPT ); Tue, 18 Oct 2016 07:29:08 -0400 Received: from mout.kundenserver.de ([212.227.126.134]:64854 "EHLO mout.kundenserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1760012AbcJRL3B (ORCPT ); Tue, 18 Oct 2016 07:29:01 -0400 Received: from duckbill-v2-sdk.fritz.box ([109.104.48.177]) by mrelayeu.kundenserver.de (mreue004) with ESMTPSA (Nemesis) id 0M1TKv-1cpwh50M5x-00tVzO; Tue, 18 Oct 2016 13:27:50 +0200 From: Stefan Wahren To: "David S. Miller" , Greg Kroah-Hartman , Jiri Slaby Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Stefan Wahren Subject: [PATCH v3 net-next 7/8] net: qualcomm: make qca_common a separate kernel module Date: Tue, 18 Oct 2016 13:27:33 +0200 Message-Id: <1476790054-27174-8-git-send-email-stefan.wahren@i2se.com> X-Mailer: git-send-email 2.1.4 In-Reply-To: <1476790054-27174-1-git-send-email-stefan.wahren@i2se.com> References: <1476790054-27174-1-git-send-email-stefan.wahren@i2se.com> X-Provags-ID: V03:K0:+9TSxqTlRD9xuOTkYoy9e57eqbenZNMEMsKW6XKOe7BluOiSdND nfhznxiDBueN6gLd9zmvuWbJzCUYdSf+9G6Ord2i/mjKiciezqExH9coJPGu9uNC6eOJHZE a3H5nz25dsjLag9pqJwMf0I8fQQcbQNe1IS1gKBQVg1mGnyfOanwT1Ad6vxVu/QOR79vooT jNRVIlvwdWK1BQeYNSq/w== X-UI-Out-Filterresults: notjunk:1; V01:K0:GMMtPSVpqaw=:I/0wpJKDtoCL0r2j/wxWFI 3Ao9GNyfDq6H4NxMUJ7FYKhgpFJFb3G7EtqfUXyV0FuL6uK+v8e71pr25gwkjneprak9mWDBc 1JCM3a+xM3EUEo/Id4qudAvZ5XsmxZdxWz1RVaXaVOUeipZ3JP+CoPkoGJA5sKAXhHnGEuCpJ n9PTEzxyBllKfAw4+ghiY2Y9c12NSc3HcsJ+wVIKPAmhekqPS+WHSgJ4EFOZVwUs1D2yBa4jA WmY2qna5Vff1zb2hyYetbw0vs3kHsSlz/i6Xp91v94QnNjJR5W4ZzCl+f1BaBRP3iyHErrxvP U6deF5IbLwO9XbpW9+rLOBu3D2k9JHL+9gMzn2Hru6v/mExibasZpdk5BrLB7J2Jf85SXf6ix iXC6QZWBIQnFu8CEv6YVZ9lO1SajD71gfHFMVBapVmXkZebdk4dbVj04LtwAzUYL99atLfBsy xgefndldbbhikOjGUghCMZX40xlVo0T32aFHq8KDRfx/0ypUAK8nnUxsyTiTMPL1N9nqPRhez BtmjQUtg9aunHxTW9FhS+D9vx5CsJNuxXlHMK5uSRhYdx6yDXG9W4A89GzGzf2dcotmO/pB1t TKixVpmcfdNTnSa6gMblHmz5blA+mqNvL6QVKKucO/mpdnXfW6cI34RrvK3ZfoagBDBWtOfqx 4cxzpznANnAtPIdhFMWWwndZdR4Qey60sIh5l0MumphQlWOJN8TNO+v9TK9So23dOvNs= Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org In order to share common functions between QCA7000 SPI and UART protocol driver the qca_common needs to be a separate kernel module. Signed-off-by: Stefan Wahren --- drivers/net/ethernet/qualcomm/Kconfig | 8 +++++++- drivers/net/ethernet/qualcomm/Makefile | 5 +++-- drivers/net/ethernet/qualcomm/qca_common.c | 11 +++++++++++ 3 files changed, 21 insertions(+), 3 deletions(-) diff --git a/drivers/net/ethernet/qualcomm/Kconfig b/drivers/net/ethernet/qualcomm/Kconfig index d7720bf..b4c369d 100644 --- a/drivers/net/ethernet/qualcomm/Kconfig +++ b/drivers/net/ethernet/qualcomm/Kconfig @@ -16,7 +16,13 @@ config NET_VENDOR_QUALCOMM if NET_VENDOR_QUALCOMM config QCA7000 - tristate "Qualcomm Atheros QCA7000 support" + tristate + help + This enables support for the Qualcomm Atheros QCA7000. + +config QCA7000_SPI + tristate "Qualcomm Atheros QCA7000 SPI support" + select QCA7000 depends on SPI_MASTER && OF ---help--- This SPI protocol driver supports the Qualcomm Atheros QCA7000. diff --git a/drivers/net/ethernet/qualcomm/Makefile b/drivers/net/ethernet/qualcomm/Makefile index 8080570..00d8729 100644 --- a/drivers/net/ethernet/qualcomm/Makefile +++ b/drivers/net/ethernet/qualcomm/Makefile @@ -2,7 +2,8 @@ # Makefile for the Qualcomm network device drivers. # -obj-$(CONFIG_QCA7000) += qcaspi.o -qcaspi-objs := qca_spi.o qca_common.o qca_7k.o qca_debug.o +obj-$(CONFIG_QCA7000) += qca_common.o +obj-$(CONFIG_QCA7000_SPI) += qcaspi.o +qcaspi-objs := qca_7k.o qca_debug.o qca_spi.o obj-y += emac/ diff --git a/drivers/net/ethernet/qualcomm/qca_common.c b/drivers/net/ethernet/qualcomm/qca_common.c index 7eefdad..2fa8c18 100644 --- a/drivers/net/ethernet/qualcomm/qca_common.c +++ b/drivers/net/ethernet/qualcomm/qca_common.c @@ -21,7 +21,9 @@ * by an atheros frame while transmitted over a serial channel; */ +#include #include +#include #include "qca_common.h" @@ -46,6 +48,7 @@ qcafrm_create_header(u8 *buf, u16 length) return QCAFRM_HEADER_LEN; } +EXPORT_SYMBOL_GPL(qcafrm_create_header); u16 qcafrm_create_footer(u8 *buf) @@ -57,6 +60,7 @@ qcafrm_create_footer(u8 *buf) buf[1] = 0x55; return QCAFRM_FOOTER_LEN; } +EXPORT_SYMBOL_GPL(qcafrm_create_footer); /* Gather received bytes and try to extract a full ethernet frame by * following a simple state machine. @@ -154,6 +158,7 @@ qcafrm_fsm_decode(struct qcafrm_handle *handle, u8 *buf, u16 buf_len, u8 recv_by return ret; } +EXPORT_SYMBOL_GPL(qcafrm_fsm_decode); int qcacmn_netdev_change_mtu(struct net_device *dev, int new_mtu) @@ -165,3 +170,9 @@ qcacmn_netdev_change_mtu(struct net_device *dev, int new_mtu) return 0; } +EXPORT_SYMBOL_GPL(qcacmn_netdev_change_mtu); + +MODULE_DESCRIPTION("Qualcomm Atheros Common"); +MODULE_AUTHOR("Qualcomm Atheros Communications"); +MODULE_AUTHOR("Stefan Wahren "); +MODULE_LICENSE("Dual BSD/GPL");