Lift this unnecessary limitation.
Details
Diff Detail
- Repository
- rG FreeBSD src repository
- Lint
Lint Not Applicable - Unit
Tests Not Applicable
Event Timeline
Presumably this can be removed because getgrouplist will set ngroups at most NGROUPS_MAX, returning -1 if it would be too large (and ngroups was > NGROUPS_MAX on input). IMO we should replace this check with an assertion in that case as documentation.
usr.sbin/mountd/mountd.c | ||
---|---|---|
3655–3656 | Taking this out breaks the code. Note that ngroups is If you are going to remove the code that takes out the ngroups = NGROUPS_MAX and gid_t groups[NGROUPS_MAX]; However, this should only be done if the other patch |
No, this can be removed because storage is allocated for NGROUPS_MAX + 1 elements. ngroups is used by getgrouplist() in input to know what the size of the array is. In output, it returns the number of elements it has filled, or would have liked to fill in case there's not enough room. In this latter case (only), it returns 1. So, if getgrouplist() returned 1, we have to reset ngroups to the maximum value, which is already done in the if above. If 0 was returned instead, we have nothing to do, since getgrouplist() updated ngroups to the number of valid elements in the array. In both cases, setting ngroups in the removed if is thus superfluous, and even wrong given that we have storage for NGROUPS_MAX + 1 elements.
usr.sbin/mountd/mountd.c | ||
---|---|---|
3655–3656 | I don't understand what you are saying. The number of slots should stay at NGROUPS_MAX + 1. Why change it? |
Oh - I was mistaken in my read of __getgroupmembership - maxgrp will be the passed in NGROUPS_MAX + 1
Remember this code is setting up exports. The "credentials" are created
from the exports in the kernel. It has nothing to do with setuid()/setgid()
etc. for processes.
usr.sbin/mountd/mountd.c | ||
---|---|---|
3655–3656 | The reason the size is set to NGROUPS_MAX + 1 is Since you are removing deduplication, asking for code ask for up to NGROUPS_MAX + 1 and then limit it to NGROUPS_MAX? |
usr.sbin/mountd/mountd.c | ||
---|---|---|
3655–3656 |
Ok, then that's the "problem", such limit is too conservative. I'll upload another revision to fix the corresponding part. |
usr.sbin/mountd/mountd.c | ||
---|---|---|
3655–3656 | Yea. The kernel code is in vfs_mount.c. I think that should be replaced by ngroups_max + 1 (It's confusing, since NGROUPS is now Then it exposes ngroups_max as a This code should probably get the tunable |
usr.sbin/mountd/mountd.c | ||
---|---|---|
3655–3656 | (Late send of this comment. Should have been sent when D47013 was added as child.) New revision that lifts this limitation: D47013. To clear any confustion, you might want to have a look at both at D46913 on the relationship between NGROUPS_MAX and our tunable. The standard way to get this tunable according to POSIX is sysconf(_SC_NGROUPS_MAX), and is what is used in the new D47016. It is unfortunate that POSIX defines {NGROUPS_MAX} as the maximum number of *supplementary groups*, and that we have the effective GID as the first position in the groups arrays internally, but we'll have to live with that I'd say (we might want to change the second part, but I'm not sure it's worth the trouble). |