/* * Copyright (c) 2012-2016 The Linux Foundation. All rights reserved. * * Previously licensed under the ISC license by Qualcomm Atheros, Inc. * * * 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. */ /* * This file was originally distributed by Qualcomm Atheros, Inc. * under proprietary terms before Copyright ownership was assigned * to the Linux Foundation. */ /** * DOC: qdf_perf * This file provides OS abstraction perf API's. */ #ifndef _QDF_PERF_H #define _QDF_PERF_H /* headers */ #include <i_qdf_perf.h> #ifdef QCA_PERF_PROFILING /* Typedefs */ typedef __qdf_perf_id_t qdf_perf_id_t; typedef int (*proc_read_t)(char *page, char **start, off_t off, int count, int *eof, void *data); typedef int (*proc_write_t)(struct file *file, const char *buf, unsigned long count, void *data); typedef void (*perf_sample_t)(struct qdf_perf_entry *entry, uint8_t done); typedef void (*perf_init_t)(struct qdf_perf_entry *entry, uint32_t def_val); /** * typedef proc_api_tbl_t - contains functions to read, write to proc FS * @proc_read: function pointer to read function * @proc_write: function pointer to write function * @sample: function pointer to sample function * @init: function pointer to init function * @def_val: int contains default value */ typedef struct proc_api_tbl { proc_read_t proc_read; proc_write_t proc_write; perf_sample_t sample; perf_init_t init; uint32_t def_val; } proc_api_tbl_t; proc_api_tbl_t api_tbl[]; /* Macros */ #define INIT_API(name, val) { \ .proc_read = read_##name, \ .proc_write = write_##name, \ .sample = sample_event, \ .init = init_##name, \ .def_val = val, \ } #define PERF_ENTRY(hdl) ((qdf_perf_entry_t *)hdl) #define qdf_perf_init(_parent, _id, _ctr_type) \ __qdf_perf_init((_parent), (_id), (_ctr_type)) #define qdf_perf_destroy(_id) __qdf_perf_destroy((_id)) #define qdf_perf_start(_id) __qdf_perf_start((_id)) #define qdf_perf_end(_id) __qdf_perf_end((_id)) /* Extern declarations */ extern __qdf_perf_id_t __qdf_perf_init(qdf_perf_id_t parent, uint8_t *id_name, qdf_perf_cntr_t type)(__qdf_perf_id_t parent, uint8_t *id_name, uint32_t type); extern bool __qdf_perf_destroy(qdf_perf_id_t id)(__qdf_perf_id_t id); extern void __qdf_perf_start(qdf_perf_id_t id)(__qdf_perf_id_t id); extern void __qdf_perf_end(qdf_perf_id_t id)(__qdf_perf_id_t id); extern int qdf_perfmod_init(void); extern void qdf_perfmod_exit(void); #else /* !QCA_PERF_PROFILING */ #define qdf_perfmod_init() #define qdf_perfmod_exit() #define DECLARE_N_EXPORT_PERF_CNTR(id) #define START_PERF_CNTR(_id, _name) #define END_PERF_CNTR(_id) #endif /* QCA_PERF_PROFILING */ #endif /* end of _QDF_PERF_H */