blob: e3a8137ced55b22d5b36369b2a92af07d1ff15fd [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
/*
*
* (C) COPYRIGHT 2018, 2020-2021 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 license.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, you can access it online at
* http://www.gnu.org/licenses/gpl-2.0.html.
*
*/
/**
* Hardware counter virtualizer API.
*
* Virtualizes a hardware counter context, so multiple clients can access
* a single hardware counter resource as though each was the exclusive user.
*/
#ifndef _KBASE_HWCNT_VIRTUALIZER_H_
#define _KBASE_HWCNT_VIRTUALIZER_H_
#include <linux/types.h>
#include <linux/workqueue.h>
struct kbase_hwcnt_context;
struct kbase_hwcnt_virtualizer;
struct kbase_hwcnt_virtualizer_client;
struct kbase_hwcnt_enable_map;
struct kbase_hwcnt_dump_buffer;
/**
* kbase_hwcnt_virtualizer_init - Initialise a hardware counter virtualizer.
* @hctx: Non-NULL pointer to the hardware counter context to
* virtualize.
* @dump_threshold_ns: Minimum threshold period for dumps between different
* clients where a new accumulator dump will not be
* performed, and instead accumulated values will be used.
* If 0, rate limiting will be disabled.
* @out_hvirt: Non-NULL pointer to where the pointer to the created
* virtualizer will be stored on success.
*
* Return: 0 on success, else error code.
*/
int kbase_hwcnt_virtualizer_init(
struct kbase_hwcnt_context *hctx,
u64 dump_threshold_ns,
struct kbase_hwcnt_virtualizer **out_hvirt);
/**
* kbase_hwcnt_virtualizer_term - Terminate a hardware counter virtualizer.
* @hvirt: Pointer to virtualizer to be terminated.
*/
void kbase_hwcnt_virtualizer_term(
struct kbase_hwcnt_virtualizer *hvirt);
/**
* kbase_hwcnt_virtualizer_metadata - Get the hardware counter metadata used by
* the virtualizer, so related counter data
* structures can be created.
* @hvirt: Non-NULL pointer to the hardware counter virtualizer.
*
* Return: Non-NULL pointer to metadata, or NULL on error.
*/
const struct kbase_hwcnt_metadata *kbase_hwcnt_virtualizer_metadata(
struct kbase_hwcnt_virtualizer *hvirt);
/**
* kbase_hwcnt_virtualizer_client_create - Create a new virtualizer client.
* @hvirt: Non-NULL pointer to the hardware counter virtualizer.
* @enable_map: Non-NULL pointer to the enable map for the client. Must have the
* same metadata as the virtualizer.
* @out_hvcli: Non-NULL pointer to where the pointer to the created client will
* be stored on success.
*
* Return: 0 on success, else error code.
*/
int kbase_hwcnt_virtualizer_client_create(
struct kbase_hwcnt_virtualizer *hvirt,
const struct kbase_hwcnt_enable_map *enable_map,
struct kbase_hwcnt_virtualizer_client **out_hvcli);
/**
* kbase_hwcnt_virtualizer_client_destroy() - Destroy a virtualizer client.
* @hvcli: Pointer to the hardware counter client.
*/
void kbase_hwcnt_virtualizer_client_destroy(
struct kbase_hwcnt_virtualizer_client *hvcli);
/**
* kbase_hwcnt_virtualizer_client_set_counters - Perform a dump of the client's
* currently enabled counters, and
* enable a new set of counters
* that will be used for
* subsequent dumps.
* @hvcli: Non-NULL pointer to the virtualizer client.
* @enable_map: Non-NULL pointer to the new counter enable map for the client.
* Must have the same metadata as the virtualizer.
* @ts_start_ns: Non-NULL pointer where the start timestamp of the dump will
* be written out to on success.
* @ts_end_ns: Non-NULL pointer where the end timestamp of the dump will
* be written out to on success.
* @dump_buf: Pointer to the buffer where the dump will be written out to on
* success. If non-NULL, must have the same metadata as the
* accumulator. If NULL, the dump will be discarded.
*
* Return: 0 on success or error code.
*/
int kbase_hwcnt_virtualizer_client_set_counters(
struct kbase_hwcnt_virtualizer_client *hvcli,
const struct kbase_hwcnt_enable_map *enable_map,
u64 *ts_start_ns,
u64 *ts_end_ns,
struct kbase_hwcnt_dump_buffer *dump_buf);
/**
* kbase_hwcnt_virtualizer_client_dump - Perform a dump of the client's
* currently enabled counters.
* @hvcli: Non-NULL pointer to the virtualizer client.
* @ts_start_ns: Non-NULL pointer where the start timestamp of the dump will
* be written out to on success.
* @ts_end_ns: Non-NULL pointer where the end timestamp of the dump will
* be written out to on success.
* @dump_buf: Pointer to the buffer where the dump will be written out to on
* success. If non-NULL, must have the same metadata as the
* accumulator. If NULL, the dump will be discarded.
*
* Return: 0 on success or error code.
*/
int kbase_hwcnt_virtualizer_client_dump(
struct kbase_hwcnt_virtualizer_client *hvcli,
u64 *ts_start_ns,
u64 *ts_end_ns,
struct kbase_hwcnt_dump_buffer *dump_buf);
/**
* kbase_hwcnt_virtualizer_queue_work() - Queue hardware counter related async
* work on a workqueue specialized for
* hardware counters.
* @hvirt: Non-NULL pointer to the hardware counter virtualizer.
* @work: Non-NULL pointer to work to queue.
*
* Return: false if work was already on a queue, true otherwise.
*
* This is a convenience function that directly calls the underlying
* kbase_hwcnt_context's kbase_hwcnt_context_queue_work.
*/
bool kbase_hwcnt_virtualizer_queue_work(struct kbase_hwcnt_virtualizer *hvirt,
struct work_struct *work);
#endif /* _KBASE_HWCNT_VIRTUALIZER_H_ */