/* 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_ */
|