/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
/*
|
*
|
* (C) COPYRIGHT 2012-2015, 2018, 2020-2022 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.
|
*
|
*/
|
|
/**
|
* DOC: Job Scheduler Context Attribute APIs
|
*/
|
|
#ifndef _KBASE_JS_CTX_ATTR_H_
|
#define _KBASE_JS_CTX_ATTR_H_
|
|
/**
|
* kbasep_js_ctx_attr_runpool_retain_ctx - Retain all attributes of a context
|
*
|
* @kbdev: KBase device
|
* @kctx: KBase context
|
*
|
* This occurs on scheduling in the context on the runpool (but after
|
* is_scheduled is set)
|
*
|
* Requires:
|
* - jsctx mutex
|
* - runpool_irq spinlock
|
* - ctx->is_scheduled is true
|
*/
|
void kbasep_js_ctx_attr_runpool_retain_ctx(struct kbase_device *kbdev, struct kbase_context *kctx);
|
|
/**
|
* kbasep_js_ctx_attr_runpool_release_ctx - Release all attributes of a context
|
*
|
* @kbdev: KBase device
|
* @kctx: KBase context
|
*
|
* This occurs on scheduling out the context from the runpool (but before
|
* is_scheduled is cleared)
|
*
|
* Requires:
|
* - jsctx mutex
|
* - runpool_irq spinlock
|
* - ctx->is_scheduled is true
|
*
|
* Return: true indicates a change in ctx attributes state of the runpool.
|
* In this state, the scheduler might be able to submit more jobs than
|
* previously, and so the caller should ensure kbasep_js_try_run_next_job_nolock()
|
* or similar is called sometime later.
|
* false indicates no change in ctx attributes state of the runpool.
|
*/
|
bool kbasep_js_ctx_attr_runpool_release_ctx(struct kbase_device *kbdev, struct kbase_context *kctx);
|
|
/**
|
* kbasep_js_ctx_attr_ctx_retain_atom - Retain all attributes of an atom
|
*
|
* @kbdev: KBase device
|
* @kctx: KBase context
|
* @katom: Atom
|
*
|
* This occurs on adding an atom to a context
|
*
|
* Requires:
|
* - jsctx mutex
|
* - If the context is scheduled, then runpool_irq spinlock must also be held
|
*/
|
void kbasep_js_ctx_attr_ctx_retain_atom(struct kbase_device *kbdev, struct kbase_context *kctx, struct kbase_jd_atom *katom);
|
|
/**
|
* kbasep_js_ctx_attr_ctx_release_atom - Release all attributes of an atom,
|
* given its retained state.
|
*
|
* @kbdev: KBase device
|
* @kctx: KBase context
|
* @katom_retained_state: Retained state
|
*
|
* This occurs after (permanently) removing an atom from a context
|
*
|
* Requires:
|
* - jsctx mutex
|
* - If the context is scheduled, then runpool_irq spinlock must also be held
|
*
|
* This is a no-op when \a katom_retained_state is invalid.
|
*
|
* Return: true indicates a change in ctx attributes state of the runpool.
|
* In this state, the scheduler might be able to submit more jobs than
|
* previously, and so the caller should ensure kbasep_js_try_run_next_job_nolock()
|
* or similar is called sometime later.
|
* false indicates no change in ctx attributes state of the runpool.
|
*/
|
bool kbasep_js_ctx_attr_ctx_release_atom(struct kbase_device *kbdev, struct kbase_context *kctx, struct kbasep_js_atom_retained_state *katom_retained_state);
|
|
/*
|
* Requires:
|
* - runpool_irq spinlock
|
*/
|
static inline s8 kbasep_js_ctx_attr_count_on_runpool(struct kbase_device *kbdev, enum kbasep_js_ctx_attr attribute)
|
{
|
struct kbasep_js_device_data *js_devdata;
|
|
KBASE_DEBUG_ASSERT(kbdev != NULL);
|
KBASE_DEBUG_ASSERT(attribute < KBASEP_JS_CTX_ATTR_COUNT);
|
js_devdata = &kbdev->js_data;
|
|
return js_devdata->runpool_irq.ctx_attr_ref_count[attribute];
|
}
|
|
/*
|
* Requires:
|
* - runpool_irq spinlock
|
*/
|
static inline bool kbasep_js_ctx_attr_is_attr_on_runpool(struct kbase_device *kbdev, enum kbasep_js_ctx_attr attribute)
|
{
|
/* In general, attributes are 'on' when they have a non-zero refcount (note: the refcount will never be < 0) */
|
return (bool) kbasep_js_ctx_attr_count_on_runpool(kbdev, attribute);
|
}
|
|
/*
|
* Requires:
|
* - jsctx mutex
|
*/
|
static inline bool kbasep_js_ctx_attr_is_attr_on_ctx(struct kbase_context *kctx, enum kbasep_js_ctx_attr attribute)
|
{
|
struct kbasep_js_kctx_info *js_kctx_info;
|
|
KBASE_DEBUG_ASSERT(kctx != NULL);
|
KBASE_DEBUG_ASSERT(attribute < KBASEP_JS_CTX_ATTR_COUNT);
|
js_kctx_info = &kctx->jctx.sched_info;
|
|
/* In general, attributes are 'on' when they have a refcount (which should never be < 0) */
|
return (bool) (js_kctx_info->ctx.ctx_attr_ref_count[attribute]);
|
}
|
|
#endif /* _KBASE_JS_DEFS_H_ */
|