| From: | Lukas Fittl <lukas(at)fittl(dot)com> |
|---|---|
| To: | John Naylor <johncnaylorls(at)gmail(dot)com> |
| Cc: | Andres Freund <andres(at)anarazel(dot)de>, Jakub Wartak <jakub(dot)wartak(at)enterprisedb(dot)com>, Hannu Krosing <hannuk(at)google(dot)com>, Robert Haas <robertmhaas(at)gmail(dot)com>, Pavel Stehule <pavel(dot)stehule(at)gmail(dot)com>, vignesh C <vignesh21(at)gmail(dot)com>, Michael Paquier <michael(at)paquier(dot)xyz>, Ibrar Ahmed <ibrar(dot)ahmad(at)gmail(dot)com>, Maciek Sakrejda <m(dot)sakrejda(at)gmail(dot)com>, pgsql-hackers <pgsql-hackers(at)postgresql(dot)org>, David Geier <geidav(dot)pg(at)gmail(dot)com> |
| Subject: | Re: Reduce timing overhead of EXPLAIN ANALYZE using rdtsc? |
| Date: | 2026-04-04 09:21:14 |
| Message-ID: | CAP53Pky=vngs0orKn2=UDmMUhf7Zahn2nRcg7T5OiLidDTNmxw@mail.gmail.com |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-hackers |
On Fri, Apr 3, 2026 at 2:06 AM John Naylor <johncnaylorls(at)gmail(dot)com> wrote:
>
> On Fri, Apr 3, 2026 at 6:16 AM Lukas Fittl <lukas(at)fittl(dot)com> wrote:
> > v16
>
> Just some minor quibbles on 0002:
Thanks for the review!
>
> --- a/src/include/port/pg_cpu.h
> +++ b/src/include/port/pg_cpu.h
> @@ -23,6 +23,12 @@ typedef enum X86FeatureId
> /* scalar registers and 128-bit XMM registers */
> PG_SSE4_2,
> PG_POPCNT,
> + PG_HYPERVISOR,
>
> The hypervisor flag doesn't really belong with an instruction family.
> Maybe a separate category like "identification"?
Yeah, I've pondered different names here, but "identification" seems
good for now - I agree it doesn't belong with the earlier flags.
>
> + /* TSC flags */
> + PG_RDTSCP,
> + PG_TSC_INVARIANT,
> + PG_TSC_ADJUST,
>
> Maybe spell out time stamp counter in the comment, since this will be
> the first time the reader encounters that in this file.
Makes sense, done.
FWIW, TSC can be spelled out either as "Time Stamp Counter" or
"Time-Stamp Counter". I've gone with the latter for now since that's
what was done elsewhere, and is how the Intel manuals reference it as
well.
>
> + * For some other Hypervisors that have an invariant TSC, e.g. HyperV, we would
> + * need to access an MSR to get the frequency (which is typically not available
>
> Maybe spell out MSR too, because I for one don't know what that is.
Done. I've also removed the note re: TSC calibration in that same
comment, since that's in a later commit and I don't think its
necessary to talk about it in that comment anyway.
>
> + X86Features[PG_HYPERVISOR] = reg[ECX] >> 31 & 1;
> + have_osxsave = reg[ECX] & (1 << 27);
> +
> + pg_cpuid_subleaf(0x07, 0, reg);
> +
> + X86Features[PG_TSC_ADJUST] = (reg[EBX] & (1 << 1)) != 0;
>
> Some inconsistency in shift style.
Fixed.
See attached v17.
Thanks,
Lukas
--
Lukas Fittl
| Attachment | Content-Type | Size |
|---|---|---|
| v17-0005-instrumentation-ARM-support-for-fast-time-measur.patch | application/octet-stream | 8.4 KB |
| v17-0002-Allow-retrieving-x86-TSC-frequency-flags-from-CP.patch | application/octet-stream | 6.5 KB |
| v17-0001-instrumentation-Streamline-ticks-to-nanosecond-c.patch | application/octet-stream | 16.4 KB |
| v17-0004-pg_test_timing-Also-test-RDTSC-RDTSCP-timing-and.patch | application/octet-stream | 7.3 KB |
| v17-0003-instrumentation-Use-Time-Stamp-Counter-TSC-on-x8.patch | application/octet-stream | 30.8 KB |
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Andrei Lepikhov | 2026-04-04 09:34:35 | Re: pg_plan_advice |
| Previous Message | Antonin Houska | 2026-04-04 08:50:14 | Re: Adding REPACK [concurrently] |