Newsgroups: php.internals
Path: news.php.net
Xref: news.php.net php.internals:102046
Return-Path: <michal@brzuchalski.com>
Mailing-List: contact internals-help@lists.php.net; run by ezmlm
Delivered-To: mailing list internals@lists.php.net
Received: (qmail 96863 invoked from network); 17 Apr 2018 07:24:18 -0000
Received: from unknown (HELO lists.php.net) (127.0.0.1)
  by localhost with SMTP; 17 Apr 2018 07:24:18 -0000
Authentication-Results: pb1.pair.com smtp.mail=michal@brzuchalski.com; spf=permerror; sender-id=unknown
Authentication-Results: pb1.pair.com header.from=michal@brzuchalski.com; sender-id=unknown
Received-SPF: error (pb1.pair.com: domain brzuchalski.com from 188.165.245.118 cause and error)
X-PHP-List-Original-Sender: michal@brzuchalski.com
X-Host-Fingerprint: 188.165.245.118 ns220893.ip-188-165-245.eu  
Received: from [188.165.245.118] ([188.165.245.118:50170] helo=poczta.brzuchalski.com)
	by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP
	id 94/78-36099-D11A5DA5 for <internals@lists.php.net>; Tue, 17 Apr 2018 03:24:15 -0400
Received: from localhost (localhost.localdomain [127.0.0.1])
	by poczta.brzuchalski.com (Postfix) with ESMTP id 3ACDE298423B
	for <internals@lists.php.net>; Tue, 17 Apr 2018 09:24:11 +0200 (CEST)
Received: from poczta.brzuchalski.com ([127.0.0.1])
	by localhost (poczta.brzuchalski.com [127.0.0.1]) (amavisd-new, port 10024)
	with ESMTP id enAfLabyB0sZ for <internals@lists.php.net>;
	Tue, 17 Apr 2018 09:24:04 +0200 (CEST)
Received: from mail-oi0-f46.google.com (unknown [209.85.218.46])
	by poczta.brzuchalski.com (Postfix) with ESMTPSA id CC2E82984236
	for <internals@lists.php.net>; Tue, 17 Apr 2018 09:24:03 +0200 (CEST)
Received: by mail-oi0-f46.google.com with SMTP id h11-v6so7684438oic.3
        for <internals@lists.php.net>; Tue, 17 Apr 2018 00:24:03 -0700 (PDT)
X-Gm-Message-State: ALQs6tCym6gXweJyDQY9AyXbuD2ZcD9ijApb7Hfrxynyx6jsj53zHWtz
	hOdrHTBM3VNf8AkptcoTwlnpYouoZGaQhRbGW5s=
X-Google-Smtp-Source: AIpwx4973B+tawzMbIlkauxWGZQDHJ8IECg6+ezeLetBnmKMKxCpUJJdSWg49qCY6f0e1raLgeYtW7Rb2zFhatZwpuc=
X-Received: by 2002:aca:efd5:: with SMTP id n204-v6mr535351oih.41.1523949842770;
 Tue, 17 Apr 2018 00:24:02 -0700 (PDT)
MIME-Version: 1.0
Received: by 2002:a9d:7106:0:0:0:0:0 with HTTP; Tue, 17 Apr 2018 00:24:02
 -0700 (PDT)
In-Reply-To: <af4cb226-df79-4b29-810e-52028792c37d@email.android.com>
References: <BN6PR02MB323404E036380FA42924D9A7BFB30@BN6PR02MB3234.namprd02.prod.outlook.com>
 <56794c33-a728-d399-2462-b62ba1b7a509@gmail.com> <af4cb226-df79-4b29-810e-52028792c37d@email.android.com>
Date: Tue, 17 Apr 2018 09:24:02 +0200
X-Gmail-Original-Message-ID: <CABdc3WpJhd9csdqtUW4KgRqmiq5vmnbrxEXjskAgPPf96nZk+w@mail.gmail.com>
Message-ID: <CABdc3WpJhd9csdqtUW4KgRqmiq5vmnbrxEXjskAgPPf96nZk+w@mail.gmail.com>
To: Dmitry Stogov <dmitry@zend.com>
Cc: Stanislav Malyshev <smalyshev@gmail.com>, Zeev Suraski <zeev@zend.com>, Xinchen Hui <laruence@gmail.com>, 
	Nikita Popov <nikic@php.net>, Bob Weinand <bwoebi@php.net>, 
	"Anatol Belski (ab@php.net)" <ab@php.net>, PHP internals list <internals@lists.php.net>
Content-Type: multipart/alternative; boundary="00000000000008b3b7056a06399b"
Subject: Re: [PHP-DEV] PHP FFI extenesion
From: michal@brzuchalski.com (=?UTF-8?Q?Micha=C5=82_Brzuchalski?=)

--00000000000008b3b7056a06399b
Content-Type: text/plain; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable

Hi Dmitry!

I am not much experienced with C but as a user, I'm just wondering if there
is a possibility to extend FFI class and autoregister all or just chosen
structs as classes, for eg.
class Libc extends FFI {
    public function __construct() {
        parent::__construct("...code", "...lib"); // tmp notation
        $this->register('struct timeval', Libc\Timeval::class); // I assume
they would extend CData
        $this->register('struct timezone', Libc\Timezone::class); // as
above
    }
}

So I can instantiate

$tz =3D new Libc\Timezone();
$tv =3D new Libc\Timeval();

and then pass them FFI function

(new Libc())->gettimeofday($tv, $tz);
var_dump($tv-tv_sec, $tv->tv_usec, $tz);

I would be able to prepare than a vendor package with a specified
autoloader.
Would that make sense?

Also wouldn't it better if CData class share the same prefixes like
FFICdata or FFI\CData?


Cheers,
Michal

2018-04-17 9:18 GMT+02:00 Dmitry Stogov <dmitry@zend.com>:

>
>
> On Apr 17, 2018 2:49 AM, Stanislav Malyshev <smalyshev@gmail.com> wrote:
> Hi!
>
> > I've spent some time thinking about simple FFI for PHP, and finally,
> borrowed most ideas from LuaJIT.
> >
> > This is an initial PoC. It was tested on Linux only.
> >
> >
> > https://github.com/dstogov/php-ffi
> >
> >
> > I would appreciate review, comments and ideas about missing features an=
d
> functionality.
> >
>
> Looks interesting. On a cursory look, couple of thoughts:
> - I think all the classes involved should be made non-serializable and
> non-unserializable.
>
> Agree.
>
> - Does it load shared libraries, or only uses ones already loaded? If
> the former, I think there should be a way to unload them at the request
> end (even though it might be performance issue, and may be not possible
> if persistent resources are involved), otherwise we leak state between
> requests.
>
> I have a bit opposit idea. We will keep FFI for CLI but disable it for we=
b
> apps (like dl()).
> At the same time, we will develop a technology to preload and reuse  PHP
> files across requests.
> And allow FFI there.
>
> - OTOH, people may want to load a set of persistent definitions from a
> config file, etc. - the ffi definition probably won't change much, and
> having locked down set of FFI interfaces the rest of the code is using
> might be beneficial
>
> Yeah. Like this.
>
> - Since this thing is dealing with raw pointers, etc., from PHP code,
> there may be a lot of crashes from using this extension in a wrong way.
> I wonder which facilities we could provide for helping people to debug
> it (for people who aren't super-comfortable using gdb on PHP engine).
>
> Programming using FFI, is very similar to C.
> I'm not sure, if we may provide good debugging facilities.
>
> Thanks for review.
>
> Dmitry.
>
>
> --
> Stas Malyshev
> smalyshev@gmail.com
>
> Hi!
>
> > I've spent some time thinking about simple FFI for PHP, and finally,
> borrowed most ideas from LuaJIT.
> >
> > This is an initial PoC. It was tested on Linux only.
> >
> >
> > https://github.com/dstogov/php-ffi
> >
> >
> > I would appreciate review, comments and ideas about missing features an=
d
> functionality.
> >
>
> Looks interesting. On a cursory look, couple of thoughts:
> - I think all the classes involved should be made non-serializable and
> non-unserializable.
> - Does it load shared libraries, or only uses ones already loaded? If
> the former, I think there should be a way to unload them at the request
> end (even though it might be performance issue, and may be not possible
> if persistent resources are involved), otherwise we leak state between
> requests.
> - OTOH, people may want to load a set of persistent definitions from a
> config file, etc. - the ffi definition probably won't change much, and
> having locked down set of FFI interfaces the rest of the code is using
> might be beneficial
> - Since this thing is dealing with raw pointers, etc., from PHP code,
> there may be a lot of crashes from using this extension in a wrong way.
> I wonder which facilities we could provide for helping people to debug
> it (for people who aren't super-comfortable using gdb on PHP engine).
>
> --
> Stas Malyshev
> smalyshev@gmail.com
>



--=20
regards / pozdrawiam,
--
Micha=C5=82 Brzuchalski
about.me/brzuchal
brzuchalski.com

--00000000000008b3b7056a06399b--