123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- /*
- *
- * (C) COPYRIGHT 2015 ARM Limited. All rights reserved.
- *
- * This program is free software and is provided to you under the terms of the
- * GNU General Public License version 2 as published by the Free Software
- * Foundation, and any use by you of this program is subject to the terms
- * of such GNU licence.
- *
- * A copy of the licence is included with the program, and can also be obtained
- * from Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- * Boston, MA 02110-1301, USA.
- *
- */
- #ifndef _KBASE_VINSTR_H_
- #define _KBASE_VINSTR_H_
- #include <mali_kbase.h>
- #include <mali_kbase_hwcnt_reader.h>
- /*****************************************************************************/
- struct kbase_vinstr_context;
- struct kbase_vinstr_client;
- /*****************************************************************************/
- /**
- * kbase_vinstr_init() - initialize the vinstr core
- * @kbdev: kbase device
- *
- * Return: pointer to the vinstr context on success or NULL on failure
- */
- struct kbase_vinstr_context *kbase_vinstr_init(struct kbase_device *kbdev);
- /**
- * kbase_vinstr_term() - terminate the vinstr core
- * @vinstr_ctx: vinstr context
- */
- void kbase_vinstr_term(struct kbase_vinstr_context *vinstr_ctx);
- /**
- * kbase_vinstr_hwcnt_reader_setup - configure hw counters reader
- * @vinstr_ctx: vinstr context
- * @setup: reader's configuration
- *
- * Return: zero on success
- */
- int kbase_vinstr_hwcnt_reader_setup(
- struct kbase_vinstr_context *vinstr_ctx,
- struct kbase_uk_hwcnt_reader_setup *setup);
- /**
- * kbase_vinstr_legacy_hwc_setup - configure hw counters for dumping
- * @vinstr_ctx: vinstr context
- * @cli: pointer where to store pointer to new vinstr client structure
- * @setup: hwc configuration
- *
- * Return: zero on success
- */
- int kbase_vinstr_legacy_hwc_setup(
- struct kbase_vinstr_context *vinstr_ctx,
- struct kbase_vinstr_client **cli,
- struct kbase_uk_hwcnt_setup *setup);
- /**
- * kbase_vinstr_hwcnt_kernel_setup - configure hw counters for kernel side
- * client
- * @vinstr_ctx: vinstr context
- * @setup: reader's configuration
- * @kernel_buffer: pointer to dump buffer
- *
- * setup->buffer_count and setup->fd are not used for kernel side clients.
- *
- * Return: pointer to client structure, or NULL on failure
- */
- struct kbase_vinstr_client *kbase_vinstr_hwcnt_kernel_setup(
- struct kbase_vinstr_context *vinstr_ctx,
- struct kbase_uk_hwcnt_reader_setup *setup,
- void *kernel_buffer);
- /**
- * kbase_vinstr_hwc_dump - issue counter dump for vinstr client
- * @cli: pointer to vinstr client
- * @event_id: id of event that triggered hwcnt dump
- *
- * Return: zero on success
- */
- int kbase_vinstr_hwc_dump(
- struct kbase_vinstr_client *cli,
- enum base_hwcnt_reader_event event_id);
- /**
- * kbase_vinstr_hwc_clear - performs a reset of the hardware counters for
- * a given kbase context
- * @cli: pointer to vinstr client
- *
- * Return: zero on success
- */
- int kbase_vinstr_hwc_clear(struct kbase_vinstr_client *cli);
- /**
- * kbase_vinstr_hwc_suspend - suspends hardware counter collection for
- * a given kbase context
- * @vinstr_ctx: vinstr context
- */
- void kbase_vinstr_hwc_suspend(struct kbase_vinstr_context *vinstr_ctx);
- /**
- * kbase_vinstr_hwc_resume - resumes hardware counter collection for
- * a given kbase context
- * @vinstr_ctx: vinstr context
- */
- void kbase_vinstr_hwc_resume(struct kbase_vinstr_context *vinstr_ctx);
- /**
- * kbase_vinstr_dump_size - Return required size of dump buffer
- * @kbdev: device pointer
- *
- * Return : buffer size in bytes
- */
- size_t kbase_vinstr_dump_size(struct kbase_device *kbdev);
- /**
- * kbase_vinstr_detach_client - Detach a client from the vinstr core
- * @cli: Pointer to vinstr client
- */
- void kbase_vinstr_detach_client(struct kbase_vinstr_client *cli);
- #endif // ifndef _KBASE_VINSTR_H_
|