From 543a904e630dfe78b193803ad04d2bd12380c2b0 Mon Sep 17 00:00:00 2001 From: Debarshi Dutta Date: Thu, 9 May 2019 11:33:35 +0530 Subject: gpu: nvgpu: fecs ctxsw trace for gm20b Register gk20a non-arch-specific functions for gm20b gpu_ops.fecs_trace, Register nvgpu_os_linux_ops.fecs_trace.init_debugfs gp10b_fecs_trace_flush is now replaced by gm20b_fecs_trace_flush in fecs_trace_gm20b.* and the fecs_trace_gp10b.* files are removed. Bug 2052906 Change-Id: I245c91ae8e6015b87bafeb3ec023b98fe4c57501 Signed-off-by: Debarshi Dutta Reviewed-on: https://git-master.nvidia.com/r/2115247 Reviewed-by: mobile promotions Tested-by: mobile promotions --- drivers/gpu/nvgpu/gm20b/fecs_trace_gm20b.c | 56 ++++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 drivers/gpu/nvgpu/gm20b/fecs_trace_gm20b.c (limited to 'drivers/gpu/nvgpu/gm20b/fecs_trace_gm20b.c') diff --git a/drivers/gpu/nvgpu/gm20b/fecs_trace_gm20b.c b/drivers/gpu/nvgpu/gm20b/fecs_trace_gm20b.c new file mode 100644 index 00000000..84772af5 --- /dev/null +++ b/drivers/gpu/nvgpu/gm20b/fecs_trace_gm20b.c @@ -0,0 +1,56 @@ +/* + * GP10B GPU FECS traces + * + * Copyright (c) 2016-2018, NVIDIA CORPORATION. All rights reserved. + * + * 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 AUTHORS OR COPYRIGHT HOLDERS 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. + */ + +#include + +#include "gk20a/fecs_trace_gk20a.h" + +#include "fecs_trace_gm20b.h" + +#include +#include + +#ifdef CONFIG_GK20A_CTXSW_TRACE +int gm20b_fecs_trace_flush(struct gk20a *g) +{ + struct fecs_method_op_gk20a op = { + .mailbox = { .id = 0, .data = 0, + .clr = ~0, .ok = 0, .fail = 0}, + .method.addr = gr_fecs_method_push_adr_write_timestamp_record_v(), + .method.data = 0, + .cond.ok = GR_IS_UCODE_OP_NOT_EQUAL, + .cond.fail = GR_IS_UCODE_OP_SKIP, + }; + int err; + + nvgpu_log(g, gpu_dbg_fn|gpu_dbg_ctxsw, " "); + + err = gr_gk20a_elpg_protected_call(g, + gr_gk20a_submit_fecs_method_op(g, op, false)); + if (err) + nvgpu_err(g, "write timestamp record failed"); + + return err; +} +#endif /* CONFIG_GK20A_CTXSW_TRACE */ -- cgit v1.2.2