MFC of r196201
URL: http://svn.freebsd.org/changeset/base/196201 Fix ipfw crash on uid or gid check. Receiving any ip packet for which there is no existing socket will crash if ipfw has a uid or gid test rule, as the uid/gid of the non existent owner of said non existent socket is tested. Brooks introduced this error as part of his >16 gids patch. It appears to be a cut-n-paste error from similar code a few lines before. The old code used the 'pcb' variable here, but in the new code that switched the 'inp' variable, which is often NULL and what is tested in the code further up. The rest of the multi-gid patch for ipfw seems solid (and cleaner than previous code). p.s. What's up with all the properties changing? It is a fresh checkout. Reviewed by: brooks Approved by: re (rwatson)
This commit is contained in:
parent
3330f5394f
commit
9e26af42e2
@ -2057,7 +2057,7 @@ check_uidgid(ipfw_insn_u32 *insn, int proto, struct ifnet *oif,
|
||||
dst_ip, htons(dst_port),
|
||||
wildcard, NULL);
|
||||
if (pcb != NULL) {
|
||||
*uc = crhold(inp->inp_cred);
|
||||
*uc = crhold(pcb->inp_cred);
|
||||
*ugid_lookupp = 1;
|
||||
}
|
||||
INP_INFO_RUNLOCK(pi);
|
||||
|
Loading…
x
Reference in New Issue
Block a user