#include <linux/sched/clock.h>
#include <linux/kthread.h>
#include <drm/drm_syncobj.h>
#include "v3d_drv.h"
#include "v3d_regs.h"
#include "v3d_trace.h"
#define V3D_CSD_CFG012_WG_COUNT_SHIFT …
static struct v3d_job *
to_v3d_job(struct drm_sched_job *sched_job)
{ … }
static struct v3d_bin_job *
to_bin_job(struct drm_sched_job *sched_job)
{ … }
static struct v3d_render_job *
to_render_job(struct drm_sched_job *sched_job)
{ … }
static struct v3d_tfu_job *
to_tfu_job(struct drm_sched_job *sched_job)
{ … }
static struct v3d_csd_job *
to_csd_job(struct drm_sched_job *sched_job)
{ … }
static struct v3d_cpu_job *
to_cpu_job(struct drm_sched_job *sched_job)
{ … }
static void
v3d_sched_job_free(struct drm_sched_job *sched_job)
{ … }
void
v3d_timestamp_query_info_free(struct v3d_timestamp_query_info *query_info,
unsigned int count)
{ … }
void
v3d_performance_query_info_free(struct v3d_performance_query_info *query_info,
unsigned int count)
{ … }
static void
v3d_cpu_job_free(struct drm_sched_job *sched_job)
{ … }
static void
v3d_switch_perfmon(struct v3d_dev *v3d, struct v3d_job *job)
{ … }
static void
v3d_job_start_stats(struct v3d_job *job, enum v3d_queue queue)
{ … }
static void
v3d_stats_update(struct v3d_stats *stats, u64 now)
{ … }
void
v3d_job_update_stats(struct v3d_job *job, enum v3d_queue queue)
{ … }
static struct dma_fence *v3d_bin_job_run(struct drm_sched_job *sched_job)
{ … }
static struct dma_fence *v3d_render_job_run(struct drm_sched_job *sched_job)
{ … }
static struct dma_fence *
v3d_tfu_job_run(struct drm_sched_job *sched_job)
{ … }
static struct dma_fence *
v3d_csd_job_run(struct drm_sched_job *sched_job)
{ … }
static void
v3d_rewrite_csd_job_wg_counts_from_indirect(struct v3d_cpu_job *job)
{ … }
static void
v3d_timestamp_query(struct v3d_cpu_job *job)
{ … }
static void
v3d_reset_timestamp_queries(struct v3d_cpu_job *job)
{ … }
static void write_to_buffer_32(u32 *dst, unsigned int idx, u32 value)
{ … }
static void write_to_buffer_64(u64 *dst, unsigned int idx, u64 value)
{ … }
static void
write_to_buffer(void *dst, unsigned int idx, bool do_64bit, u64 value)
{ … }
static void
v3d_copy_query_results(struct v3d_cpu_job *job)
{ … }
static void
v3d_reset_performance_queries(struct v3d_cpu_job *job)
{ … }
static void
v3d_write_performance_query_result(struct v3d_cpu_job *job, void *data,
unsigned int query)
{ … }
static void
v3d_copy_performance_query(struct v3d_cpu_job *job)
{ … }
static const v3d_cpu_job_fn cpu_job_function[] = …;
static struct dma_fence *
v3d_cpu_job_run(struct drm_sched_job *sched_job)
{ … }
static struct dma_fence *
v3d_cache_clean_job_run(struct drm_sched_job *sched_job)
{ … }
static enum drm_gpu_sched_stat
v3d_gpu_reset_for_timeout(struct v3d_dev *v3d, struct drm_sched_job *sched_job)
{ … }
static enum drm_gpu_sched_stat
v3d_cl_job_timedout(struct drm_sched_job *sched_job, enum v3d_queue q,
u32 *timedout_ctca, u32 *timedout_ctra)
{ … }
static enum drm_gpu_sched_stat
v3d_bin_job_timedout(struct drm_sched_job *sched_job)
{ … }
static enum drm_gpu_sched_stat
v3d_render_job_timedout(struct drm_sched_job *sched_job)
{ … }
static enum drm_gpu_sched_stat
v3d_generic_job_timedout(struct drm_sched_job *sched_job)
{ … }
static enum drm_gpu_sched_stat
v3d_csd_job_timedout(struct drm_sched_job *sched_job)
{ … }
static const struct drm_sched_backend_ops v3d_bin_sched_ops = …;
static const struct drm_sched_backend_ops v3d_render_sched_ops = …;
static const struct drm_sched_backend_ops v3d_tfu_sched_ops = …;
static const struct drm_sched_backend_ops v3d_csd_sched_ops = …;
static const struct drm_sched_backend_ops v3d_cache_clean_sched_ops = …;
static const struct drm_sched_backend_ops v3d_cpu_sched_ops = …;
int
v3d_sched_init(struct v3d_dev *v3d)
{ … }
void
v3d_sched_fini(struct v3d_dev *v3d)
{ … }