On 2018-12-14 2:31 p.m., Wentland, Harry wrote: > On 2018-12-07 3:32 p.m., Kuehling, Felix wrote: >> On 2018-12-07 9:46 a.m., Wentland, Harry wrote: >>> On 2018-12-07 9:41 a.m., Wentland, Harry wrote: >>>> On 2018-12-07 12:40 a.m., Kuehling, Felix wrote: >>>>> This change seems to be breaking the build for me. I'm getting errors >>>>> like this: >>>>> >>>>> CC [M] drivers/gpu/drm/amd/amdgpu/../display/amdgpu_dm/amdgpu_dm.o >>>>> In file included from ../include/trace/events/tlb.h:9:0, >>>>> from ../arch/x86/include/asm/mmu_context.h:10, >>>>> from ../include/linux/mmu_context.h:5, >>>>> from ../drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd.h:30, >>>>> from ../drivers/gpu/drm/amd/amdgpu/amdgpu.h:85, >>>>> from >>>>> ../drivers/gpu/drm/amd/amdgpu/../display/amdgpu_dm/amdgpu_dm.c:34: >>>>> ../include/linux/tracepoint.h:285:20: error: redefinition of >>>>> â__tpstrtab_amdgpu_dc_rregâ >>>>> static const char __tpstrtab_##name[] \ >>>>> ^ >>>>> ../include/linux/tracepoint.h:293:2: note: in expansion of macro >>>>> âDEFINE_TRACE_FNâ >>>>> DEFINE_TRACE_FN(name, NULL, NULL); >>>>> ^ >>>>> ../include/trace/define_trace.h:28:2: note: in expansion of macro >>>>> âDEFINE_TRACEâ >>>>> DEFINE_TRACE(name) >>>>> ^ >>>>> ../drivers/gpu/drm/amd/amdgpu/../display/amdgpu_dm/./amdgpu_dm_trace.h:34:1: >>>>> note: in expansion of macro âTRACE_EVENTâ >>>>> TRACE_EVENT(amdgpu_dc_rreg, >>>>> ^ >>>>> >>>>> I have a local change that adds #include <amdgpu_amdkfd.h> to amdgpu.h, >>>>> which pulls in include/trace/events/tlb.h. That seems to create some kind >>>>> of conflict with trace definitions. Any ideas how to fix this? It seems a >>>>> bit fragile if adding some random include can break the build like this. >>>>> >>>> That's the trace subsystem for you. David and I are trying to understand >>>> what's going on. I think the problem is that both tlb.h and >>>> amdgpu_dm_trace.h define trace events and we now include both here. >>>> >>>> I think we'd want to include neither trace events from amdgpu.h to avoid >>>> this problem in the future, so we'll probably have to (a) clean up the >>>> dc.h include to only contain what amdgpu.h needs and (b) clean up >>>> amdgpu_amdkfd.h to only contain what amdgpu.h needs. At the end amdgpu.h >>>> doesn't care about the tracer. The problem seems that dc.h and >>>> amdgpu_amdkfd.h are the main includes for our respective drivers but are >>>> also wholesale included in amdgpu.h. >>>> >>> Apologies for the spam. >>> >>> Just noticed that amdgpu.h includes only amdgpu_dm.h which is clean. The >>> problem is that including amdgpu.h from amdgpu_dm.c now pulls in your trace >>> events (from tlb.h) which we don't expect and care about. I think we should >>> make sure amdgpu.h won't include anything that defines TRACE_EVENTs. >> amdgpu_amdkfd.h defines a macro that uses use_mm and unuse_mm. Therefore >> it needs to include mmu_context.h, which pulls in the conflicting trace >> events. Maybe we can move that into a different header file that doesn't >> get included in amdgpu.h. Or find another way to avoid including >> amdgpu_amdkfd.h in amdgpu.h. >> > It's defined but not used in amdgpu_amdkfd.h (at least in the amd-stg tree). > Couldn't you include mmu_context.h in the files that use it > (amdgpu_amdkfd_gfx_v7/8/9.c) instead and avoid the problem that way? Yes, that's what I ended up doing. I already fixed it in this commit:
commit 2a90860cfb895ff55d961a1b727d58bb68e213ba Author: Felix Kuehling <felix.kuehl...@amd.com> Date: Fri Dec 7 17:01:27 2018 -0500 drm/amdgpu: Workaround build failure due to trace conflict Avoid including mmu_context.h in amdgpu_amdkfd.h since that may be included in other header files that define traces. This leads to conflicts due to traces defined in other headers included via mmu_context.h. Signed-off-by: Felix Kuehling <felix.kuehl...@amd.com> Acked-by: Alex Deucher <alexander.deuc...@amd.com> Regards, Felix > > Harry > >> Thanks, >> Felix >> >> >> >>> Harry >>> >>>> Harry >>>> >>>>> Thanks, >>>>> Felix >>>>> >>>>> -----Original Message----- >>>>> From: amd-gfx <amd-gfx-boun...@lists.freedesktop.org> On Behalf Of David >>>>> Francis >>>>> Sent: Friday, November 30, 2018 9:57 AM >>>>> To: amd-gfx@lists.freedesktop.org >>>>> Cc: Francis, David <david.fran...@amd.com> >>>>> Subject: [PATCH 04/16 v2] drm/amd/display: Add tracing to dc >>>>> >>>>> [Why] >>>>> Tracing is a useful and cheap debug functionality >>>>> >>>>> [How] >>>>> This creates a new trace system amdgpu_dm, currently with three trace >>>>> events >>>>> >>>>> amdgpu_dc_rreg and amdgpu_dc_wreg report the address and value of any dc >>>>> register reads and writes >>>>> >>>>> amdgpu_dc_performance requires at least one of those two to be enabled. >>>>> It counts the register reads and writes since the last entry >>>>> >>>>> v2: Don't check for NULL before kfree >>>>> >>>>> Signed-off-by: David Francis <david.fran...@amd.com> >>>>> Reviewed-by: Harry Wentland <harry.wentl...@amd.com> >>>>> Acked-by: Leo Li <sunpeng...@amd.com> >>>>> --- >>>>> .../gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 3 + >>>>> .../amd/display/amdgpu_dm/amdgpu_dm_trace.h | 104 ++++++++++++++++++ >>>>> drivers/gpu/drm/amd/display/dc/core/dc.c | 19 ++++ >>>>> drivers/gpu/drm/amd/display/dc/dc_types.h | 8 ++ >>>>> .../amd/display/dc/dcn10/dcn10_cm_common.c | 4 +- >>>>> drivers/gpu/drm/amd/display/dc/dm_services.h | 12 +- >>>>> 6 files changed, 146 insertions(+), 4 deletions(-) create mode 100644 >>>>> drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_trace.h >>>>> >>>>> diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c >>>>> b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c >>>>> index 76b1aebdca0c..376927c8bcc6 100644 >>>>> --- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c >>>>> +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c >>>>> @@ -23,6 +23,9 @@ >>>>> * >>>>> */ >>>>> >>>>> +/* The caprices of the preprocessor require that this be declared right >>>>> +here */ #define CREATE_TRACE_POINTS >>>>> + >>>>> #include "dm_services_types.h" >>>>> #include "dc.h" >>>>> #include "dc/inc/core_types.h" >>>>> diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_trace.h >>>>> b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_trace.h >>>>> new file mode 100644 >>>>> index 000000000000..d898981684d5 >>>>> --- /dev/null >>>>> +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_trace.h >>>>> @@ -0,0 +1,104 @@ >>>>> +/* >>>>> + * Copyright 2018 Advanced Micro Devices, Inc. >>>>> + * >>>>> + * Permission is hereby granted, free of charge, to any person >>>>> +obtaining a >>>>> + * copy of this software and associated documentation files (the >>>>> +"Software"), >>>>> + * to deal in the Software without restriction, including without >>>>> +limitation >>>>> + * the rights to use, copy, modify, merge, publish, distribute, >>>>> +sublicense, >>>>> + * and/or sell copies of the Software, and to permit persons to whom >>>>> +the >>>>> + * Software is furnished to do so, subject to the following conditions: >>>>> + * >>>>> + * The above copyright notice and this permission notice shall be >>>>> +included in >>>>> + * all copies or substantial portions of the Software. >>>>> + * >>>>> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, >>>>> +EXPRESS OR >>>>> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF >>>>> +MERCHANTABILITY, >>>>> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT >>>>> +SHALL >>>>> + * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, >>>>> +DAMAGES OR >>>>> + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR >>>>> +OTHERWISE, >>>>> + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE >>>>> +OR >>>>> + * OTHER DEALINGS IN THE SOFTWARE. >>>>> + * >>>>> + * Authors: AMD >>>>> + * >>>>> + */ >>>>> + >>>>> +#undef TRACE_SYSTEM >>>>> +#define TRACE_SYSTEM amdgpu_dm >>>>> + >>>>> +#if !defined(_AMDGPU_DM_TRACE_H) || defined(TRACE_HEADER_MULTI_READ) >>>>> +#define _AMDGPU_DM_TRACE_H_ >>>>> + >>>>> +#include <linux/tracepoint.h> >>>>> + >>>>> +TRACE_EVENT(amdgpu_dc_rreg, >>>>> + TP_PROTO(unsigned long *read_count, uint32_t reg, uint32_t value), >>>>> + TP_ARGS(read_count, reg, value), >>>>> + TP_STRUCT__entry( >>>>> + __field(uint32_t, reg) >>>>> + __field(uint32_t, value) >>>>> + ), >>>>> + TP_fast_assign( >>>>> + __entry->reg = reg; >>>>> + __entry->value = value; >>>>> + *read_count = *read_count + 1; >>>>> + ), >>>>> + TP_printk("reg=0x%08lx, value=0x%08lx", >>>>> + (unsigned long)__entry->reg, >>>>> + (unsigned long)__entry->value) >>>>> +); >>>>> + >>>>> +TRACE_EVENT(amdgpu_dc_wreg, >>>>> + TP_PROTO(unsigned long *write_count, uint32_t reg, uint32_t value), >>>>> + TP_ARGS(write_count, reg, value), >>>>> + TP_STRUCT__entry( >>>>> + __field(uint32_t, reg) >>>>> + __field(uint32_t, value) >>>>> + ), >>>>> + TP_fast_assign( >>>>> + __entry->reg = reg; >>>>> + __entry->value = value; >>>>> + *write_count = *write_count + 1; >>>>> + ), >>>>> + TP_printk("reg=0x%08lx, value=0x%08lx", >>>>> + (unsigned long)__entry->reg, >>>>> + (unsigned long)__entry->value) >>>>> +); >>>>> + >>>>> + >>>>> +TRACE_EVENT(amdgpu_dc_performance, >>>>> + TP_PROTO(unsigned long read_count, unsigned long write_count, >>>>> + unsigned long *last_read, unsigned long *last_write, >>>>> + const char *func, unsigned int line), >>>>> + TP_ARGS(read_count, write_count, last_read, last_write, func, line), >>>>> + TP_STRUCT__entry( >>>>> + __field(uint32_t, reads) >>>>> + __field(uint32_t, writes) >>>>> + __field(uint32_t, read_delta) >>>>> + __field(uint32_t, write_delta) >>>>> + __string(func, func) >>>>> + __field(uint32_t, line) >>>>> + ), >>>>> + TP_fast_assign( >>>>> + __entry->reads = read_count; >>>>> + __entry->writes = write_count; >>>>> + __entry->read_delta = read_count - *last_read; >>>>> + __entry->write_delta = write_count - *last_write; >>>>> + __assign_str(func, func); >>>>> + __entry->line = line; >>>>> + *last_read = read_count; >>>>> + *last_write = write_count; >>>>> + ), >>>>> + TP_printk("%s:%d reads=%08ld (%08ld total), writes=%08ld (%08ld total)", >>>>> + __get_str(func), __entry->line, >>>>> + (unsigned long)__entry->read_delta, >>>>> + (unsigned long)__entry->reads, >>>>> + (unsigned long)__entry->write_delta, >>>>> + (unsigned long)__entry->writes) >>>>> +); >>>>> +#endif /* _AMDGPU_DM_TRACE_H_ */ >>>>> + >>>>> +#undef TRACE_INCLUDE_PATH >>>>> +#define TRACE_INCLUDE_PATH . >>>>> +#define TRACE_INCLUDE_FILE amdgpu_dm_trace #include >>>>> +<trace/define_trace.h> >>>>> diff --git a/drivers/gpu/drm/amd/display/dc/core/dc.c >>>>> b/drivers/gpu/drm/amd/display/dc/core/dc.c >>>>> index dba6b57830c7..3903b2c0a6f1 100644 >>>>> --- a/drivers/gpu/drm/amd/display/dc/core/dc.c >>>>> +++ b/drivers/gpu/drm/amd/display/dc/core/dc.c >>>>> @@ -175,6 +175,17 @@ static bool create_links( >>>>> return false; >>>>> } >>>>> >>>>> +static struct dc_perf_trace *dc_perf_trace_create(void) { >>>>> + return kzalloc(sizeof(struct dc_perf_trace), GFP_KERNEL); } >>>>> + >>>>> +static void dc_perf_trace_destroy(struct dc_perf_trace **perf_trace) { >>>>> + kfree(*perf_trace); >>>>> + *perf_trace = NULL; >>>>> +} >>>>> + >>>>> /** >>>>> >>>>> ***************************************************************************** >>>>> * Function: dc_stream_adjust_vmin_vmax @@ -536,6 +547,8 @@ static >>>>> void destruct(struct dc *dc) >>>>> if (dc->ctx->created_bios) >>>>> dal_bios_parser_destroy(&dc->ctx->dc_bios); >>>>> >>>>> + dc_perf_trace_destroy(&dc->ctx->perf_trace); >>>>> + >>>>> kfree(dc->ctx); >>>>> dc->ctx = NULL; >>>>> >>>>> @@ -659,6 +672,12 @@ static bool construct(struct dc *dc, >>>>> goto fail; >>>>> } >>>>> >>>>> + dc_ctx->perf_trace = dc_perf_trace_create(); >>>>> + if (!dc_ctx->perf_trace) { >>>>> + ASSERT_CRITICAL(false); >>>>> + goto fail; >>>>> + } >>>>> + >>>>> /* Create GPIO service */ >>>>> dc_ctx->gpio_service = dal_gpio_service_create( >>>>> dc_version, >>>>> diff --git a/drivers/gpu/drm/amd/display/dc/dc_types.h >>>>> b/drivers/gpu/drm/amd/display/dc/dc_types.h >>>>> index 6e12d640d020..8390baedaf71 100644 >>>>> --- a/drivers/gpu/drm/amd/display/dc/dc_types.h >>>>> +++ b/drivers/gpu/drm/amd/display/dc/dc_types.h >>>>> @@ -73,10 +73,18 @@ struct hw_asic_id { >>>>> void *atombios_base_address; >>>>> }; >>>>> >>>>> +struct dc_perf_trace { >>>>> + unsigned long read_count; >>>>> + unsigned long write_count; >>>>> + unsigned long last_entry_read; >>>>> + unsigned long last_entry_write; >>>>> +}; >>>>> + >>>>> struct dc_context { >>>>> struct dc *dc; >>>>> >>>>> void *driver_context; /* e.g. amdgpu_device */ >>>>> + struct dc_perf_trace *perf_trace; >>>>> void *cgs_device; >>>>> >>>>> enum dce_environment dce_environment; >>>>> diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_cm_common.c >>>>> b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_cm_common.c >>>>> index 3eea44092a04..7469333a2c8a 100644 >>>>> --- a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_cm_common.c >>>>> +++ b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_cm_common.c >>>>> @@ -324,7 +324,7 @@ bool cm_helper_translate_curve_to_hw_format( >>>>> if (output_tf == NULL || lut_params == NULL || output_tf->type >>>>> == TF_TYPE_BYPASS) >>>>> return false; >>>>> >>>>> - PERF_TRACE(); >>>>> + PERF_TRACE_CTX(output_tf->ctx); >>>>> >>>>> corner_points = lut_params->corner_points; >>>>> rgb_resulted = lut_params->rgb_resulted; @@ -513,7 +513,7 @@ >>>>> bool cm_helper_translate_curve_to_degamma_hw_format( >>>>> if (output_tf == NULL || lut_params == NULL || output_tf->type >>>>> == TF_TYPE_BYPASS) >>>>> return false; >>>>> >>>>> - PERF_TRACE(); >>>>> + PERF_TRACE_CTX(output_tf->ctx); >>>>> >>>>> corner_points = lut_params->corner_points; >>>>> rgb_resulted = lut_params->rgb_resulted; diff --git >>>>> a/drivers/gpu/drm/amd/display/dc/dm_services.h >>>>> b/drivers/gpu/drm/amd/display/dc/dm_services.h >>>>> index 28128c02de00..1961cc6d9143 100644 >>>>> --- a/drivers/gpu/drm/amd/display/dc/dm_services.h >>>>> +++ b/drivers/gpu/drm/amd/display/dc/dm_services.h >>>>> @@ -31,6 +31,8 @@ >>>>> >>>>> #define __DM_SERVICES_H__ >>>>> >>>>> +#include "amdgpu_dm_trace.h" >>>>> + >>>>> /* TODO: remove when DC is complete. */ #include "dm_services_types.h" >>>>> #include "logger_interface.h" >>>>> @@ -70,6 +72,7 @@ static inline uint32_t dm_read_reg_func( >>>>> } >>>>> #endif >>>>> value = cgs_read_register(ctx->cgs_device, address); >>>>> + trace_amdgpu_dc_rreg(&ctx->perf_trace->read_count, address, value); >>>>> >>>>> return value; >>>>> } >>>>> @@ -90,6 +93,7 @@ static inline void dm_write_reg_func( >>>>> } >>>>> #endif >>>>> cgs_write_register(ctx->cgs_device, address, value); >>>>> + trace_amdgpu_dc_wreg(&ctx->perf_trace->write_count, address, value); >>>>> } >>>>> >>>>> static inline uint32_t dm_read_index_reg( @@ -351,8 +355,12 @@ >>>>> unsigned long long dm_get_elapse_time_in_ns(struct dc_context *ctx, >>>>> /* >>>>> * performance tracing >>>>> */ >>>>> -void dm_perf_trace_timestamp(const char *func_name, unsigned int line); >>>>> -#define PERF_TRACE() dm_perf_trace_timestamp(__func__, __LINE__) >>>>> +#define PERF_TRACE() >>>>> trace_amdgpu_dc_performance(CTX->perf_trace->read_count,\ >>>>> + CTX->perf_trace->write_count, >>>>> &CTX->perf_trace->last_entry_read,\ >>>>> + &CTX->perf_trace->last_entry_write, __func__, __LINE__) >>>>> +#define PERF_TRACE_CTX(__CTX) >>>>> trace_amdgpu_dc_performance(__CTX->perf_trace->read_count,\ >>>>> + __CTX->perf_trace->write_count, >>>>> &__CTX->perf_trace->last_entry_read,\ >>>>> + &__CTX->perf_trace->last_entry_write, __func__, __LINE__) >>>>> >>>>> >>>>> /* >>>>> -- >>>>> 2.17.1 >>>>> >>>>> _______________________________________________ >>>>> amd-gfx mailing list >>>>> amd-gfx@lists.freedesktop.org >>>>> https://lists.freedesktop.org/mailman/listinfo/amd-gfx >>>>> _______________________________________________ >>>>> amd-gfx mailing list >>>>> amd-gfx@lists.freedesktop.org >>>>> https://lists.freedesktop.org/mailman/listinfo/amd-gfx >>>>> >>>> _______________________________________________ >>>> amd-gfx mailing list >>>> amd-gfx@lists.freedesktop.org >>>> https://lists.freedesktop.org/mailman/listinfo/amd-gfx >>>> > _______________________________________________ > amd-gfx mailing list > amd-gfx@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/amd-gfx _______________________________________________ amd-gfx mailing list amd-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/amd-gfx