Bläddra i källkod

Merge "qca-wifi: Add OS-abstraction APIs"

Linux Build Service Account 4 år sedan
förälder
incheckning
cee5e9acc4
2 ändrade filer med 242 tillägg och 0 borttagningar
  1. 118 0
      qal/linux/src/qal_bridge.c
  2. 124 0
      qal/linux/src/qal_devnode.c

+ 118 - 0
qal/linux/src/qal_bridge.c

@@ -0,0 +1,118 @@
+/*
+ * Copyright (c) 2021 The Linux Foundation. All rights reserved.
+ *
+ * Permission to use, copy, modify, and/or distribute this software for
+ * any purpose with or without fee is hereby granted, provided that the
+ * above copyright notice and this permission notice appear in all
+ * copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
+ * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
+ * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
+ * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
+ * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
+ * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+ * PERFORMANCE OF THIS SOFTWARE.
+ */
+
+/**
+ * DOC: qal_bridge
+ * This file provides OS dependent bridge related APIs
+ */
+
+#include <linux/if_bridge.h>
+#include <qdf_module.h>
+#include "qal_bridge.h"
+#include "qdf_types.h"
+
+QDF_STATUS
+qal_bridge_fdb_register_notify(qal_notify_blk_t nb)
+{
+	if (!nb)
+		return QDF_STATUS_E_INVAL;
+
+	br_fdb_register_notify(nb);
+
+	return QDF_STATUS_SUCCESS;
+}
+
+qdf_export_symbol(qal_bridge_fdb_register_notify);
+
+QDF_STATUS
+qal_bridge_fdb_unregister_notify(qal_notify_blk_t nb)
+{
+	if (!nb)
+		return QDF_STATUS_E_INVAL;
+
+	br_fdb_unregister_notify(nb);
+
+	return QDF_STATUS_SUCCESS;
+}
+
+qdf_export_symbol(qal_bridge_fdb_unregister_notify);
+
+qal_br_fdb_entry_t
+qal_bridge_fdb_has_entry(qal_netdev_t dev, const char *addr, uint16_t vid)
+{
+	if (!dev)
+		return NULL;
+
+	return br_fdb_has_entry(dev, addr, vid);
+}
+
+qdf_export_symbol(qal_bridge_fdb_has_entry);
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 4, 24)
+QDF_STATUS
+__qal_bridge_fdb_delete_by_netdev(__qal_netdev_t dev,
+				  const unsigned char *addr, uint16_t vid)
+{
+	/* Use 5.4-specific API */
+	qdf_info("Needs alternative implementation");
+
+	return QDF_STATUS_SUCCESS;
+}
+#else
+QDF_STATUS
+qal_bridge_fdb_delete_by_netdev(qal_netdev_t dev,
+				const unsigned char *addr, uint16_t vid)
+{
+	int ret;
+
+	if (!dev)
+		return QDF_STATUS_E_INVAL;
+
+	ret = br_fdb_delete_by_netdev(dev, addr, vid);
+
+	return qdf_status_from_os_return(ret);
+}
+#endif
+
+qdf_export_symbol(qal_bridge_fdb_delete_by_netdev);
+
+QDF_STATUS
+qal_bridge_fdb_update_register_notify(qal_notify_blk_t nb)
+{
+	if (!nb)
+		return QDF_STATUS_E_INVAL;
+
+	br_fdb_update_register_notify(nb);
+
+	return QDF_STATUS_SUCCESS;
+}
+
+qdf_export_symbol(qal_bridge_fdb_update_register_notify);
+
+QDF_STATUS
+qal_bridge_fdb_update_unregister_notify(qal_notify_blk_t nb)
+{
+	if (!nb)
+		return QDF_STATUS_E_INVAL;
+
+	br_fdb_update_unregister_notify(nb);
+
+	return QDF_STATUS_SUCCESS;
+}
+
+qdf_export_symbol(qal_bridge_fdb_update_unregister_notify);

+ 124 - 0
qal/linux/src/qal_devnode.c

@@ -0,0 +1,124 @@
+/*
+ * Copyright (c) 2021 The Linux Foundation. All rights reserved.
+ *
+ * Permission to use, copy, modify, and/or distribute this software for
+ * any purpose with or without fee is hereby granted, provided that the
+ * above copyright notice and this permission notice appear in all
+ * copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
+ * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
+ * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
+ * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
+ * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
+ * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+ * PERFORMANCE OF THIS SOFTWARE.
+ */
+
+/**
+ * DOC: qal_devnode
+ * This file provides OS dependent device node related APIs
+ */
+
+#include <linux/of_pci.h>
+#include <linux/of.h>
+#include <qdf_module.h>
+#include "qal_devnode.h"
+
+/**
+ * qal_devnode_fetch_pci_domain_id() - This function will try to obtain the
+ * host bridge domain number
+ * @node: device tree node
+ * @domain_id: pointer to domain number
+ *
+ * Return: QDF_STATUS_SUCCESS on valid domain_id, error code otherwise
+ */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 18, 0))
+
+QDF_STATUS
+qal_devnode_fetch_pci_domain_id(qdf_devnode_t devnode, int *domain_id)
+{
+	*domain_id = 0;
+
+	return QDF_STATUS_SUCCESS;
+}
+
+qdf_export_symbol(qal_devnode_fetch_pci_domain_id);
+#else
+QDF_STATUS
+qal_devnode_fetch_pci_domain_id(qdf_devnode_t devnode, int *domain_id)
+{
+	int ret;
+
+	if (!devnode) {
+		qdf_err("Device node information is invalid");
+		return QDF_STATUS_E_INVAL;
+	}
+
+	ret = of_get_pci_domain_nr(devnode);
+	if ((ret >= PCI_DOMAIN_ID_MIN) && (ret <= PCI_DOMAIN_ID_MAX)) {
+		*domain_id = ret;
+		return QDF_STATUS_SUCCESS;
+	}
+
+	return qdf_status_from_os_return(ret);
+}
+
+qdf_export_symbol(qal_devnode_fetch_pci_domain_id);
+#endif
+
+/**
+ * qal_devnode_read_u32_array() - Find and read an array of 32 bit integers
+ * from a property.
+ * @devnode: device node from which the property value is to be read.
+ * @pname: name of the property to be searched.
+ * @u32_val: pointer to return value, modified only if return value is 0.
+ * @elem: number of array elements to read
+ *
+ * Return: QDF_STATUS_SUCCESS on valid 32bit integer data, error code otherwise
+ */
+QDF_STATUS
+qal_devnode_read_u32_array(const qdf_devnode_t devnode,
+			   const char *pname, uint32_t *u32_val,
+			   size_t elem)
+{
+	int ret;
+
+	if (!devnode) {
+		qdf_err("Device node information is invalid");
+		return QDF_STATUS_E_INVAL;
+	}
+
+	ret = of_property_read_u32_array(devnode, pname, u32_val, elem);
+
+	return qdf_status_from_os_return(ret);
+}
+
+qdf_export_symbol(qal_devnode_read_u32_array);
+
+/**
+ * qal_devnode_read_u32() - Find and read 32 bit integer from a property.
+ * @devnode: device node from which the property value is to be read.
+ * @pname: name of the property to be searched.
+ * @u32_val: pointer to return value, modified only if return value is 0.
+ *
+ * Return: QDF_STATUS_SUCCESS on valid 32bit integer data, error code otherwise
+ */
+QDF_STATUS
+qal_devnode_read_u32(const qdf_devnode_t devnode,
+		     const char *pname, uint32_t *u32_val)
+{
+	int ret;
+
+	if (!devnode) {
+		qdf_err("Device node information is invalid");
+		return QDF_STATUS_E_INVAL;
+	}
+
+	ret = of_property_read_u32(devnode, pname, u32_val);
+
+	return qdf_status_from_os_return(ret);
+}
+
+qdf_export_symbol(qal_devnode_read_u32);