1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- /*
- * Copyright (c) 2017 The Linux Foundation. All rights reserved.
- * Copyright (c) 2023 Qualcomm Innovation Center, Inc. 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
- #include "qdf_types.h"
- /**
- * enum 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);
- /**
- * qdf_debug_domain_valid() - bounds checks the given domain
- * @domain: the domain to validate
- *
- * Return: true is the given domain is a valid debug domain
- */
- bool qdf_debug_domain_valid(enum qdf_debug_domain domain);
- #endif /* __QDF_DEBUG_DOMAIN_H */
|