Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Packages for the Linux perf profiler #600

Open
wants to merge 21 commits into
base: testing
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
deb8325
perf: Package for the Linux perf profiler
matteodelabre Jun 25, 2022
2ca282f
Merge branch 'testing' into package/perf/initial
matteodelabre Jun 26, 2022
5f73e76
Merge branch 'testing' into package/perf/initial
Eeems Sep 26, 2022
4a45df8
Merge branch 'testing' into package/perf/initial
Eeems Oct 1, 2022
af9bced
Merge branch 'testing' into package/perf/initial
Eeems Oct 29, 2022
e909c5b
Merge branch 'testing' into package/perf/initial
Eeems Nov 7, 2022
94c486b
Merge branch 'testing' into package/perf/initial
Eeems Nov 21, 2022
06b53a9
Add linux-mainline-perf and linux-stracciatella-perf as split packages
matteodelabre Nov 21, 2022
fd46dac
Install python->python3 symlink for build
matteodelabre Nov 21, 2022
c1d12e7
Disable werror for old kernel perf build
matteodelabre Nov 21, 2022
4f85b60
Add provides/conflicts for perf packages
matteodelabre Nov 28, 2022
84b5f00
Merge branch 'testing' into package/perf/initial
Eeems Aug 8, 2023
d436b08
Merge branch 'testing' into package/perf/initial
Eeems Aug 30, 2023
f5364cc
Merge branch 'testing' into package/perf/initial
Eeems Sep 8, 2023
9fa1fd5
Merge branch 'testing' into package/perf/initial
Eeems Sep 27, 2023
2aed7f5
Merge branch 'testing' into package/perf/initial
Eeems Nov 27, 2023
e0f0af8
Merge branch 'testing' into package/perf/initial
Eeems Dec 6, 2023
2c607e0
Update package
Eeems Dec 6, 2023
fb3532b
Merge branch 'testing' into package/perf/initial
Eeems Feb 3, 2024
ad523c0
Merge branch 'testing' into package/perf/initial
Eeems Apr 21, 2024
db61784
Merge branch 'testing' into package/perf/initial
Eeems May 8, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Add provides/conflicts for perf packages
  • Loading branch information
matteodelabre committed Nov 28, 2022

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature.
commit 4f85b60383e1a15ecdbbb8f691761db041c7f77f
15 changes: 15 additions & 0 deletions docs/package.md
Original file line number Diff line number Diff line change
@@ -404,6 +404,21 @@ A list of packages that the current package replaces.
Setting this field allows the current package to overwrite and take ownership of files from other packages.
Note that the replaced packages will not be automatically uninstalled unless you also declare a conflict with them using the [`conflicts` field](#conflicts-field).

#### `provides` field

<table>
<tr>
<th>Required?</th>
<td>No, defaults to <code>()</code></th>
</tr>
<tr>
<th>Type</th>
<td>Array of strings</td>
</tr>
</table>

A list of virtual packages that the current package provides.

#### `package()` function

The `package()` function populates the `$pkgdir` directory with the files and directories that need to be installed using artifacts from the `$srcdir` directory.
2 changes: 2 additions & 0 deletions package/linux-mainline/package
Original file line number Diff line number Diff line change
@@ -63,6 +63,8 @@ linux-mainline-perf() {
pkgdesc="Linux profiling with performance counters"
url=https://perf.wiki.kernel.org
section=devel
provides=(perf)
conflicts=(perf)

package() {
install -D -m 755 -t "$pkgdir"/opt/bin "$srcdir"/tools/perf/perf
2 changes: 2 additions & 0 deletions package/linux-stracciatella/package
Original file line number Diff line number Diff line change
@@ -67,6 +67,8 @@ linux-stracciatella-perf() {
pkgdesc="Linux profiling with performance counters"
url=https://perf.wiki.kernel.org
section=devel
provides=(perf)
conflicts=(perf)

package() {
install -D -m 755 -t "$pkgdir"/opt/bin "$srcdir"/tools/perf/perf
4 changes: 3 additions & 1 deletion scripts/toltec/recipe.py
Original file line number Diff line number Diff line change
@@ -343,6 +343,7 @@ class Package: # pylint:disable=too-many-instance-attributes
installdepends: Set[Dependency]
conflicts: Set[Dependency]
replaces: Set[Dependency]
provides: Set[Dependency]

functions: bash.Functions
custom_functions: bash.Functions
@@ -390,7 +391,7 @@ def _load_fields(self, variables: bash.Variables) -> None:
self.license = _pop_field_string(variables, "license")
self.variables["license"] = self.license

for field in ("installdepends", "conflicts", "replaces"):
for field in ("installdepends", "conflicts", "replaces", "provides"):
field_raw = _pop_field_indexed(variables, field, [])
self.variables[field] = field_raw
setattr(self, field, set())
@@ -482,6 +483,7 @@ def control_fields(self) -> str:
("Depends", self.installdepends),
("Conflicts", self.conflicts),
("Replaces", self.replaces),
("Provides", self.provides),
):
if field:
control += (