Page MenuHomeFreeBSD

Refresh CPU types and classes from sys/sys/pmc.h.
ClosedPublic

Authored by pauamma_gundo.com on May 28 2022, 6:58 PM.
Tags
None
Referenced Files
F101999419: D35344.diff
Wed, Nov 6, 9:28 AM
Unknown Object (File)
Oct 6 2024, 5:58 AM
Unknown Object (File)
Sep 27 2024, 11:17 PM
Unknown Object (File)
Sep 27 2024, 10:10 AM
Unknown Object (File)
Sep 24 2024, 5:45 PM
Unknown Object (File)
Sep 19 2024, 2:42 PM
Unknown Object (File)
Sep 18 2024, 10:08 AM
Unknown Object (File)
Sep 9 2024, 1:09 AM
Subscribers

Details

Summary

While here, fix a few nits.

Assuming that the Arm7 trademark covers ARMv7 as well.

Inspired by reviewing D35342.

Sources for trademark info

Test Plan

man # and eyeball.
mandoc -T lint
igor

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 45827
Build 42715: arc lint + arc unit

Event Timeline

mhorne added a subscriber: mhorne.

Thank you for this!

lib/libpmc/pmc.3
176

I believe this also covers POWER9 CPUs.

This revision is now accepted and ready to land.May 30 2022, 2:49 PM
lib/libpmc/pmc.3
176

I believe this also covers POWER9 CPUs.

Maybe add that to sys/sys/pmc.h in that case? I went by the current content:

	__PMC_CPU(PPC_POWER8,   0x390,  "IBM POWER8")		\
luporl added inline comments.
lib/libpmc/pmc.3
176

It does cover POWER9 CPUs too.

The reason there is only PPC_POWER8 class in sys/sys/pmc.h is that POWER9 counters are programmed exactly like the POWER8 ones.
There are different counters between POWER8 and POWER9, but this only changes the value that must be set to access them. This is handled somewhere in the PMU code, where it queries the model of current CPU.

Waiting for an answer to my inline question about pmc_close_logfile to update the diff, and I'd still like manpages approval after that.

lib/libpmc/pmc.3
176

Thanks. Will add as a trademark, then.

475

While I'm touching this file: shouldn't this be pmc_close_logfile instead?

lib/libpmc/pmc.3
475

It seems that pmc_configure_logfile(-1) is used to flush and close any open logfile for the process. The exact difference in intent/functionality between this and pmc_close_logfile() is not obvious on a quick glance.

So, I think it is okay to leave this as-is for now.

This revision now requires review to proceed.Jun 3 2022, 12:17 AM

No enough experience on this topic. I prefer to wait for the approval from src

The PowerPC parts look good.

This revision is now accepted and ready to land.Nov 1 2022, 1:48 PM
mhorne added inline comments.
lib/libpmc/pmc.3
162

Making a note for future work: we ought to find a better solution for this list of AMD and Intel processors. What is here is so outdated as to not be useful (or worse, misleading); instead we need to find the words to communicate that "most AMD and Intel processors are supported", but avoid trying (and failing) to maintain a list of specific CPU models.

lib/libpmc/pmc.3
162

avoid trying (and failing) to maintain a list of specific CPU models.

Is there an implicit definition that could work instead? *rummages into dmesg.boot* Like whatever test outputs "TSC: P-state invariant, performance statistics" at boot? (13.1 amd64)

No enough experience on this topic. I prefer to wait for the approval from src

Which I now have (checked in IRC, and mhorne says their approval is for src overall, including the ARM bits). Can I have mentor approval?