On Fri, 19 Feb 2021 09:16:26 +0200 Tzvetomir Stoyanov <tz.stoyanov@xxxxxxxxx> wrote: > Hi Steven, > > On Fri, Feb 19, 2021 at 4:03 AM Steven Rostedt <rostedt@xxxxxxxxxxx> wrote: > > > > On Thu, 3 Dec 2020 08:02:26 +0200 > > "Tzvetomir Stoyanov (VMware)" <tz.stoyanov@xxxxxxxxx> wrote: > > > > > +static int perf_mmap(struct perf_cpu *perf) > > > +{ > > > + mmap_mask = NUM_PAGES * getpagesize() - 1; > > > + > > > + /* associate a buffer with the file */ > > > + perf->mpage = mmap(NULL, (NUM_PAGES + 1) * getpagesize(), > > > + PROT_READ | PROT_WRITE, MAP_SHARED, perf->perf_fd, 0); > > > + if (perf->mpage == MAP_FAILED) > > > + return -1; > > > + return 0; > > > +} > > > > BTW, I found that the above holds the conversions we need for the local > > clock! > > > > printf("time_shift=%d\n", perf->mpage->time_shift); > > printf("time_mult=%d\n", perf->mpage->time_mult); > > printf("time_offset=%lld\n", perf->mpage->time_offset); > > > > Which gives me: > > > > time_shift=31 > > time_mult=633046315 > > time_offset=-115773323084683 > > > > [ one for each CPU ] > > This will give us time shift/mult/offset for each host CPU, right ? Is > the local trace clock > different for each CPU ? It can be. Note, the above offset is basically useless. That injects the current time into the value and we can't rely on it. But the shift and mult is needed. But, usually, the shift and offset are identical on most systems across CPUs, but there's no guarantee that it will always be the case. >Currently, the time offset is calculated per > VCPU, assuming > that the host CPU on which this VCPU runs has no impact on the > timestamp synchronization. > If the local clock depends on the CPU, then we should calculate the > time offset of each guest > event individually, depending on host CPU and VCPU the event happened > - as the host task which runs > the VCPU can migrate between CPUs at any time. So, we need to: > 1. Add timesync information for each host CPU in the trace.dat file. > 2. Track the migration between CPUs of each task that runs VCPU and > save that information > in the trace.dat file. I was thinking about this too. And perhaps we can hold off until we find systems that have different values for mult and shift. That said, we can easily add this information by recording the sched_switch events in a separate buffer. And I've been thinking about doing this by default anyway. More below. > 2. When calculating the new timestamp of each guest event > (individually) - somehow find out on > which host CPU that guest event happened ? > > Points 1 and 2 are doable, but will break the current trace.dat file > option that holds the timesync information. I don't think we need to have it in the timesync option. I think we can create another option to hold guest event data. > Point 3 is not clear to me, how we can get such information before the > host and guest events are synchronised ? > My thoughts about this is. When we enable tracing of a guest (-A), we then create an instance on the host that records only kvm enter / exit events as well as sched switch events. Basically, enable all the events that we need to synchronize and show entering and exiting of the guest. The synchronization logic already shows us what host thread controls each guest VCPU. If we record the kvm enter/exit and sched_switch events in a separate buffer, we can see when a host thread that runs a guest VCPU migrates to another CPU. Since the timestamps of those events are recorded in the meta events themselves (sched_switch), we know exactly where we need to use the new mult and shift values for the guest events. Make sense? -- Steve