1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * Copyright 2017 Advanced Micro Devices, Inc. 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Permission is hereby granted, free of charge, to any person obtaining a 5*4882a593Smuzhiyun * copy of this software and associated documentation files (the "Software"), 6*4882a593Smuzhiyun * to deal in the Software without restriction, including without limitation 7*4882a593Smuzhiyun * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8*4882a593Smuzhiyun * and/or sell copies of the Software, and to permit persons to whom the 9*4882a593Smuzhiyun * Software is furnished to do so, subject to the following conditions: 10*4882a593Smuzhiyun * 11*4882a593Smuzhiyun * The above copyright notice and this permission notice shall be included in 12*4882a593Smuzhiyun * all copies or substantial portions of the Software. 13*4882a593Smuzhiyun * 14*4882a593Smuzhiyun * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15*4882a593Smuzhiyun * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16*4882a593Smuzhiyun * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 17*4882a593Smuzhiyun * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR 18*4882a593Smuzhiyun * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 19*4882a593Smuzhiyun * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 20*4882a593Smuzhiyun * OTHER DEALINGS IN THE SOFTWARE. 21*4882a593Smuzhiyun * 22*4882a593Smuzhiyun */ 23*4882a593Smuzhiyun 24*4882a593Smuzhiyun #if !defined(_GPU_SCHED_TRACE_H) || defined(TRACE_HEADER_MULTI_READ) 25*4882a593Smuzhiyun #define _GPU_SCHED_TRACE_H_ 26*4882a593Smuzhiyun 27*4882a593Smuzhiyun #include <linux/stringify.h> 28*4882a593Smuzhiyun #include <linux/types.h> 29*4882a593Smuzhiyun #include <linux/tracepoint.h> 30*4882a593Smuzhiyun 31*4882a593Smuzhiyun #undef TRACE_SYSTEM 32*4882a593Smuzhiyun #define TRACE_SYSTEM gpu_scheduler 33*4882a593Smuzhiyun #define TRACE_INCLUDE_FILE gpu_scheduler_trace 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun TRACE_EVENT(drm_sched_job, 36*4882a593Smuzhiyun TP_PROTO(struct drm_sched_job *sched_job, struct drm_sched_entity *entity), 37*4882a593Smuzhiyun TP_ARGS(sched_job, entity), 38*4882a593Smuzhiyun TP_STRUCT__entry( 39*4882a593Smuzhiyun __field(struct drm_sched_entity *, entity) 40*4882a593Smuzhiyun __field(struct dma_fence *, fence) 41*4882a593Smuzhiyun __field(const char *, name) 42*4882a593Smuzhiyun __field(uint64_t, id) 43*4882a593Smuzhiyun __field(u32, job_count) 44*4882a593Smuzhiyun __field(int, hw_job_count) 45*4882a593Smuzhiyun ), 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun TP_fast_assign( 48*4882a593Smuzhiyun __entry->entity = entity; 49*4882a593Smuzhiyun __entry->id = sched_job->id; 50*4882a593Smuzhiyun __entry->fence = &sched_job->s_fence->finished; 51*4882a593Smuzhiyun __entry->name = sched_job->sched->name; 52*4882a593Smuzhiyun __entry->job_count = spsc_queue_count(&entity->job_queue); 53*4882a593Smuzhiyun __entry->hw_job_count = atomic_read( 54*4882a593Smuzhiyun &sched_job->sched->hw_rq_count); 55*4882a593Smuzhiyun ), 56*4882a593Smuzhiyun TP_printk("entity=%p, id=%llu, fence=%p, ring=%s, job count:%u, hw job count:%d", 57*4882a593Smuzhiyun __entry->entity, __entry->id, 58*4882a593Smuzhiyun __entry->fence, __entry->name, 59*4882a593Smuzhiyun __entry->job_count, __entry->hw_job_count) 60*4882a593Smuzhiyun ); 61*4882a593Smuzhiyun 62*4882a593Smuzhiyun TRACE_EVENT(drm_run_job, 63*4882a593Smuzhiyun TP_PROTO(struct drm_sched_job *sched_job, struct drm_sched_entity *entity), 64*4882a593Smuzhiyun TP_ARGS(sched_job, entity), 65*4882a593Smuzhiyun TP_STRUCT__entry( 66*4882a593Smuzhiyun __field(struct drm_sched_entity *, entity) 67*4882a593Smuzhiyun __field(struct dma_fence *, fence) 68*4882a593Smuzhiyun __field(const char *, name) 69*4882a593Smuzhiyun __field(uint64_t, id) 70*4882a593Smuzhiyun __field(u32, job_count) 71*4882a593Smuzhiyun __field(int, hw_job_count) 72*4882a593Smuzhiyun ), 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun TP_fast_assign( 75*4882a593Smuzhiyun __entry->entity = entity; 76*4882a593Smuzhiyun __entry->id = sched_job->id; 77*4882a593Smuzhiyun __entry->fence = &sched_job->s_fence->finished; 78*4882a593Smuzhiyun __entry->name = sched_job->sched->name; 79*4882a593Smuzhiyun __entry->job_count = spsc_queue_count(&entity->job_queue); 80*4882a593Smuzhiyun __entry->hw_job_count = atomic_read( 81*4882a593Smuzhiyun &sched_job->sched->hw_rq_count); 82*4882a593Smuzhiyun ), 83*4882a593Smuzhiyun TP_printk("entity=%p, id=%llu, fence=%p, ring=%s, job count:%u, hw job count:%d", 84*4882a593Smuzhiyun __entry->entity, __entry->id, 85*4882a593Smuzhiyun __entry->fence, __entry->name, 86*4882a593Smuzhiyun __entry->job_count, __entry->hw_job_count) 87*4882a593Smuzhiyun ); 88*4882a593Smuzhiyun 89*4882a593Smuzhiyun TRACE_EVENT(drm_sched_process_job, 90*4882a593Smuzhiyun TP_PROTO(struct drm_sched_fence *fence), 91*4882a593Smuzhiyun TP_ARGS(fence), 92*4882a593Smuzhiyun TP_STRUCT__entry( 93*4882a593Smuzhiyun __field(struct dma_fence *, fence) 94*4882a593Smuzhiyun ), 95*4882a593Smuzhiyun 96*4882a593Smuzhiyun TP_fast_assign( 97*4882a593Smuzhiyun __entry->fence = &fence->finished; 98*4882a593Smuzhiyun ), 99*4882a593Smuzhiyun TP_printk("fence=%p signaled", __entry->fence) 100*4882a593Smuzhiyun ); 101*4882a593Smuzhiyun 102*4882a593Smuzhiyun TRACE_EVENT(drm_sched_job_wait_dep, 103*4882a593Smuzhiyun TP_PROTO(struct drm_sched_job *sched_job, struct dma_fence *fence), 104*4882a593Smuzhiyun TP_ARGS(sched_job, fence), 105*4882a593Smuzhiyun TP_STRUCT__entry( 106*4882a593Smuzhiyun __field(const char *,name) 107*4882a593Smuzhiyun __field(uint64_t, id) 108*4882a593Smuzhiyun __field(struct dma_fence *, fence) 109*4882a593Smuzhiyun __field(uint64_t, ctx) 110*4882a593Smuzhiyun __field(unsigned, seqno) 111*4882a593Smuzhiyun ), 112*4882a593Smuzhiyun 113*4882a593Smuzhiyun TP_fast_assign( 114*4882a593Smuzhiyun __entry->name = sched_job->sched->name; 115*4882a593Smuzhiyun __entry->id = sched_job->id; 116*4882a593Smuzhiyun __entry->fence = fence; 117*4882a593Smuzhiyun __entry->ctx = fence->context; 118*4882a593Smuzhiyun __entry->seqno = fence->seqno; 119*4882a593Smuzhiyun ), 120*4882a593Smuzhiyun TP_printk("job ring=%s, id=%llu, depends fence=%p, context=%llu, seq=%u", 121*4882a593Smuzhiyun __entry->name, __entry->id, 122*4882a593Smuzhiyun __entry->fence, __entry->ctx, 123*4882a593Smuzhiyun __entry->seqno) 124*4882a593Smuzhiyun ); 125*4882a593Smuzhiyun 126*4882a593Smuzhiyun #endif 127*4882a593Smuzhiyun 128*4882a593Smuzhiyun /* This part must be outside protection */ 129*4882a593Smuzhiyun #undef TRACE_INCLUDE_PATH 130*4882a593Smuzhiyun #define TRACE_INCLUDE_PATH ../../drivers/gpu/drm/scheduler 131*4882a593Smuzhiyun #include <trace/define_trace.h> 132