Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:79425 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 56847 invoked from network); 4 Dec 2014 13:56:59 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 4 Dec 2014 13:56:59 -0000 Authentication-Results: pb1.pair.com smtp.mail=julienpauli@gmail.com; spf=pass; sender-id=pass Authentication-Results: pb1.pair.com header.from=julienpauli@gmail.com; sender-id=pass Received-SPF: pass (pb1.pair.com: domain gmail.com designates 209.85.192.43 as permitted sender) X-PHP-List-Original-Sender: julienpauli@gmail.com X-Host-Fingerprint: 209.85.192.43 mail-qg0-f43.google.com Received: from [209.85.192.43] ([209.85.192.43:43537] helo=mail-qg0-f43.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id 58/00-56256-A2860845 for ; Thu, 04 Dec 2014 08:56:59 -0500 Received: by mail-qg0-f43.google.com with SMTP id q108so12774022qgd.30 for ; Thu, 04 Dec 2014 05:56:55 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:sender:in-reply-to:references:from:date:message-id :subject:to:cc:content-type; bh=daDAihzVdSBQTg/h/IKH2MazNNYcBGS3+lImJZpCyFk=; b=GyaBE+rS/cnlZtGqzINnqi71r0jBv7ObmJDizFVRdg2axlQpLrygQvVd1ioNc4LKkt v/fZhgyu43It+ujxE7inE11fL2aE3LkHZ/q6RHEplvBozL0mVsTlXsN9XiRKyz2zMcZ5 EPLWWWsnWeUJGFShvUj6+TMgT8wuFkoWiGxJo+NW18GwjFgkco3xHs0mQvtU7DIf3xtm 7IaTfIK+epHBsRdHKFncGouTouxuxEEOMYIQb46OMJoynvpHzfBJ4aTnUXuchpaoQV+l gWBsbGKMWoFG3giXlJATHQLlXfGeXaUAvIdg1mQ21RQW/brSlGW15iqQcDxkN9G6rVq+ mQhA== X-Received: by 10.224.65.69 with SMTP id h5mr17066584qai.69.1417701415464; Thu, 04 Dec 2014 05:56:55 -0800 (PST) MIME-Version: 1.0 Sender: julienpauli@gmail.com Received: by 10.140.20.86 with HTTP; Thu, 4 Dec 2014 05:56:15 -0800 (PST) In-Reply-To: References: Date: Thu, 4 Dec 2014 14:56:15 +0100 X-Google-Sender-Auth: VM_0SywehYj8wQyI3RSR5OFguHQ Message-ID: To: Ferenc Kovacs Cc: Benjamin Eberlei , PHP Internals Content-Type: text/plain; charset=UTF-8 Subject: Re: [PHP-DEV] [RFC] Turn gc_collect_cycles into a function pointer From: jpauli@php.net (Julien Pauli) On Thu, Dec 4, 2014 at 1:17 PM, Julien Pauli wrote: > On Thu, Dec 4, 2014 at 12:39 PM, Ferenc Kovacs wrote: >> >> >> On Thu, Dec 4, 2014 at 11:53 AM, Julien Pauli wrote: >>> >>> On Thu, Dec 4, 2014 at 9:30 AM, Benjamin Eberlei >>> wrote: >>> > Good morning, >>> > >>> > This is just a very small change, I propose this RFC for discussion to >>> > turn >>> > the C function "gc_collect_cycles" into a pointer. >>> > >>> > https://wiki.php.net/rfc/gc_fn_pointer >>> > >>> > Composer's garbage collection optimization showed that PHP Profilers >>> > fail >>> > to capture the dynamics of GC and we need better hooks to make this >>> > possible. >>> >>> There are many other things that could be turned into function >>> pointers to allow extensions to hook. >>> Our hook strategy should be reviewed entirely. >>> >>> Not only GC. If you look at streams, many of them are not >>> overwritable, and some are, but they are missing from the headers file >>> so you may not overwrite them. >>> >>> I suggest we design a wider RFC for PHP7 about what we would be able >>> to hook, and what not (and what is the impact, because the more you >>> hook , the more complex it becomes about bad interactions). >>> >>> This may also include a refactoring in the zend_module_entry and the >>> zend_extension structs. Fe, zend_extension hooks about the op_array >>> could be reworked , I find the op_array_dtor_handler hook misplaced in >>> the chain. >>> zend_module_entry could also benefit from refactoring to have a better >>> knowing of other extensions, and a true dependency manager. >>> >> >> That sounds like a lot of work. >> +1 if somebody willing to champion that effort, but I wouldn't delay/discard >> this small improvement on the vague promise that maybe this will be solved >> as part of a bigger rfc. >> just my 2 cents ofc. > > Yep, but the problem in adding a new hook is that today its for > feature A, tomorrow it will be for feature B, etc... > There is a risk of lack of consistency between all the ideas, that's > why I myself did not propose any single idea in this way, but prefer > merging them and propose something more consistent. > We could benefit from a new major release to have a more global > hooking strategy. > Also, as this changes the ABI by publishing a new ZEND_API, we should > consider adding this in a major and not in a stable release (even > thought that doesnt break the ABI). > > I agree some ideas may represent more work than others (like a > dependency management system for extensions), however, big part of the > ideas is just about "what hook to move", "where to", "why" and "what > hook to add" (and why). > > Also, having too many hooks can lead to many problems like extensions > incompatibility, something barely taken care of in our module API, but > which should as well be redesigned as it doesn't really work that > much. > > Julien.P For GC and any other function that would need to be overwritten, we may use zend_utility_functions. That would limit the number of exported symbols we publish. I don't know why zend_execute and zend_execute_internal are not part of it though. That would need a refactor to export zend_utility_function as global, and use it in any SAPI (it's actually local to main()). Dmitry, Laruence , any advice ? Julien.Pauli