From 9ab141145ea5c7d4cfa47002ae9b625ef3e773c7 Mon Sep 17 00:00:00 2001 From: Jay Jayanna Date: Fri, 24 Jul 2020 17:04:38 -0700 Subject: [PATCH] soc: qcom: qrtr: APIs for ethernet transport Provide APIs to be used by the ethernet transport/adaption layer to interface with qrtr-ethernet driver. Ethernet transport/adaption layer will use these APIs to: 1. Let qrtr-ethernet know when the ethernet link is up/down so that endpoint registration/deregistration is done as needed. 2. Provide a function pointer for qrtr-ethernet module to transmit data to the ethernet adaption layer. Change-Id: Ifd1a07aef2fc5cd906128d2bed68574a2ab4c29b Signed-off-by: Jay Jayanna --- include/soc/qcom/qrtr_ethernet.h | 51 ++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 include/soc/qcom/qrtr_ethernet.h diff --git a/include/soc/qcom/qrtr_ethernet.h b/include/soc/qcom/qrtr_ethernet.h new file mode 100644 index 000000000000..023453eaf0b4 --- /dev/null +++ b/include/soc/qcom/qrtr_ethernet.h @@ -0,0 +1,51 @@ +/* + * Copyright (c) 2020, The Linux Foundation. All rights reserved. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 and + * only version 2 as published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * QRTR-Ethernet API header + */ + +#ifndef _QRTR_ETHERNET_H +#define _QRTR_ETHERNET_H + +#include + +/** + * qrtr_ethernet_cb_info - struct to pass transport layer information to qrtr + * @eth_send: function pointer to send qrtr packets to transport layer + */ +struct qrtr_ethernet_cb_info { + int (*eth_send)(struct sk_buff *skb); +}; + +/** + * eth_adapt_result - struct to pass on buffer from external ap to qrtr + * buf_addr - address of the buffer that holds the data from external ap + * bytes_xferd - size of the above buffer + */ +struct eth_adapt_result { + void *buf_addr; + size_t bytes_xferd; +}; + +#if IS_ENABLED(CONFIG_QRTR_ETHERNET) || IS_ENABLED(CONFIG_QTI_QRTR_ETHERNET) +void qcom_ethernet_init_cb(struct qrtr_ethernet_cb_info *cbinfo); +void qcom_ethernet_qrtr_dl_cb(struct eth_adapt_result *eth_res); +void qcom_ethernet_qrtr_status_cb(unsigned int event); +#else +static inline void qcom_ethernet_init_cb(struct qrtr_ethernet_cb_info *cbinfo) +{ +} +static inline void qcom_ethernet_qrtr_dl_cb(struct eth_adapt_result *eth_res) {} +static inline void qcom_ethernet_qrtr_status_cb(unsigned int event) {} +#endif /* CONFIG_QRTR_ETHERNET or CONFIG_QTI_QRTR_ETHERNET */ + +#endif /* _QRTR_ETHERNET_H */