Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:79428 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 63760 invoked from network); 4 Dec 2014 15:04:18 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 4 Dec 2014 15:04:18 -0000 Authentication-Results: pb1.pair.com header.from=are.you.winning@gmail.com; sender-id=pass Authentication-Results: pb1.pair.com smtp.mail=are.you.winning@gmail.com; spf=pass; sender-id=pass Received-SPF: pass (pb1.pair.com: domain gmail.com designates 209.85.212.176 as permitted sender) X-PHP-List-Original-Sender: are.you.winning@gmail.com X-Host-Fingerprint: 209.85.212.176 mail-wi0-f176.google.com Received: from [209.85.212.176] ([209.85.212.176:43719] helo=mail-wi0-f176.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id DE/50-61462-0F770845 for ; Thu, 04 Dec 2014 10:04:17 -0500 Received: by mail-wi0-f176.google.com with SMTP id ex7so34972130wid.15 for ; Thu, 04 Dec 2014 07:04:14 -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:date:message-id:subject :from:to:cc:content-type; bh=3yb82lNaou9xioxqEPTtLreG7ILatcH+X4rAE689IPM=; b=IHjS19kN4pjmlI+NY8G6aMWdTdyWoiOqbIUswgGJYJDv79UpmqZJbmg0v6jGLJg7ZG 75UJTglOglcnZqz6cNqAwzvFgMR6+6WQEE1mg7VhhGA5HerPpYeAT7uQl/vhyZtNLcXS EKd4+on+N7H4iD4v/6OJA4oVsLCs75CeaLBjX6FhtgyqVncoE+iM7Xmu68FPumr94QbD CtWJo2J+UUY8uf7A9zXmRb6YcWPyhlsHjG6IYC1ZaWb+7ympGuQGSza/WlPShw5oH4uG Y+5YQ5YiZLWhCm2CVDuk5Fa0qDjzl4p/B+pJag/XFhyXYFjwJhgJTBv1/rf+jsI0KJ++ 7oQA== MIME-Version: 1.0 X-Received: by 10.194.90.10 with SMTP id bs10mr4829948wjb.43.1417705454037; Thu, 04 Dec 2014 07:04:14 -0800 (PST) Sender: are.you.winning@gmail.com Received: by 10.180.8.36 with HTTP; Thu, 4 Dec 2014 07:04:13 -0800 (PST) In-Reply-To: References: Date: Thu, 4 Dec 2014 15:04:13 +0000 X-Google-Sender-Auth: dnqqQ1dcErnlncj1CZVl_fqSO2c Message-ID: To: Ferenc Kovacs Cc: Julien Pauli , Benjamin Eberlei , PHP Internals Content-Type: multipart/alternative; boundary=047d7bd9058efbf0950509654533 Subject: Re: [PHP-DEV] [RFC] Turn gc_collect_cycles into a function pointer From: cw@daverandom.com (Chris Wright) --047d7bd9058efbf0950509654533 Content-Type: text/plain; charset=UTF-8 On 4 December 2014 at 14:26, Ferenc Kovacs wrote: > 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 > > > > Those are all solid ideas and I wouldn't go against them if proposed, I'm > just a bit afraid that we end up with > http://en.wikipedia.org/wiki/Nirvana_fallacy where we reject small ideas > on > the ground of not being perfect or part of a bigger scheme while we don't > have the resources to actually make those bigger schemes a reallity. > Let see what the others think though. > +1 --047d7bd9058efbf0950509654533--