From: Tzvetomir Stoyanov <tz.stoyanov@gmail.com>
To: Steven Rostedt <rostedt@goodmis.org>
Cc: linux-trace-devel@vger.kernel.org
Subject: Re: [PATCH v17 12/18] trace-cmd: Implement new option in trace.dat file: TRACECMD_OPTION_TIME_SHIFT
Date: Thu, 5 Dec 2019 17:09:29 +0200 [thread overview]
Message-ID: <CAPpZLN5Fb29dCnHWBDdLt9d9guikb6KqawhYCwqcZVp91rAWBw@mail.gmail.com> (raw)
In-Reply-To: <20191204194650.7055bc1c@gandalf.local.home>
On Thu, Dec 5, 2019 at 2:46 AM Steven Rostedt <rostedt@goodmis.org> wrote:
[ ... ]
> > +static inline unsigned long long
> > +timestamp_correction_calc(unsigned long long ts, struct ts_offset_sample *min,
> > + struct ts_offset_sample *max)
> > +{
> > + long long tscor = min->offset +
> > + (((((long long)ts) - min->time)*
> > + (max->offset-min->offset))/(max->time-min->time));
>
> When every I see a division like this, I'd like to think we should add:
>
> long long offset = ((long long)ts - min->time) *
> (max->offset - min->offset);
> long long delta = max->time - min->time;
> long long tscor = min->offset +
> (offset + delta / 2) / delta;
>
> This handles rounding of delta instead of truncating. Also, it's best
> to have spaces around operators, as it's hard to see where the variable
> stops and the operation beings with max->time-min->time.
>
> > +
> > + if (tscor < 0)
> > + return ts - llabs(tscor);
>
> I'm curious to why the test and using llabs, instead of just returning:
>
> ts + tscor ?
>
> Is there a difference between that when tscor is negative and using
> llabs?
>
The only reason to use llabs() is mixed signed - unsigned calculation. As time
correction tscor can be negative, will it be converted to unsigned in
"ts + tscor" ?
> > +
> > + return ts + tscor;
> > +}
> > +
> > +static unsigned long long timestamp_correct(unsigned long long ts,
> > + struct tracecmd_input *handle)
> > +{
> > + struct host_trace_info *host = &handle->host;
> > + int min, mid, max;
> > +
> > + if (handle->ts_offset)
> > + return ts + handle->ts_offset;
> > +
> > + if (!host->sync_enable || !host->ts_samples_count || !host->ts_samples)
> > + return ts;
>
> Hmm, perhaps we should make host->sync_enable false when
> host->ts_samples_count or host->ts_samples are NULL and remove the
> extra checks? (slight optimization)
>
> > +
> > + /* We have one sample, nothing to calc here */
> > + if (host->ts_samples_count == 1)
> > + return ts + host->ts_samples[0].offset;
> > +
> > + /* We have two samples, nothing to search here */
> > + if (host->ts_samples_count == 2)
> > + return timestamp_correction_calc(ts, &host->ts_samples[0],
> > + &host->ts_samples[1]);
> > +
> > + /* We have more than two samples */
> > + if (ts <= host->ts_samples[0].time)
> > + return timestamp_correction_calc(ts,
> > + &host->ts_samples[0],
> > + &host->ts_samples[1]);
> > + else if (ts >= host->ts_samples[host->ts_samples_count-1].time)
> > + return timestamp_correction_calc(ts,
> > + &host->ts_samples[host->ts_samples_count-2],
> > + &host->ts_samples[host->ts_samples_count-1]);
> > + min = 0;
> > + max = host->ts_samples_count-1;
> > + mid = (min + max)/2;
> > + while (min <= max) {
> > + if (ts < host->ts_samples[mid].time)
> > + max = mid - 1;
> > + else if (ts > host->ts_samples[mid].time)
> > + min = mid + 1;
> > + else
> > + break;
> > + mid = (min + max)/2;
> > + }
>
> Hmm, probably should libc's bsearch() instead of open coding a binary
> search.
>
I do not use bsearch() as there is no exact match it that search - only the
interval in which the timestamp fits should be found. May be there is a way
to use bsearch() in this scenario, I can think about it.
[ ...]
> > }
> >
> > +static int tsync_offset_cmp(const void *a, const void *b)
> > +{
> > + struct ts_offset_sample *ts_a = (struct ts_offset_sample *)a;
> > + struct ts_offset_sample *ts_b = (struct ts_offset_sample *)b;
> > +
> > + if (ts_a->time > ts_b->time)
> > + return 1;
> > + if (ts_a->time < ts_b->time)
> > + return -1;
> > + return 0;
> > +}
>
> We have the compare function for bsearch() here.
>
We can use it only for exact match, cannot use the same function for finding the
interval.
[ ... ]
> > static int trace_pid_map_cmp(const void *a, const void *b)
> > {
> > struct tracecmd_proc_addr_map *m_a = (struct tracecmd_proc_addr_map *)a;
> > @@ -2323,6 +2438,7 @@ static int handle_options(struct tracecmd_input *handle)
> > struct input_buffer_instance *buffer;
> > struct hook_list *hook;
> > char *buf;
> > + int sampes_size;
>
> "sampes"? Is this short for "samples"? Just use "samples_size" then.
>
It's a typo, fixed it :)
>
> > int cpus;
> >
> > /* By default, use usecs, unless told otherwise */
> > @@ -2370,6 +2486,28 @@ static int handle_options(struct tracecmd_input *handle)
> > offset = strtoll(buf, NULL, 0);
> > handle->ts_offset += offset;
> > break;
> > + case TRACECMD_OPTION_TIME_SHIFT:
> > + /*
> > + * long long int (8 bytes) trace session ID
> > + * int (4 bytes) count of timestamp offsets.
> > + * long long array of size [count] of times,
> > + * when the offsets were calculated.
> > + * long long array of size [count] of timestamp offsets.
> > + */
> > + if (size < 12 || handle->flags & TRACECMD_FL_IGNORE_DATE)
> > + break;
> > + handle->host.trace_id = tep_read_number(handle->pevent,
> > + buf, 8);
> > + handle->host.ts_samples_count = tep_read_number(handle->pevent,
> > + buf + 8, 4);
> > + sampes_size = (8 * handle->host.ts_samples_count);
> > + if (size != (12 + (2 * sampes_size)))
> > + break;
> > + handle->host.ts_samples = malloc(2 * sampes_size);
> > + if (!handle->host.ts_samples)
> > + return -ENOMEM;
> > + tsync_offset_load(handle, buf + 12);
> > + break;
> > case TRACECMD_OPTION_CPUSTAT:
> > buf[size-1] = '\n';
> > cpustats = realloc(cpustats, cpustats_size + size + 1);
> > @@ -3078,6 +3216,8 @@ void tracecmd_close(struct tracecmd_input *handle)
> > trace_pid_map_free(handle->pid_maps);
> > handle->pid_maps = NULL;
> >
> > + trace_tsync_offset_free(&handle->host);
> > +
> > if (handle->flags & TRACECMD_FL_BUFFER_INSTANCE)
> > tracecmd_close(handle->parent);
> > else {
> > @@ -3532,3 +3672,29 @@ unsigned long long tracecmd_get_traceid(struct tracecmd_input *handle)
> > {
> > return handle->trace_id;
> > }
> > +
> > +/**
> > + * tracecmd_get_tsync_peer - get the trace session id of the peer host
> > + * @handle: input handle for the trace.dat file
> > + *
> > + * Returns the trace id of the peer host, written in the trace file
> > + *
> > + * This information is stored in guest trace.dat file
> > + */
> > +unsigned long long tracecmd_get_tsync_peer(struct tracecmd_input *handle)
> > +{
> > + return handle->host.trace_id;
> > +}
> > +
> > +/**
> > + * tracecmd_enable_tsync - enable / disable the timestamps correction
> > + * @handle: input handle for the trace.dat file
> > + * @enable: enable / disable the timestamps correction
> > + *
> > + * Enables or disables timestamps correction on file load, using the array of
> > + * recorded time offsets
> > + */
> > +void tracecmd_enable_tsync(struct tracecmd_input *handle, bool enable)
> > +{
>
> Perhaps here we should check if samples are allocated already, and only
> allow it to be enabled if they are.
>
> -- Steve
>
>
> > + handle->host.sync_enable = enable;
> > +}
>
Thanks !
--
Tzvetomir (Ceco) Stoyanov
VMware Open Source Technology Center
next prev parent reply other threads:[~2019-12-05 15:09 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-12-03 10:35 [PATCH v17 00/18]Timestamp synchronization of host - guest tracing session Tzvetomir Stoyanov (VMware)
2019-12-03 10:35 ` [PATCH v17 01/18] trace-cmd: Implement new lib API: tracecmd_local_events_system() Tzvetomir Stoyanov (VMware)
2019-12-03 10:35 ` [PATCH v17 02/18] trace-cmd: Add support for negative time offsets in trace.dat file Tzvetomir Stoyanov (VMware)
2019-12-03 10:35 ` [PATCH v17 03/18] trace-cmd: Add implementations of htonll() and ntohll() Tzvetomir Stoyanov (VMware)
2019-12-20 13:50 ` Steven Rostedt
2020-01-06 14:30 ` Tzvetomir Stoyanov
2019-12-03 10:35 ` [PATCH v17 04/18] trace-cmd: Add new library APIs for ftrace instances Tzvetomir Stoyanov (VMware)
2019-12-04 16:17 ` Steven Rostedt
2019-12-05 14:40 ` Tzvetomir Stoyanov
2019-12-03 10:35 ` [PATCH v17 05/18] trace-cmd: Add new library API for local CPU count Tzvetomir Stoyanov (VMware)
2019-12-04 20:09 ` Steven Rostedt
2019-12-03 10:35 ` [PATCH v17 06/18] trace-cmd: Add new library API for reading ftrace buffers Tzvetomir Stoyanov (VMware)
2019-12-04 21:10 ` Steven Rostedt
2019-12-03 10:35 ` [PATCH v17 07/18] trace-cmd: Find and store pids of tasks, which run virtual CPUs of given VM Tzvetomir Stoyanov (VMware)
2019-12-04 21:35 ` Steven Rostedt
2019-12-03 10:35 ` [PATCH v17 08/18] trace-cmd: Implement new API tracecmd_add_option_v() Tzvetomir Stoyanov (VMware)
2019-12-04 21:47 ` Steven Rostedt
2019-12-03 10:35 ` [PATCH v17 09/18] trace-cmd: Add new API to generate a unique ID of the tracing session Tzvetomir Stoyanov (VMware)
2019-12-03 10:35 ` [PATCH v17 10/18] trace-cmd: Store the session tracing ID in the trace.dat file Tzvetomir Stoyanov (VMware)
2019-12-03 10:35 ` [PATCH v17 11/18] trace-cmd: Exchange tracing IDs between host and guest Tzvetomir Stoyanov (VMware)
2019-12-04 22:03 ` Steven Rostedt
2019-12-03 10:35 ` [PATCH v17 12/18] trace-cmd: Implement new option in trace.dat file: TRACECMD_OPTION_TIME_SHIFT Tzvetomir Stoyanov (VMware)
2019-12-05 0:46 ` Steven Rostedt
2019-12-05 15:09 ` Tzvetomir Stoyanov [this message]
2019-12-03 10:35 ` [PATCH v17 13/18] trace-cmd: Add guest information in host's trace.dat file Tzvetomir Stoyanov (VMware)
2019-12-05 0:59 ` Steven Rostedt
2019-12-03 10:35 ` [PATCH v17 14/18] trace-cmd: Add host trace clock as guest trace argument Tzvetomir Stoyanov (VMware)
2019-12-09 19:31 ` Steven Rostedt
2019-12-10 8:49 ` Tzvetomir Stoyanov
2019-12-10 15:48 ` Steven Rostedt
2019-12-11 8:21 ` Tzvetomir Stoyanov
2019-12-11 15:01 ` Steven Rostedt
2019-12-03 10:35 ` [PATCH v17 15/18] trace-cmd: Refactor few trace-cmd internal functions Tzvetomir Stoyanov (VMware)
2019-12-09 19:32 ` Steven Rostedt
2019-12-03 10:35 ` [PATCH v17 16/18] trace-cmd: Basic infrastructure for host - guest timestamp synchronization Tzvetomir Stoyanov (VMware)
2019-12-10 17:04 ` Steven Rostedt
2019-12-10 18:39 ` Steven Rostedt
2019-12-12 12:34 ` Tzvetomir Stoyanov
2019-12-12 14:54 ` Steven Rostedt
2019-12-12 14:00 ` Tzvetomir Stoyanov
2019-12-03 10:35 ` [PATCH v17 17/18] trace-cmd: [POC] PTP-like algorithm " Tzvetomir Stoyanov (VMware)
2019-12-03 10:35 ` [PATCH v17 18/18] trace-cmd: Debug scripts for " Tzvetomir Stoyanov (VMware)
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=CAPpZLN5Fb29dCnHWBDdLt9d9guikb6KqawhYCwqcZVp91rAWBw@mail.gmail.com \
--to=tz.stoyanov@gmail.com \
--cc=linux-trace-devel@vger.kernel.org \
--cc=rostedt@goodmis.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).