Date: Mon, 2 Jan 2017 23:56:22 +1100 (EST) From: Ian Smith <smithi@nimnet.asn.au> To: sdf <jiejinmv@163.com> Cc: freebsd-questions@freebsd.org Subject: Re: when should we lock a process? Message-ID: <20170102233228.Q26979@sola.nimnet.asn.au> In-Reply-To: <mailman.105.1483358402.69123.freebsd-questions@freebsd.org> References: <mailman.105.1483358402.69123.freebsd-questions@freebsd.org>
next in thread | previous in thread | raw e-mail | index | archive | help
In freebsd-questions Digest, Vol 657, Issue 1, Message: 10 On Mon, 2 Jan 2017 17:23:15 +0800 (CST) sdf <jiejinmv@163.com> wrote: > Hi, friends. Can you see me? > I am new here and i am reading freebsd 11.0's kernel code since these days. > I don't know the purpose of this line of code: > ================= > PROC_LOCK(p); > ================ > which is located at sys/kern/kern_exec.c line:394 function:do_execve(). > And let me paste its context here: > 387 /* > 388 * Lock the process and set the P_INEXEC flag to indicate that > 389 * it should be left alone until we're done here. This is > 390 * necessary to avoid race conditions - e.g. in ptrace() - > 391 * that might allow a local user to illicitly obtain elevated > 392 * privileges. > 393 */ > 394 PROC_LOCK(p); > 395 KASSERT((p->p_flag & P_INEXEC) == 0, > 396 ("%s(): process already has P_INEXEC flag", __func__)); > 397 p->p_flag |= P_INEXEC; > 398 PROC_UNLOCK(p); > > Could some one tell me when to lock a process? In another word, What > are we doing when we are locking a process. I can trace out its > definition but i want to know more. > ================================== > #define PROC_LOCK(p) mtx_lock(&(p)->p_mtx) > ================================== > > Thanks! > BTW: Is this maillist for kernel questions? If my question is not > suitable here, could you tell me which maillist is for kernel > developers? You will most likely find freebsd-hackers@freebsd.org a more suitable place for kernel (and other) code questions. https://lists.freebsd.org/mailman/listinfo/freebsd-hackers You can review the archives there; you may need to subscribe to post. All public FreeBSD lists: https://lists.freebsd.org/mailman/listinfo cheers, Ian
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20170102233228.Q26979>