[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <bdeb80ea-99dd-d9ea-d508-9cb8d2c6fbf4@linux.intel.com>
Date: Sun, 27 Jun 2021 09:30:53 -0700
From: Andi Kleen <ak@...ux.intel.com>
To: Greg KH <greg@...ah.com>
Cc: kan.liang@...ux.intel.com, peterz@...radead.org, mingo@...hat.com,
linux-kernel@...r.kernel.org, eranian@...gle.com,
namhyung@...nel.org, acme@...nel.org, jolsa@...hat.com
Subject: Re: [PATCH 2/7] perf: Create a symlink for a PMU
> Then do not break things by renaming the device name, as you all have
> now stated that this name is part of the user/kernel api.
The renaming comes from the fallback mode on future systems. In the
fallback mode the driver doesn't know the true name, so it has to useĀ
the numeric name. If you don't use the fallback mode and have the full
driver then yes you'll get the same names as always (or at least as they
make sense for the hardware).
But we would like to have the fallback mode too to allow more people use
uncore monitoring, and that's where the need to for the second name
comes in.
>
> But really, I do not see why this is an issue, why isn't userspace just
> properly walking the list of devices and picking the one on this
> specific system that they want to look at?
perf is not an fully automated tool that knows what it wants to look at.
It's not like udev etc.
It's a tool to let the user specify what they want to measure on the
command line. And that specification is through the pmu name.
Of course it walks the list to find the name, but it can only chose
based on the name the user specified.
It's like the ftrace tool doesn't know what trace points to measure on
its own, it just knows what is specified on the command line. Or the ip
tool doesn't know on its own what network device names to use for some
network configuration, it has to get the information from the command line.
>
>>>> Anyways thinking about it if Greg doesn't want symlinks (even though sysfs
>>>> already has symlinks elsewhere), maybe we could just create two devices
>>>> without symlinks. Kan, do you think that would work?
>>> Do not have 2 different structures represent the same hardware device,
>>> that too is a shortcut to madness.
>>>
>>> What prevents userspace from handling device names changing today? Why
>>> are you forcing userspace to pick a specific device name at all?
>> The way the perf tool works is that you have to specify the names on the
>> command line:
>>
>> perf stat -a -e uncore_cha/event=1/ ...
>>
>> With the numeric identifiers it would be
>>
>> perf stat -a -e uncore_type_X_Y/event=1/
>>
>> The tool handles it all abstractly.
> Great, and that device name is something that is unique per machine.
> And per boot.
No it's not unique and per boot. It's always the same on a given
platform, it's specified by firmware. I would expect the names to be
stable over all systems of a given chip.
> So why are you suddenly thinking that this name has to be
> "stable"?
It's about as stable as the existing names. The existing names change
sometimes too when the hardware changes (for example before Skylake we
had "uncore_cbo", since Skylake there is "uncore_cha"). The numeric
identifier should have similar stability (doesn't change as long as the
hardware doesn't change significantly)
>
> If you think it does have to be stable, that was your choice, so now you
> must keep it stable. Don't try to mess with symlinks and the like
> please, as again, that way lies madness and unmaintainability for the
> next 20+ years.
We keep it as stable as possible, but in the fallback mode only the
numeric IDs are possible. In the "driver knows full hardware" mode it
keeps the existing names, as possible.
>
>> So yes the user tools itself can handle it. But the problem is that it is
>> directly exposed to the users, so the users would need to change all their
>> scripts when switching between the two cases. That is what we're trying to
>> avoid -- provide them a way that works on both.
> But these are different systems! Why would anyone expect that the
> device name is the same on different systems?
The scenario is that you run the same system but with two different kernels.
Kernel 1 doesn't know the model number and can only operate in fallback
mode:
It only shows numeric IDs and that's what you have to use
Kernel 2 knows the model number and has a full driver which supports the
full Linux standard naming.
You can use the standard names (like uncore_cha)
But the problem is that it would be impossible to write a script that
works on both Kernel 1 and Kernel 2 on the same system without the
symlink or equivalent.
> If you insist on keeping
> the name identical for newer kernel versions, then again, that was your
> choice and now you have to do that. Do not try to work around your own
> requirement by using a symlink.
Are you suggesting to only use numerical names everywhere?
That would be a big change for existing users. The idea was that people
who use the fully enabled driver can use the much nicer symbolic names.
But people who care about writing scripts that work everywhere can use
the more difficult to use numeric names.
Anyways it looks like we're setting on using the "name" method suggested
by Kan. I must say I'm not a big fan of it though, it's just another
incompatible break in the perf ABI that would be totally avoidable.
-Andi
Powered by blists - more mailing lists