1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun #undef TRACE_SYSTEM 3*4882a593Smuzhiyun #define TRACE_SYSTEM thermal_power_allocator 4*4882a593Smuzhiyun 5*4882a593Smuzhiyun #if !defined(_TRACE_THERMAL_POWER_ALLOCATOR_H) || defined(TRACE_HEADER_MULTI_READ) 6*4882a593Smuzhiyun #define _TRACE_THERMAL_POWER_ALLOCATOR_H 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun #include <linux/tracepoint.h> 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun TRACE_EVENT(thermal_power_allocator, 11*4882a593Smuzhiyun TP_PROTO(struct thermal_zone_device *tz, u32 *req_power, 12*4882a593Smuzhiyun u32 total_req_power, u32 *granted_power, 13*4882a593Smuzhiyun u32 total_granted_power, size_t num_actors, 14*4882a593Smuzhiyun u32 power_range, u32 max_allocatable_power, 15*4882a593Smuzhiyun int current_temp, s32 delta_temp), 16*4882a593Smuzhiyun TP_ARGS(tz, req_power, total_req_power, granted_power, 17*4882a593Smuzhiyun total_granted_power, num_actors, power_range, 18*4882a593Smuzhiyun max_allocatable_power, current_temp, delta_temp), 19*4882a593Smuzhiyun TP_STRUCT__entry( 20*4882a593Smuzhiyun __field(int, tz_id ) 21*4882a593Smuzhiyun __dynamic_array(u32, req_power, num_actors ) 22*4882a593Smuzhiyun __field(u32, total_req_power ) 23*4882a593Smuzhiyun __dynamic_array(u32, granted_power, num_actors) 24*4882a593Smuzhiyun __field(u32, total_granted_power ) 25*4882a593Smuzhiyun __field(size_t, num_actors ) 26*4882a593Smuzhiyun __field(u32, power_range ) 27*4882a593Smuzhiyun __field(u32, max_allocatable_power ) 28*4882a593Smuzhiyun __field(int, current_temp ) 29*4882a593Smuzhiyun __field(s32, delta_temp ) 30*4882a593Smuzhiyun ), 31*4882a593Smuzhiyun TP_fast_assign( 32*4882a593Smuzhiyun __entry->tz_id = tz->id; 33*4882a593Smuzhiyun memcpy(__get_dynamic_array(req_power), req_power, 34*4882a593Smuzhiyun num_actors * sizeof(*req_power)); 35*4882a593Smuzhiyun __entry->total_req_power = total_req_power; 36*4882a593Smuzhiyun memcpy(__get_dynamic_array(granted_power), granted_power, 37*4882a593Smuzhiyun num_actors * sizeof(*granted_power)); 38*4882a593Smuzhiyun __entry->total_granted_power = total_granted_power; 39*4882a593Smuzhiyun __entry->num_actors = num_actors; 40*4882a593Smuzhiyun __entry->power_range = power_range; 41*4882a593Smuzhiyun __entry->max_allocatable_power = max_allocatable_power; 42*4882a593Smuzhiyun __entry->current_temp = current_temp; 43*4882a593Smuzhiyun __entry->delta_temp = delta_temp; 44*4882a593Smuzhiyun ), 45*4882a593Smuzhiyun 46*4882a593Smuzhiyun TP_printk("thermal_zone_id=%d req_power={%s} total_req_power=%u granted_power={%s} total_granted_power=%u power_range=%u max_allocatable_power=%u current_temperature=%d delta_temperature=%d", 47*4882a593Smuzhiyun __entry->tz_id, 48*4882a593Smuzhiyun __print_array(__get_dynamic_array(req_power), 49*4882a593Smuzhiyun __entry->num_actors, 4), 50*4882a593Smuzhiyun __entry->total_req_power, 51*4882a593Smuzhiyun __print_array(__get_dynamic_array(granted_power), 52*4882a593Smuzhiyun __entry->num_actors, 4), 53*4882a593Smuzhiyun __entry->total_granted_power, __entry->power_range, 54*4882a593Smuzhiyun __entry->max_allocatable_power, __entry->current_temp, 55*4882a593Smuzhiyun __entry->delta_temp) 56*4882a593Smuzhiyun ); 57*4882a593Smuzhiyun 58*4882a593Smuzhiyun TRACE_EVENT(thermal_power_allocator_pid, 59*4882a593Smuzhiyun TP_PROTO(struct thermal_zone_device *tz, s32 err, s32 err_integral, 60*4882a593Smuzhiyun s64 p, s64 i, s64 d, s32 output), 61*4882a593Smuzhiyun TP_ARGS(tz, err, err_integral, p, i, d, output), 62*4882a593Smuzhiyun TP_STRUCT__entry( 63*4882a593Smuzhiyun __field(int, tz_id ) 64*4882a593Smuzhiyun __field(s32, err ) 65*4882a593Smuzhiyun __field(s32, err_integral) 66*4882a593Smuzhiyun __field(s64, p ) 67*4882a593Smuzhiyun __field(s64, i ) 68*4882a593Smuzhiyun __field(s64, d ) 69*4882a593Smuzhiyun __field(s32, output ) 70*4882a593Smuzhiyun ), 71*4882a593Smuzhiyun TP_fast_assign( 72*4882a593Smuzhiyun __entry->tz_id = tz->id; 73*4882a593Smuzhiyun __entry->err = err; 74*4882a593Smuzhiyun __entry->err_integral = err_integral; 75*4882a593Smuzhiyun __entry->p = p; 76*4882a593Smuzhiyun __entry->i = i; 77*4882a593Smuzhiyun __entry->d = d; 78*4882a593Smuzhiyun __entry->output = output; 79*4882a593Smuzhiyun ), 80*4882a593Smuzhiyun 81*4882a593Smuzhiyun TP_printk("thermal_zone_id=%d err=%d err_integral=%d p=%lld i=%lld d=%lld output=%d", 82*4882a593Smuzhiyun __entry->tz_id, __entry->err, __entry->err_integral, 83*4882a593Smuzhiyun __entry->p, __entry->i, __entry->d, __entry->output) 84*4882a593Smuzhiyun ); 85*4882a593Smuzhiyun #endif /* _TRACE_THERMAL_POWER_ALLOCATOR_H */ 86*4882a593Smuzhiyun 87*4882a593Smuzhiyun /* This part must be outside protection */ 88*4882a593Smuzhiyun #include <trace/define_trace.h> 89