Home | History | Annotate | Line # | Download | only in common
uipc_usrreq_70.c revision 1.5
      1  1.5  pgoyette /*	$NetBSD: uipc_usrreq_70.c,v 1.5 2019/12/12 02:15:42 pgoyette Exp $	*/
      2  1.1       roy 
      3  1.1       roy /*-
      4  1.1       roy  * Copyright (c) 2016 The NetBSD Foundation, Inc.
      5  1.1       roy  * All rights reserved.
      6  1.1       roy  *
      7  1.1       roy  * This code is derived from software contributed to The NetBSD Foundation
      8  1.1       roy  * by Roy Marples.
      9  1.1       roy  *
     10  1.1       roy  * Redistribution and use in source and binary forms, with or without
     11  1.1       roy  * modification, are permitted provided that the following conditions
     12  1.1       roy  * are met:
     13  1.1       roy  * 1. Redistributions of source code must retain the above copyright
     14  1.1       roy  *    notice, this list of conditions and the following disclaimer.
     15  1.1       roy  * 2. Redistributions in binary form must reproduce the above copyright
     16  1.1       roy  *    notice, this list of conditions and the following disclaimer in the
     17  1.1       roy  *    documentation and/or other materials provided with the distribution.
     18  1.1       roy  *
     19  1.1       roy  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     20  1.1       roy  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     21  1.1       roy  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     22  1.1       roy  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     23  1.1       roy  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     24  1.1       roy  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     25  1.1       roy  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     26  1.1       roy  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     27  1.1       roy  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     28  1.1       roy  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     29  1.1       roy  * POSSIBILITY OF SUCH DAMAGE.
     30  1.1       roy  */
     31  1.1       roy 
     32  1.1       roy #include <sys/cdefs.h>
     33  1.5  pgoyette __KERNEL_RCSID(0, "$NetBSD: uipc_usrreq_70.c,v 1.5 2019/12/12 02:15:42 pgoyette Exp $");
     34  1.2  pgoyette 
     35  1.2  pgoyette #if defined(_KERNEL_OPT)
     36  1.2  pgoyette #include "opt_compat_netbsd.h"
     37  1.2  pgoyette #endif
     38  1.1       roy 
     39  1.1       roy #include <sys/param.h>
     40  1.1       roy #include <sys/lwp.h>
     41  1.1       roy #include <sys/socket.h>
     42  1.1       roy #include <sys/socketvar.h>
     43  1.1       roy #include <sys/unpcb.h>
     44  1.1       roy #include <sys/mbuf.h>
     45  1.1       roy #include <sys/kauth.h>
     46  1.2  pgoyette #include <sys/compat_stub.h>
     47  1.1       roy 
     48  1.1       roy #include <compat/sys/socket.h>
     49  1.1       roy 
     50  1.1       roy struct mbuf *
     51  1.1       roy compat_70_unp_addsockcred(struct lwp *l, struct mbuf *control)
     52  1.1       roy {
     53  1.1       roy 	struct sockcred70 *sc;
     54  1.1       roy 	struct mbuf *m;
     55  1.1       roy 	void *p;
     56  1.1       roy 
     57  1.1       roy 	m = sbcreatecontrol1(&p, SOCKCRED70SIZE(kauth_cred_ngroups(l->l_cred)),
     58  1.1       roy 		SCM_OCREDS, SOL_SOCKET, M_WAITOK);
     59  1.2  pgoyette 	if (m == NULL) {
     60  1.1       roy 		return control;
     61  1.2  pgoyette 	}
     62  1.1       roy 
     63  1.1       roy 	sc = p;
     64  1.1       roy 	sc->sc_uid = kauth_cred_getuid(l->l_cred);
     65  1.1       roy 	sc->sc_euid = kauth_cred_geteuid(l->l_cred);
     66  1.1       roy 	sc->sc_gid = kauth_cred_getgid(l->l_cred);
     67  1.1       roy 	sc->sc_egid = kauth_cred_getegid(l->l_cred);
     68  1.1       roy 	sc->sc_ngroups = kauth_cred_ngroups(l->l_cred);
     69  1.1       roy 
     70  1.1       roy 	for (int i = 0; i < sc->sc_ngroups; i++)
     71  1.1       roy 		sc->sc_groups[i] = kauth_cred_group(l->l_cred, i);
     72  1.1       roy 
     73  1.1       roy 	return m_add(control, m);
     74  1.1       roy }
     75  1.2  pgoyette 
     76  1.2  pgoyette void
     77  1.2  pgoyette uipc_usrreq_70_init(void)
     78  1.2  pgoyette {
     79  1.2  pgoyette 
     80  1.5  pgoyette 	MODULE_HOOK_SET(uipc_unp_70_hook, compat_70_unp_addsockcred);
     81  1.2  pgoyette }
     82  1.2  pgoyette 
     83  1.2  pgoyette void
     84  1.2  pgoyette uipc_usrreq_70_fini(void)
     85  1.2  pgoyette {
     86  1.2  pgoyette 
     87  1.4  pgoyette 	MODULE_HOOK_UNSET(uipc_unp_70_hook);
     88  1.2  pgoyette }
     89