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

libbpf-tools/profile: Add support for PID-namespacing #5152

Merged
merged 3 commits into from
Dec 18, 2024

Conversation

ekyooo
Copy link
Contributor

@ekyooo ekyooo commented Nov 21, 2024

Support PID namespace translation as memleak.py does.

Copy link
Contributor

@eiffel-fl eiffel-fl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have few comments, but it is looking really good!

@@ -595,6 +610,8 @@ int main(int argc, char **argv)
env.perf_max_stack_depth * sizeof(unsigned long));
bpf_map__set_max_entries(obj->maps.stackmap, env.stack_storage_size);

set_pidns(obj);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You can catch the returned value and show a warning message in case PID namespace does not exist?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed. thank you.

Comment on lines 532 to 515
if (kernel_at_least(5, 7))
return -EPERM;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The problem with fixed version check is that they will not work on kernel where a specific patch could have been backported.
Is there a way to rather check for the existence of a given bpf helper?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In bcc/tools, we have a few cases (including profile) checking kernel version for bpf_get_ns_current_pid_tgid() availability. But for libbpf-tools, I think we can do better.
See trace_helpers.c. There are a few probe_*() functions which tries to detect whether a particular feature (prog_type, map_type) is supported or not. I think we can have another probe function to check whether bpf_get_ns_current_pid_tgid() is supported or not.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for good feedback.
I have applied the opinion.

@eiffel-fl
Could you please check if it's what you want?

Thank you.

@@ -595,6 +631,10 @@ int main(int argc, char **argv)
env.perf_max_stack_depth * sizeof(unsigned long));
bpf_map__set_max_entries(obj->maps.stackmap, env.stack_storage_size);

err = set_pidns(obj);
if (err)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let us do 'err && env.verbose' here. We want to print out the below information under verbose mode.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it's modified. thank you.

Comment on lines 532 to 515
if (kernel_at_least(5, 7))
return -EPERM;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In bcc/tools, we have a few cases (including profile) checking kernel version for bpf_get_ns_current_pid_tgid() availability. But for libbpf-tools, I think we can do better.
See trace_helpers.c. There are a few probe_*() functions which tries to detect whether a particular feature (prog_type, map_type) is supported or not. I think we can have another probe function to check whether bpf_get_ns_current_pid_tgid() is supported or not.

@ekyooo ekyooo force-pushed the profile_pidns branch 2 times, most recently from f9be357 to 405c48f Compare December 3, 2024 11:22
Copy link
Contributor

@eiffel-fl eiffel-fl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi,

Some other comments, it is looking great though!
I will test it later.

Best regards.

{ .code = BPF_JMP | BPF_EXIT },
};

insn_cnt = sizeof(insns) / sizeof(struct bpf_insn);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
insn_cnt = sizeof(insns) / sizeof(struct bpf_insn);
insn_cnt = sizeof(insns) / sizeof(insns[0]);

This way, you do not have problem if one day we need to change the type.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it's modified. Thank you.

struct bpf_pidns_info ns = {};

if (use_pidns && !bpf_get_ns_current_pid_tgid(pidns_dev, pidns_ino, &ns,
sizeof(struct bpf_pidns_info))) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Use ns for sizeof instead of the type name?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's modified. Thank you.

@@ -1248,6 +1248,28 @@ bool probe_ringbuf()
return true;
}

bool probe_bpf_ns_current_pid_tgid(void)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would first add a commit introducing this helper, then using it in another commit in profile.c.
What do you think?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's done. thank you.

Add PID translation for nested PID namespace environments, such as container.
…d_tgid

Add a utility function to check if bpf_get_ns_current_pid_tgid is available in
the target kernel.
…he kernel

Support PID namespace mapping only in kernels where bpf_get_ns_current_pid_tgid
is available.
Copy link
Contributor

@eiffel-fl eiffel-fl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM! Thank you!

u64 *valp;
static const u64 zero;
struct key_t key = {};
u64 id;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: id scope can be reduced to else block.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, I prefer that style, but as far as I know, bcc/libbpf-tools follows the 'declaration first' rule.
Thank you for good opinion.

@ekyooo
Copy link
Contributor Author

ekyooo commented Dec 13, 2024

LGTM! Thank you!

Thank you.
I wonder if the test went well in your environment as well.

@eiffel-fl
Copy link
Contributor

LGTM! Thank you!

Thank you. I wonder if the test went well in your environment as well.

I am not really familiar with the CI, but I was able to compile and run the tool locally without problems.

@yonghong-song yonghong-song merged commit 04dbccd into iovisor:master Dec 18, 2024
8 of 12 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants