Page MenuHomeFreeBSD

add libpmcstat
ClosedPublic

Authored by br on Oct 18 2017, 1:24 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Jan 5, 7:43 AM
Unknown Object (File)
Sun, Jan 5, 7:33 AM
Unknown Object (File)
Sun, Jan 5, 7:16 AM
Unknown Object (File)
Fri, Dec 27, 4:21 AM
Unknown Object (File)
Dec 16 2024, 4:59 AM
Unknown Object (File)
Dec 6 2024, 12:47 PM
Unknown Object (File)
Dec 2 2024, 2:29 PM
Unknown Object (File)
Dec 1 2024, 12:24 AM
Subscribers

Details

Summary

Move a set of functions from pmcstat to libpmcstat allowing us to reuse them in other HWPMC-based applications.
This include symbols lookup, pmc logging, pmc attachment, process creation, ELF parsing, etc.

Test Plan

World build on amd64 host

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

libpmcstat.c must be split into per-function .c file. Also, I strongly suggest to mark the library as internal, since we cannot maintain PMC ABI even for a few weeks.

  • split libpmcstat
  • add new function pmcstat_symbol_search_by_name() allowing to find mapped IP for given function name
lib/libpmcstat/Makefile
8

Please put this one file per line, See e.g. the lib/libc/amd64/sys/Makefile.inc as an example. This style makes file additions much easier to read, and merges into branches are less likely to cause conflicts.

lib/libpmcstat/libpmcstat.h
39

Why do you need this ?

42

You need BEGIN_DECLS/END_DECLS braces around function declarations in the headers, to make this usable from C++. This is a usual reason to group all function declarations into single group.

220

I strongly suggest to not add the min/max symbols into the header.

usr.sbin/pmcstat/pmcstat.h
35โ€“36

Do you still need _cpuset.h before libpmcstat.h ?

It seems that you need it for real, then why did not you include the header from libpmcstat.h ? You tried to make libpmcstat.h self-contained ?

  • wrap lines
  • use BEGIN/END_DECLS and group function declarations
  • move min/max
  • include _cpuset.h in libpmcstat.h
lib/libpmcstat/Makefile
8

Agree. Thanks!

lib/libpmcstat/libpmcstat.h
39

type WINDOW used in libpmcstat.h, so curses.h included to make it self-contained

42

thanks for explanation, I added BEGIN/END_DECLS and grouped function declarations

220

OK I moved this to .c files

usr.sbin/pmcstat/pmcstat.h
35โ€“36

type cpuset_t used by libpmstat.h, so I moved this to libpmcstat.h to make it self-contained.
thanks!

lib/libpmcstat/libpmcstat.h
298

Can you pass this parameter as void *, and cast in plugin(s) ?

I want to remove curses.h from the header.

remove dependency on curses.h for libpmcstat.h

lib/libpmcstat/libpmcstat.h
298

Sure!
stdio.h header added however for FILE.

This stuff would greatly benefit from more cleanup, but I think your have other priorities.

This revision is now accepted and ready to land.Oct 24 2017, 1:21 PM

This stuff would greatly benefit from more cleanup

You mean in the existing pmc implementation, not the libification, correct?

This stuff would greatly benefit from more cleanup

You mean in the existing pmc implementation, not the libification, correct?

It is moved around, so I am not sure what is your point.

Real place to start fixing is the user/kernel interface, to be able to have stable ABI for pmc events.

It is moved around, so I am not sure what is your point.

Just trying to confirm my understanding of your comment - pmc needs cleanup both before and after this change. This change doesn't make it better or worse.

It is moved around, so I am not sure what is your point.

Just trying to confirm my understanding of your comment - pmc needs cleanup both before and after this change. This change doesn't make it better or worse.

The extraction of internal interfaces into a library certainly increases the amount of work for supposed cleanup. More, since I do not think that the extraction is done just for its own sake, but there will be a new code which uses the exposed interfaces, the overall amount of work is certainly larger.

The library definitely does not provide any consistent set of useful and designed interfaces, it is the internals exposed. This is one of the reason why I asked for it to be internal library, we certainly do not want to claim that even an API of the library is maintained, not to mention ABI (and I did not asked about providing symbol versioning for the library either). But I do not think that it is constructive to block other code because this mess is reused.

This revision was automatically updated to reflect the committed changes.