aboutsummaryrefslogtreecommitdiff
path: root/scripts/README.md
blob: a5f765cceb3aa857f5ae102bdb5059ba0b3cea0f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
# Scripts

This directory contains scripts for maintaining bpftool's GitHub mirror.

## gh-label-release-assets.sh

This script can **add labels to GitHub release assets**. Labels are used in the
GitHub interface instead of the file name in the list of assets, but they do
not alter the download URL.

The script takes the tag reference for the release as single parameter. The
repository to use, and the names and labels to set for assets are currently
defined in the script itself.

It requires the [GitHub command line][gh] (`gh`).

Note that only users with push access to the repository can update release
assets and set labels.

[gh]: https://cli.github.com/

## sync-kernel.sh

### Synchronize Linux and bpftool mirror

This script synchronizes the bpftool mirror with the bpftool sources (and
related files) from the Linux kernel repository.

Synchronization is usually performed against the `bpf-next` and `bpf` trees,
because this is where most bpftool updates are merged.

By default, the script does not pick the very latest commits in these trees,
but instead it uses the commits referenced in the libbpf submodule. This is
because bpftool strongly relies on libbpf, and the libbpf GitHub mirror is used
here as a submodule dependency. This libbpf mirror is also periodically updated
to the latest `bpf-next` and `bpf` tree, and records to what kernel commits it
was brought up-to-date. To ensure optimal compatibility between the bpftool
sources and the libbpf dependency, we want to update them to the same point of
reference.

### Prerequisites

There is no particular tool required for running the script, except `git` of
course.

However, you need a local copy of the Linux Git repository on your system
in order to successfully run the script. You can set it up as follows:

```console
$ git clone 'https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf-next.git' linux
$ cd linux
$ git remote rename origin bpf-next
$ git branch --move master bpf-next
$ git remote add bpf 'https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf.git'
$ git fetch bpf
$ git checkout bpf/master
$ git switch --create bpf
$ git branch --set-upstream-to bpf/master
$ git switch bpf-next
```

At the end of the process, the repository should contain two branches
`bpf-next` and `bpf`, pointing to the `master` branches of the `bpf-next` and
`bpf` remote repositories, respectively. These two branches are required to
synchronize the mirror correctly.

You can later update this repository with the following commands:

```console
$ git switch bpf
$ git pull --set-upstream bpf master
$ git switch bpf-next
$ git pull --set-upstream bpf-next master
```

Also make sure you have cloned the bpftool mirror recursively, to check out the
libbpf submodule. If you have not, run the following:

```console
$ git submodule update --init
```

### Usage

As preliminary steps:

- Make sure that you have a Linux Git repository installed (see above), with
  two branches `bpf-next` and `bpf` up-to-date.
- Make sure your mirror repository is clean.

Then run the script:

```console
$ ./sync-kernel.sh <bpftool-repo> <kernel-repo>
```

If working from within the bpftool repository, the path to the `<bpftool-repo>`
is typically the current working directory (`.`). The second argument,
`<kernel-repo>`, is the path to the Linux Git repository mentioned earlier.

Several environment variables can modify some internal parameters of the
script:

- Set `BPF_NEXT_BASELINE `to override the `bpf-next` tree commit to use (the
  commit from the `bpf-next` branch with which the bpftool repository is
  currently synchronized, prior to running the script). If unset, use the hash
  from `<bpftool-repo>/CHECKPOINT-COMMIT` is used.
- Set `BPF_BASELINE `to override the `bpf` tree commit to use (the commit from
  the `bpf` branch with which the bpftool repository is currently synchronized,
  prior to running the script). If unset, use the hash from
  `<bpftool-repo>/BPF-CHECKPOINT-COMMIT` is used.
- Set `BPF_NEXT_TIP_COMMIT` to override the `bpf-next` tree target commit (the
  commit in `bpf-next` up to which the bpftool mirror should be synchronized).
  If unset, use the hash from `<bpftool-repo>/libbpf/CHECKPOINT-COMMIT`, after
  the libbpf repository update that takes place at the beginning of the update
  process.
- Set `BPF_TIP_COMMIT` to override the `bpf` tree target commit (the commit in
  `bpf` up to which the bpftool mirror should be synchronized). If unset, use
  the hash from `<bpftool-repo>/libbpf/BPF-CHECKPOINT-COMMIT`, after the libbpf
  repository update that takes place at the beginning of the update process.
- Set `SKIP_LIBBPF_UPDATE` to `1` to avoid updating libbpf automatically.
- Set `MANUAL_MODE` to `1` to manually control every cherry-picked commit.

### How it works

This script synchronizes the bpftool mirror with upstream bpftool sources from
the Linux kernel repository.

It performs the following steps:

- First, the script updates the libbpf submodule, commits the change, and (by
  default) picks up libbpf's latest checkpoints to use them as target commits
  for the bpftool mirror.

- In the Linux repository, from the `bpf-next` branch, it creates new branches,
  filters out all non-bpftool-related files, and reworks the layout to
  replicate the layout from the bpftool mirror.

- It generates patches for each commit touching `bpftool` or the required UAPI
  files, up to the target commit, and exports these patches to a temporary
  repository.

- In a new branch in the bpftool mirror, the script applies (`git am`) each of
  these patches to the mirror.

- Then the script checks out the `bpf` branch in the Linux repository, and
  repeats the same operations.

- On top of the new patches applied to the mirror, the script creates a last
  commit with the updated checkpoints, using a cover letter summarizing the
  changes as the commit description.

- The next step is verification. The script applies to the Linux repository
  (`bpf-next` branch) a patch containing known differences between the Linux
  repository and the bpftool mirror. Then it looks for remaining differences
  between the two repositories, and warn the user if it finds any. Patches
  picked up from the `bpf` tree are usually a source of differences at this
  step. If the patch containing the known differences is to be updated after
  the synchronization in progress, the user should do it at this time, before
  the temporary files from the script are deleted.

- At last, the script cleans up the temporary files and branches in the Linux
  repository. Note that these temporary files and branches are not cleaned up
  if the script fails during execution.