bpftool: Set program type only if it differs from the desired one
authorWei Yongjun <weiyongjun1@huawei.com>
Fri, 7 Apr 2023 08:14:26 +0000 (08:14 +0000)
committerAndrii Nakryiko <andrii@kernel.org>
Fri, 7 Apr 2023 22:28:12 +0000 (15:28 -0700)
commitb24f0b049e706c6fc6e822dfc519ee33c3865092
treeb9608607cc6c995e338fbf47dacb7b8ef1f3d1cb
parent3ebf5212bf042954666b19fe4ff5a98911b08128
bpftool: Set program type only if it differs from the desired one

After commit d6e6286a12e7 ("libbpf: disassociate section handler on explicit
bpf_program__set_type() call"), bpf_program__set_type() will force cleanup
the program's SEC() definition, this commit fixed the test helper but missed
the bpftool, which leads to bpftool prog autoattach broken as follows:

  $ bpftool prog load spi-xfer-r1v1.o /sys/fs/bpf/test autoattach
  Program spi_xfer_r1v1 does not support autoattach, falling back to pinning

This patch fix bpftool to set program type only if it differs.

Fixes: d6e6286a12e7 ("libbpf: disassociate section handler on explicit bpf_program__set_type() call")
Signed-off-by: Wei Yongjun <weiyongjun1@huawei.com>
Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
Link: https://lore.kernel.org/bpf/20230407081427.2621590-1-weiyongjun@huaweicloud.com
tools/bpf/bpftool/prog.c