Skip to content
Permalink
Browse files
soc: qcom: Add tracepoints to mdt loader
Add trace events to the mdt loader driver. These events
can help us trace the region where we are loading the
segments and the time it takes to initialize the image
and setup the memory region.

Signed-off-by: Rishabh Bhatnagar <rishabhb@codeaurora.org>
  • Loading branch information
Rishabh Bhatnagar authored and intel-lab-lkp committed Nov 16, 2020
1 parent 306e3e9 commit 437cc5c0ceb1f4b36564b99d7289af089576fdd0
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 0 deletions.
@@ -17,6 +17,9 @@
#include <linux/slab.h>
#include <linux/soc/qcom/mdt_loader.h>

#define CREATE_TRACE_POINTS
#include <trace/events/mdt_loader.h>

static bool mdt_phdr_valid(const struct elf32_phdr *phdr)
{
if (phdr->p_type != PT_LOAD)
@@ -198,6 +201,7 @@ static int __qcom_mdt_load(struct device *dev, const struct firmware *fw,
if (pas_init) {
ret = qcom_scm_pas_mem_setup(pas_id, mem_phys,
max_addr - min_addr);

if (ret) {
dev_err(dev, "unable to setup relocation\n");
goto out;
@@ -232,6 +236,7 @@ static int __qcom_mdt_load(struct device *dev, const struct firmware *fw,

ptr = mem_region + offset;


if (phdr->p_filesz && phdr->p_offset < fw->size) {
/* Firmware is large enough to be non-split */
if (phdr->p_offset + phdr->p_filesz > fw->size) {
@@ -256,6 +261,8 @@ static int __qcom_mdt_load(struct device *dev, const struct firmware *fw,
release_firmware(seg_fw);
}

trace_qcom_mdt_load_segment(mem_phys + offset, phdr->p_filesz,
fw_name);
if (phdr->p_memsz > phdr->p_filesz)
memset(ptr + phdr->p_filesz, 0, phdr->p_memsz - phdr->p_filesz);
}
@@ -0,0 +1,38 @@
/* SPDX-License-Identifier: GPL-2.0-only */
/*
* Copyright (c) 2020, The Linux Foundation. All rights reserved.
*/

#undef TRACE_SYSTEM
#define TRACE_SYSTEM mdt_loader

#if !defined(_TRACE_MDT_LOADER_H) || defined(TRACE_HEADER_MULTI_READ)
#define _TRACE_MDT_LOADER_H

#include <linux/types.h>
#include <linux/tracepoint.h>

TRACE_EVENT(qcom_mdt_load_segment,

TP_PROTO(phys_addr_t region_start, size_t region_size, const char *fw),

TP_ARGS(region_start, region_size, fw),

TP_STRUCT__entry(
__field(phys_addr_t, region_start)
__field(size_t, region_size)
__string(fw, fw)
),

TP_fast_assign(
__entry->region_start = region_start;
__entry->region_size = region_size;
__assign_str(fw, fw);
),

TP_printk("firmware:%s region start=%pa size=%zx",
__get_str(fw), __entry->region_start, __entry->region_size)
);

#endif
#include <trace/define_trace.h>

0 comments on commit 437cc5c

Please sign in to comment.