Commit aadd6ba4 authored by James Clark's avatar James Clark Committed by Arnaldo Carvalho de Melo

perf cs-etm: Refactor timestamp variable names

Remove ambiguity in variable names relating to timestamps.

A later commit will save the sample kernel timestamp in one of the etm
structs, so name all elements appropriately to avoid confusion.

This is also removes some ambiguity arising from the fact that the
--timestamp argument to perf record refers to sample kernel timestamps,
and the /timestamp/ event modifier refers to CS timestamps, so the term
is overloaded.
Signed-off-by: default avatarJames Clark <james.clark@arm.com>
Reviewed-by: default avatarMathieu Poirier <mathieu.poirier@linaro.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Al Grant <al.grant@arm.com>
Cc: Anshuman Khandual <anshuman.khandual@arm.com>
Cc: Branislav Rankov <branislav.rankov@arm.com>
Cc: Denis Nikitin <denik@chromium.org>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: John Garry <john.garry@huawei.com>
Cc: Leo Yan <leo.yan@linaro.org>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Mike Leach <mike.leach@linaro.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Suzuki Poulouse <suzuki.poulose@arm.com>
Cc: Will Deacon <will@kernel.org>
Cc: linux-arm-kernel@lists.infradead.org
Cc: coresight@lists.linaro.org
Link: https://lore.kernel.org/r/20210510143248.27423-2-james.clark@arm.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 046b243a
...@@ -276,13 +276,13 @@ cs_etm_decoder__do_soft_timestamp(struct cs_etm_queue *etmq, ...@@ -276,13 +276,13 @@ cs_etm_decoder__do_soft_timestamp(struct cs_etm_queue *etmq,
const uint8_t trace_chan_id) const uint8_t trace_chan_id)
{ {
/* No timestamp packet has been received, nothing to do */ /* No timestamp packet has been received, nothing to do */
if (!packet_queue->timestamp) if (!packet_queue->cs_timestamp)
return OCSD_RESP_CONT; return OCSD_RESP_CONT;
packet_queue->timestamp = packet_queue->next_timestamp; packet_queue->cs_timestamp = packet_queue->next_cs_timestamp;
/* Estimate the timestamp for the next range packet */ /* Estimate the timestamp for the next range packet */
packet_queue->next_timestamp += packet_queue->instr_count; packet_queue->next_cs_timestamp += packet_queue->instr_count;
packet_queue->instr_count = 0; packet_queue->instr_count = 0;
/* Tell the front end which traceid_queue needs attention */ /* Tell the front end which traceid_queue needs attention */
...@@ -308,8 +308,8 @@ cs_etm_decoder__do_hard_timestamp(struct cs_etm_queue *etmq, ...@@ -308,8 +308,8 @@ cs_etm_decoder__do_hard_timestamp(struct cs_etm_queue *etmq,
* Function do_soft_timestamp() will report the value to the front end, * Function do_soft_timestamp() will report the value to the front end,
* hence asking the decoder to keep decoding rather than stopping. * hence asking the decoder to keep decoding rather than stopping.
*/ */
if (packet_queue->timestamp) { if (packet_queue->cs_timestamp) {
packet_queue->next_timestamp = elem->timestamp; packet_queue->next_cs_timestamp = elem->timestamp;
return OCSD_RESP_CONT; return OCSD_RESP_CONT;
} }
...@@ -320,8 +320,8 @@ cs_etm_decoder__do_hard_timestamp(struct cs_etm_queue *etmq, ...@@ -320,8 +320,8 @@ cs_etm_decoder__do_hard_timestamp(struct cs_etm_queue *etmq,
* which instructions started by subtracting the number of instructions * which instructions started by subtracting the number of instructions
* executed to the timestamp. * executed to the timestamp.
*/ */
packet_queue->timestamp = elem->timestamp - packet_queue->instr_count; packet_queue->cs_timestamp = elem->timestamp - packet_queue->instr_count;
packet_queue->next_timestamp = elem->timestamp; packet_queue->next_cs_timestamp = elem->timestamp;
packet_queue->instr_count = 0; packet_queue->instr_count = 0;
/* Tell the front end which traceid_queue needs attention */ /* Tell the front end which traceid_queue needs attention */
...@@ -334,8 +334,8 @@ cs_etm_decoder__do_hard_timestamp(struct cs_etm_queue *etmq, ...@@ -334,8 +334,8 @@ cs_etm_decoder__do_hard_timestamp(struct cs_etm_queue *etmq,
static void static void
cs_etm_decoder__reset_timestamp(struct cs_etm_packet_queue *packet_queue) cs_etm_decoder__reset_timestamp(struct cs_etm_packet_queue *packet_queue)
{ {
packet_queue->timestamp = 0; packet_queue->cs_timestamp = 0;
packet_queue->next_timestamp = 0; packet_queue->next_cs_timestamp = 0;
packet_queue->instr_count = 0; packet_queue->instr_count = 0;
} }
......
...@@ -38,8 +38,6 @@ ...@@ -38,8 +38,6 @@
#include <tools/libc_compat.h> #include <tools/libc_compat.h>
#include "util/synthetic-events.h" #include "util/synthetic-events.h"
#define MAX_TIMESTAMP (~0ULL)
struct cs_etm_auxtrace { struct cs_etm_auxtrace {
struct auxtrace auxtrace; struct auxtrace auxtrace;
struct auxtrace_queues queues; struct auxtrace_queues queues;
...@@ -86,7 +84,7 @@ struct cs_etm_queue { ...@@ -86,7 +84,7 @@ struct cs_etm_queue {
struct cs_etm_decoder *decoder; struct cs_etm_decoder *decoder;
struct auxtrace_buffer *buffer; struct auxtrace_buffer *buffer;
unsigned int queue_nr; unsigned int queue_nr;
u8 pending_timestamp; u8 pending_timestamp_chan_id;
u64 offset; u64 offset;
const unsigned char *buf; const unsigned char *buf;
size_t buf_len, buf_used; size_t buf_len, buf_used;
...@@ -208,7 +206,7 @@ void cs_etm__etmq_set_traceid_queue_timestamp(struct cs_etm_queue *etmq, ...@@ -208,7 +206,7 @@ void cs_etm__etmq_set_traceid_queue_timestamp(struct cs_etm_queue *etmq,
* be more than one channel per cs_etm_queue, we need to specify * be more than one channel per cs_etm_queue, we need to specify
* what traceID queue needs servicing. * what traceID queue needs servicing.
*/ */
etmq->pending_timestamp = trace_chan_id; etmq->pending_timestamp_chan_id = trace_chan_id;
} }
static u64 cs_etm__etmq_get_timestamp(struct cs_etm_queue *etmq, static u64 cs_etm__etmq_get_timestamp(struct cs_etm_queue *etmq,
...@@ -216,22 +214,22 @@ static u64 cs_etm__etmq_get_timestamp(struct cs_etm_queue *etmq, ...@@ -216,22 +214,22 @@ static u64 cs_etm__etmq_get_timestamp(struct cs_etm_queue *etmq,
{ {
struct cs_etm_packet_queue *packet_queue; struct cs_etm_packet_queue *packet_queue;
if (!etmq->pending_timestamp) if (!etmq->pending_timestamp_chan_id)
return 0; return 0;
if (trace_chan_id) if (trace_chan_id)
*trace_chan_id = etmq->pending_timestamp; *trace_chan_id = etmq->pending_timestamp_chan_id;
packet_queue = cs_etm__etmq_get_packet_queue(etmq, packet_queue = cs_etm__etmq_get_packet_queue(etmq,
etmq->pending_timestamp); etmq->pending_timestamp_chan_id);
if (!packet_queue) if (!packet_queue)
return 0; return 0;
/* Acknowledge pending status */ /* Acknowledge pending status */
etmq->pending_timestamp = 0; etmq->pending_timestamp_chan_id = 0;
/* See function cs_etm_decoder__do_{hard|soft}_timestamp() */ /* See function cs_etm_decoder__do_{hard|soft}_timestamp() */
return packet_queue->timestamp; return packet_queue->cs_timestamp;
} }
static void cs_etm__clear_packet_queue(struct cs_etm_packet_queue *queue) static void cs_etm__clear_packet_queue(struct cs_etm_packet_queue *queue)
...@@ -814,7 +812,7 @@ static int cs_etm__setup_queue(struct cs_etm_auxtrace *etm, ...@@ -814,7 +812,7 @@ static int cs_etm__setup_queue(struct cs_etm_auxtrace *etm,
int ret = 0; int ret = 0;
unsigned int cs_queue_nr; unsigned int cs_queue_nr;
u8 trace_chan_id; u8 trace_chan_id;
u64 timestamp; u64 cs_timestamp;
struct cs_etm_queue *etmq = queue->priv; struct cs_etm_queue *etmq = queue->priv;
if (list_empty(&queue->head) || etmq) if (list_empty(&queue->head) || etmq)
...@@ -854,7 +852,7 @@ static int cs_etm__setup_queue(struct cs_etm_auxtrace *etm, ...@@ -854,7 +852,7 @@ static int cs_etm__setup_queue(struct cs_etm_auxtrace *etm,
/* /*
* Run decoder on the trace block. The decoder will stop when * Run decoder on the trace block. The decoder will stop when
* encountering a timestamp, a full packet queue or the end of * encountering a CS timestamp, a full packet queue or the end of
* trace for that block. * trace for that block.
*/ */
ret = cs_etm__decode_data_block(etmq); ret = cs_etm__decode_data_block(etmq);
...@@ -865,10 +863,10 @@ static int cs_etm__setup_queue(struct cs_etm_auxtrace *etm, ...@@ -865,10 +863,10 @@ static int cs_etm__setup_queue(struct cs_etm_auxtrace *etm,
* Function cs_etm_decoder__do_{hard|soft}_timestamp() does all * Function cs_etm_decoder__do_{hard|soft}_timestamp() does all
* the timestamp calculation for us. * the timestamp calculation for us.
*/ */
timestamp = cs_etm__etmq_get_timestamp(etmq, &trace_chan_id); cs_timestamp = cs_etm__etmq_get_timestamp(etmq, &trace_chan_id);
/* We found a timestamp, no need to continue. */ /* We found a timestamp, no need to continue. */
if (timestamp) if (cs_timestamp)
break; break;
/* /*
...@@ -892,7 +890,7 @@ static int cs_etm__setup_queue(struct cs_etm_auxtrace *etm, ...@@ -892,7 +890,7 @@ static int cs_etm__setup_queue(struct cs_etm_auxtrace *etm,
* queue and will be processed in cs_etm__process_queues(). * queue and will be processed in cs_etm__process_queues().
*/ */
cs_queue_nr = TO_CS_QUEUE_NR(queue_nr, trace_chan_id); cs_queue_nr = TO_CS_QUEUE_NR(queue_nr, trace_chan_id);
ret = auxtrace_heap__add(&etm->heap, cs_queue_nr, timestamp); ret = auxtrace_heap__add(&etm->heap, cs_queue_nr, cs_timestamp);
out: out:
return ret; return ret;
} }
...@@ -2221,7 +2219,7 @@ static int cs_etm__process_queues(struct cs_etm_auxtrace *etm) ...@@ -2221,7 +2219,7 @@ static int cs_etm__process_queues(struct cs_etm_auxtrace *etm)
int ret = 0; int ret = 0;
unsigned int cs_queue_nr, queue_nr; unsigned int cs_queue_nr, queue_nr;
u8 trace_chan_id; u8 trace_chan_id;
u64 timestamp; u64 cs_timestamp;
struct auxtrace_queue *queue; struct auxtrace_queue *queue;
struct cs_etm_queue *etmq; struct cs_etm_queue *etmq;
struct cs_etm_traceid_queue *tidq; struct cs_etm_traceid_queue *tidq;
...@@ -2283,9 +2281,9 @@ static int cs_etm__process_queues(struct cs_etm_auxtrace *etm) ...@@ -2283,9 +2281,9 @@ static int cs_etm__process_queues(struct cs_etm_auxtrace *etm)
if (ret) if (ret)
goto out; goto out;
timestamp = cs_etm__etmq_get_timestamp(etmq, &trace_chan_id); cs_timestamp = cs_etm__etmq_get_timestamp(etmq, &trace_chan_id);
if (!timestamp) { if (!cs_timestamp) {
/* /*
* Function cs_etm__decode_data_block() returns when * Function cs_etm__decode_data_block() returns when
* there is no more traces to decode in the current * there is no more traces to decode in the current
...@@ -2308,7 +2306,7 @@ static int cs_etm__process_queues(struct cs_etm_auxtrace *etm) ...@@ -2308,7 +2306,7 @@ static int cs_etm__process_queues(struct cs_etm_auxtrace *etm)
* this queue/traceID. * this queue/traceID.
*/ */
cs_queue_nr = TO_CS_QUEUE_NR(queue_nr, trace_chan_id); cs_queue_nr = TO_CS_QUEUE_NR(queue_nr, trace_chan_id);
ret = auxtrace_heap__add(&etm->heap, cs_queue_nr, timestamp); ret = auxtrace_heap__add(&etm->heap, cs_queue_nr, cs_timestamp);
} }
out: out:
...@@ -2380,7 +2378,7 @@ static int cs_etm__process_event(struct perf_session *session, ...@@ -2380,7 +2378,7 @@ static int cs_etm__process_event(struct perf_session *session,
struct perf_tool *tool) struct perf_tool *tool)
{ {
int err = 0; int err = 0;
u64 timestamp; u64 sample_kernel_timestamp;
struct cs_etm_auxtrace *etm = container_of(session->auxtrace, struct cs_etm_auxtrace *etm = container_of(session->auxtrace,
struct cs_etm_auxtrace, struct cs_etm_auxtrace,
auxtrace); auxtrace);
...@@ -2394,11 +2392,11 @@ static int cs_etm__process_event(struct perf_session *session, ...@@ -2394,11 +2392,11 @@ static int cs_etm__process_event(struct perf_session *session,
} }
if (sample->time && (sample->time != (u64) -1)) if (sample->time && (sample->time != (u64) -1))
timestamp = sample->time; sample_kernel_timestamp = sample->time;
else else
timestamp = 0; sample_kernel_timestamp = 0;
if (timestamp || etm->timeless_decoding) { if (sample_kernel_timestamp || etm->timeless_decoding) {
err = cs_etm__update_queues(etm); err = cs_etm__update_queues(etm);
if (err) if (err)
return err; return err;
......
...@@ -171,8 +171,8 @@ struct cs_etm_packet_queue { ...@@ -171,8 +171,8 @@ struct cs_etm_packet_queue {
u32 head; u32 head;
u32 tail; u32 tail;
u32 instr_count; u32 instr_count;
u64 timestamp; u64 cs_timestamp;
u64 next_timestamp; u64 next_cs_timestamp;
struct cs_etm_packet packet_buffer[CS_ETM_PACKET_MAX_BUFFER]; struct cs_etm_packet packet_buffer[CS_ETM_PACKET_MAX_BUFFER];
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment