From owner-freebsd-current@FreeBSD.ORG Sat Feb 4 00:02:33 2012 Return-Path: Delivered-To: freebsd-current@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 7554E1065672 for ; Sat, 4 Feb 2012 00:02:33 +0000 (UTC) (envelope-from dmitrym@juniper.net) Received: from exprod7og103.obsmtp.com (exprod7og103.obsmtp.com [64.18.2.159]) by mx1.freebsd.org (Postfix) with ESMTP id EFFAD8FC21 for ; Sat, 4 Feb 2012 00:02:32 +0000 (UTC) Received: from P-EMHUB03-HQ.jnpr.net ([66.129.224.36]) (using TLSv1) by exprod7ob103.postini.com ([64.18.6.12]) with SMTP ID DSNKTyx1l46edWDPR8yYCsUdy3EB4moczXtY@postini.com; Fri, 03 Feb 2012 16:02:33 PST Received: from magenta.juniper.net (172.17.27.123) by P-EMHUB03-HQ.jnpr.net (172.24.192.33) with Microsoft SMTP Server (TLS) id 8.3.213.0; Fri, 3 Feb 2012 16:01:48 -0800 Received: from [172.24.26.191] (dmitrym-lnx.jnpr.net [172.24.26.191]) by magenta.juniper.net (8.11.3/8.11.3) with ESMTP id q1401m167044; Fri, 3 Feb 2012 16:01:48 -0800 (PST) (envelope-from dmitrym@juniper.net) Message-ID: <4F2C756A.80900@juniper.net> Date: Fri, 3 Feb 2012 16:01:46 -0800 From: Dmitry Mikulin User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:9.0) Gecko/20111229 Thunderbird/9.0 MIME-Version: 1.0 To: Kostik Belousov References: <749E238A-A85F-4264-9DEB-BCE1BBD21C9D@juniper.net> <20120125074824.GD2726@deviant.kiev.zoral.com.ua> <4F2094B4.70707@juniper.net> <20120126122326.GT2726@deviant.kiev.zoral.com.ua> <4F22E8FD.6010201@juniper.net> <20120129074843.GL2726@deviant.kiev.zoral.com.ua> <4F26E0D1.8040100@juniper.net> <20120130192727.GZ2726@deviant.kiev.zoral.com.ua> In-Reply-To: <20120130192727.GZ2726@deviant.kiev.zoral.com.ua> Content-Type: multipart/mixed; boundary="------------030706030706070106060906" X-EXCLAIMER-MD-CONFIG: e4081efb-6d29-443c-8708-750833aec629 X-Mailman-Approved-At: Sat, 04 Feb 2012 00:19:19 +0000 X-Content-Filtered-By: Mailman/MimeDel 2.1.5 Cc: freebsd-current Current , Marcel Moolenaar Subject: Re: [ptrace] please review follow fork/exec changes X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 04 Feb 2012 00:02:33 -0000 --------------030706030706070106060906 Content-Type: text/plain; charset="ISO-8859-1"; format=flowed Content-Transfer-Encoding: 7bit > Please provide more details, I am looking forward for the panic > message and backtrace. I can't seem to get the panic with the latest source base, but tracing doesn't appear to work with vfork(). I attached a modified test case to closer model what gdb is doing. If you change fork() to vfork() in simple.c the parent doesn't get the events the same way it does under fork(). > The lack of the notification for parent is exactly what the patch I > posted fixes. More exactly, it is the lack of notification for parent > with PT_CONTINUE loop. I will commit this today. > > Regarding a single notification. Currently, parent arrives at the > syscall return code only after the child is attached to the debugger. > See the cv_wait() in kern_fork.c:739. In other words, if you get the > PL_FLAG_FORK, the child is already attached (at last it shall be). My > scescx.c code illustrates this well, IMO. > > You still get a separate stop from the child, but I do not see how is it > harmful. There a couple of tweaks to the interface that I'd like to have: - set PL_FLAG_FORKED in the child so gdb can identify the stop as a fork() event. - add a switch similar to PT_FOLLOW_FORK to enable/disable exec() notifications. Gdb gets confused by the events it hasn't explicitly asked for and having a switch makes it easier to filter out unwanted stops. Do you think it's possible/makes sense? Thanks. Dmitry. --------------030706030706070106060906--