|
@@ -0,0 +1,66 @@
|
|
|
+/*
|
|
|
+ * Copyright (c) 2017 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: qdf_debug_domain
|
|
|
+ * QCA driver framework (QDF) debug domain APIs. Debug domains are used to track
|
|
|
+ * resource allocations across different driver states, particularly for runtime
|
|
|
+ * leak detection.
|
|
|
+ */
|
|
|
+
|
|
|
+#ifndef __QDF_DEBUG_DOMAIN_H
|
|
|
+#define __QDF_DEBUG_DOMAIN_H
|
|
|
+
|
|
|
+/**
|
|
|
+ * struct qdf_debug_domain - debug domains for tracking resource allocations
|
|
|
+ * @QDF_DEBUG_DOMAIN_INIT: The default debug domain, tied to driver load
|
|
|
+ * @QDF_DEBUG_DOMAIN_ACTIVE: The active debug domain, tied some "running" state
|
|
|
+ * @QDF_DEBUG_DOMAIN_COUNT: The number of debug domains for iterating, etc.
|
|
|
+ */
|
|
|
+enum qdf_debug_domain {
|
|
|
+ QDF_DEBUG_DOMAIN_INIT,
|
|
|
+ QDF_DEBUG_DOMAIN_ACTIVE,
|
|
|
+
|
|
|
+ /* keep last */
|
|
|
+ QDF_DEBUG_DOMAIN_COUNT,
|
|
|
+};
|
|
|
+
|
|
|
+/**
|
|
|
+ * qdf_debug_domain_get() - Get the current debug domain
|
|
|
+ *
|
|
|
+ * Return: the current debug domain
|
|
|
+ */
|
|
|
+enum qdf_debug_domain qdf_debug_domain_get(void);
|
|
|
+
|
|
|
+/**
|
|
|
+ * qdf_debug_domain_set() - Set the current debug domain
|
|
|
+ * @domain: the domain to change to
|
|
|
+ *
|
|
|
+ * Return: None
|
|
|
+ */
|
|
|
+void qdf_debug_domain_set(enum qdf_debug_domain domain);
|
|
|
+
|
|
|
+/**
|
|
|
+ * qdf_debug_domain_name() - Get the human readable name of a debug domain
|
|
|
+ * @domain: The domain to return the name of
|
|
|
+ *
|
|
|
+ * Return: name of the given domain
|
|
|
+ */
|
|
|
+const char *qdf_debug_domain_name(enum qdf_debug_domain domain);
|
|
|
+
|
|
|
+#endif /* __QDF_DEBUG_DOMAIN_H */
|