From: David Scott <dave.scott@eu.citrix.com>
To: Ian Jackson <Ian.Jackson@eu.citrix.com>, Rob Hoes <Rob.Hoes@citrix.com>
Cc: ian.campbell@citrix.com, xen-devel@lists.xen.org
Subject: Re: [PATCH v2-resend 22/30] libxl: ocaml: event management [and 1 more messages]
Date: Tue, 12 Nov 2013 15:49:05 +0000 [thread overview]
Message-ID: <52824DF1.2030404@eu.citrix.com> (raw)
In-Reply-To: <21122.16826.622192.625659@mariner.uk.xensource.com>
Rob Hoes writes ("[Xen-devel] [PATCH v2-resend 22/30] libxl: ocaml:
event management"):
>> +/* Event handling */
> ...
>> +short Poll_val(value event)
> ...
>> + switch (Int_val(event)) {
>> + case 0: res = POLLIN; break;
>> + case 1: res = POLLPRI; break;
> ...
>> +short Poll_events_val(value event_list)
> ...
>> + while (event_list != Val_emptylist) {
>> + events |= Poll_val(Field(event_list, 0));
>> + event_list = Field(event_list, 1);
On 12/11/13 14:56, Ian Jackson wrote:
> This is quite striking. You're converting a bitfield into a linked
> list of consed enums. Does ocaml really not have something more
> resembling a set-of-small-enum type, represeted as a bitfield ?
>
> The result is going to be a lot of consing every time libxl scratches
> its nose. In some cases very frequently. For example, if we're
> running the bootloader and copying input and output back and forth,
> we're using the datacopier machinery in libxl_aoutils.c. That
> involves enabling the fd writeability callback on each output fd,
> every time data is read from the input fd, and then disabling the
> writeability callback every time the data has been written. So one
> fd register/deregister pair for every lump of console output. There
> are probably other examples.
Unfortunately there's no direct support for bitfields in OCaml's heap
data representation. The common pattern is to convert bitfields into
lists of constructors e.g.
https://github.com/ocaml/ocaml/blob/trunk/otherlibs/unix/open.c#L74
On the positive side, the GC is optimised specifically for the case of
short-lived small objects, since this is what you get when you write a
compiler or a theorem prover. An allocation in the minor heap is simply
a pointer bump, and the trash is chucked out pretty often. The rule of
thumb is that anything which has the allocation profile of a compiler or
a theorem prover usually works pretty well :-)
I think if we're allocating a (shortish) list per "lump" of console I/O
we're probably ok since I assume we're allocating and deallocating
bigger buffers for the console data anyway. For higher throughput
channels (vchan, network, disk etc) I'd go for larger,
statically-allocated pools of buffers for the data and use a bigger
lump-size to amortize the cost of the metadata handling.
Cheers,
Dave
next prev parent reply other threads:[~2013-11-12 15:49 UTC|newest]
Thread overview: 146+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-11-06 17:49 [PATCH v4 00/27] libxl: ocaml: improve the bindings Rob Hoes
2013-08-22 10:50 ` [PATCH v2-resend 00/30] " Rob Hoes
2013-08-22 10:50 ` [PATCH v2-resend 01/30] libxl: Add LIBXL_SHUTDOWN_REASON_UNKNOWN Rob Hoes
2013-08-27 14:54 ` Ian Jackson
[not found] ` <12f36dbf-3fdc-45e8-b3c1-5194ea356197@FTLPEX01CL02.citrite.net>
2013-09-10 10:55 ` Ian Campbell
2013-08-22 10:50 ` [PATCH v2-resend 02/30] libxl: idl: allow KeyedUnion members to be empty Rob Hoes
2013-08-27 14:53 ` Ian Jackson
2013-08-27 14:56 ` Ian Campbell
2013-08-27 14:59 ` Ian Jackson
2013-08-27 15:04 ` Ian Campbell
2013-08-27 16:27 ` Ian Jackson
2013-08-22 10:50 ` [PATCH v2-resend 03/30] libxl: idl: add domain_type field to libxl_dominfo struct Rob Hoes
2013-08-27 14:55 ` Ian Jackson
2013-09-10 10:56 ` Ian Campbell
2013-09-10 11:00 ` Ian Campbell
2013-09-10 11:03 ` Rob Hoes
2013-08-22 10:50 ` [PATCH v2-resend 04/30] libxl: idl: complete some enums in the IDL with their defaults Rob Hoes
2013-08-27 14:56 ` Ian Jackson
2013-09-10 10:57 ` Ian Campbell
2013-09-10 11:02 ` Ian Campbell
2013-08-22 10:50 ` [PATCH v2-resend 05/30] libxl: ocaml: fix code intended to output comments before definitions Rob Hoes
2013-08-27 14:57 ` Ian Jackson
2013-09-10 10:57 ` Ian Campbell
2013-08-22 10:50 ` [PATCH v2-resend 06/30] libxl: ocaml: support for Arrays in bindings generator Rob Hoes
2013-08-27 14:59 ` Ian Jackson
2013-08-27 15:06 ` Ian Campbell
2013-08-27 15:12 ` Ian Jackson
2013-08-28 14:37 ` Rob Hoes
2013-08-22 10:50 ` [PATCH v2-resend 07/30] libxl: ocaml: avoid reserved words in type and field names Rob Hoes
2013-08-27 15:01 ` Ian Jackson
2013-08-29 10:29 ` Rob Hoes
2013-08-22 10:50 ` [PATCH v2-resend 08/30] libxl: ocaml: support for KeyedUnion in the bindings generator Rob Hoes
2013-08-27 15:09 ` Ian Jackson
2013-08-27 15:13 ` Ian Campbell
2013-08-27 15:20 ` Ian Jackson
2013-08-27 15:28 ` Ian Campbell
2013-08-28 14:47 ` Rob Hoes
2013-08-22 10:50 ` [PATCH v2-resend 09/30] libxl: ocaml: add some more builtin types Rob Hoes
2013-08-27 15:21 ` Ian Jackson
2013-08-28 14:52 ` Rob Hoes
2013-08-22 10:50 ` [PATCH v2-resend 10/30] libxc: ocaml: add simple binding for xentoollog (output only) Rob Hoes
2013-08-27 15:33 ` Ian Jackson
2013-08-29 12:54 ` Rob Hoes
2013-08-29 13:12 ` Ian Campbell
2013-08-29 15:07 ` Ian Jackson
2013-08-29 15:05 ` Ian Jackson
2013-08-22 10:50 ` [PATCH v2-resend 11/30] libxl: ocaml: allocate a long lived libxl context Rob Hoes
2013-08-27 15:38 ` Ian Jackson
2013-08-28 15:55 ` Rob Hoes
2013-08-22 10:51 ` [PATCH v2-resend 12/30] libxl: ocaml: switch all functions over to take a context Rob Hoes
2013-08-27 15:41 ` Ian Jackson
2013-08-22 10:51 ` [PATCH v2-resend 13/30] libxl: ocaml: propagate the libxl return error code in exceptions Rob Hoes
2013-08-27 15:43 ` Ian Jackson
2013-08-22 10:51 ` [PATCH v2-resend 14/30] libxl: ocaml: make Val_defbool GC-proof Rob Hoes
2013-08-27 15:48 ` Ian Jackson
2013-08-22 10:51 ` [PATCH v2-resend 15/30] libxl: ocaml: add domain_build/create_info/config and events to the bindings Rob Hoes
2013-08-27 15:50 ` Ian Jackson
2013-08-22 10:51 ` [PATCH v2-resend 16/30] libxl: ocaml: add META to list of generated files in Makefile Rob Hoes
2013-08-27 17:49 ` Ian Jackson
2013-08-22 10:51 ` [PATCH v2-resend 17/30] libxl: ocaml: fix the handling of enums in the bindings generator Rob Hoes
2013-08-27 17:41 ` Ian Jackson
2013-08-22 10:51 ` [PATCH v2-resend 18/30] libxl: ocaml: use the "string option" type for IDL strings Rob Hoes
2013-08-27 17:44 ` Ian Jackson
2013-08-28 8:30 ` Ian Campbell
2013-08-28 10:33 ` Ian Jackson
2013-08-28 10:41 ` Ian Campbell
2013-08-22 10:51 ` [PATCH v2-resend 19/30] libxl: ocaml: add xen_console_read Rob Hoes
2013-08-27 17:46 ` Ian Jackson
2013-08-22 10:51 ` [PATCH v2-resend 20/30] libxl: ocaml: add dominfo_list and dominfo_get Rob Hoes
2013-08-27 17:51 ` Ian Jackson
2013-08-22 10:51 ` [PATCH v2-resend 21/30] libxl: ocaml: implement some simple tests Rob Hoes
2013-08-27 17:52 ` Ian Jackson
2013-08-22 10:51 ` [PATCH v2-resend 22/30] libxl: ocaml: event management Rob Hoes
2013-08-27 17:56 ` Ian Jackson
2013-08-22 10:51 ` [PATCH v2-resend 23/30] libxl: ocaml: allow device operations to be called asynchronously Rob Hoes
2013-08-22 10:51 ` [PATCH v2-resend 24/30] libxl: ocaml: add NIC helper functions Rob Hoes
2013-08-22 10:51 ` [PATCH v2-resend 25/30] libxl: ocaml: add PCI device " Rob Hoes
2013-08-22 10:51 ` [PATCH v2-resend 26/30] libxl: ocaml: add disk and cdrom " Rob Hoes
2013-08-22 10:51 ` [PATCH v2-resend 27/30] libxl: ocaml: add VM lifecycle operations Rob Hoes
2013-08-22 10:51 ` [PATCH v2-resend 28/30] libxl: ocaml: in send_debug_keys, clean up before raising exception Rob Hoes
2013-08-22 10:51 ` [PATCH v2-resend 29/30] libxl: ocaml: provide defaults for libxl types Rob Hoes
2013-08-22 10:51 ` [PATCH v2-resend 30/30] libxl: ocaml: use CAMLlocal1 macro rather than value-type in auto-generated C-code Rob Hoes
2013-09-10 10:58 ` [PATCH v2-resend 00/30] libxl: ocaml: improve the bindings Ian Campbell
2013-09-10 11:02 ` Rob Hoes
2013-09-10 12:57 ` Ian Campbell
2013-09-10 13:06 ` Rob Hoes
2013-11-06 17:49 ` [PATCH v4 01/27] libxl: ocaml: support for Arrays in bindings generator Rob Hoes
2013-11-06 17:49 ` [PATCH v4 02/27] libxl: ocaml: avoid reserved words in type and field names Rob Hoes
2013-11-11 14:17 ` Ian Campbell
2013-11-06 17:49 ` [PATCH v4 03/27] libxl: ocaml: support for KeyedUnion in the bindings generator Rob Hoes
2013-11-06 17:49 ` [PATCH v4 04/27] libxl: ocaml: add some more builtin types Rob Hoes
2013-11-06 17:49 ` [PATCH v4 05/27] libxc: ocaml: add simple binding for xentoollog (output only) Rob Hoes
2013-11-11 15:30 ` Ian Campbell
2013-11-12 13:46 ` Rob Hoes
2013-11-12 13:52 ` Ian Campbell
2013-11-06 17:49 ` [PATCH v4 06/27] libxl: ocaml: allocate a long lived libxl context Rob Hoes
2013-11-06 17:49 ` [PATCH v4 07/27] libxl: ocaml: switch all functions over to take a context Rob Hoes
2013-11-06 17:49 ` [PATCH v4 08/27] libxl: idl: add Enumeration.value_namespace property Rob Hoes
2013-11-11 14:31 ` Ian Campbell
2013-11-06 17:49 ` [PATCH v4 09/27] libxl: make the libxl error type an IDL enum Rob Hoes
2013-11-11 14:31 ` Ian Campbell
2013-11-06 17:49 ` [PATCH v4 10/27] libxl: ocaml: generate string_of_* functions for enums Rob Hoes
2013-11-11 14:33 ` Ian Campbell
2013-11-06 17:49 ` [PATCH v4 11/27] libxl: ocaml: propagate the libxl return error code in exceptions Rob Hoes
2013-11-06 17:49 ` [PATCH v4 12/27] libxl: ocaml: make Val_defbool GC-proof Rob Hoes
2013-11-06 17:49 ` [PATCH v4 13/27] libxl: ocaml: add domain_build/create_info/config and events to the bindings Rob Hoes
2013-11-06 17:49 ` [PATCH v4 14/27] libxl: ocaml: fix the handling of enums in the bindings generator Rob Hoes
2013-11-06 17:49 ` [PATCH v4 15/27] libxl: ocaml: use the "string option" type for IDL strings Rob Hoes
2013-11-06 17:49 ` [PATCH v4 16/27] libxl: ocaml: add dominfo_list and dominfo_get Rob Hoes
2013-11-06 17:49 ` [PATCH v4 17/27] libxl: ocaml: implement some simple tests Rob Hoes
2013-11-06 17:49 ` [PATCH v4 18/27] libxl: ocaml: event management Rob Hoes
2013-11-11 14:42 ` [PATCH v2-resend 22/30] libxl: ocaml: event management [and 1 more messages] Ian Jackson
2013-11-11 15:39 ` Rob Hoes
2013-11-12 14:56 ` Ian Jackson
2013-11-12 15:49 ` David Scott [this message]
2013-11-12 16:41 ` Ian Jackson
2013-11-12 17:14 ` Rob Hoes
2013-11-12 17:18 ` Ian Jackson
2013-11-14 17:39 ` Rob Hoes
2013-11-14 18:08 ` Ian Jackson
2013-11-26 18:03 ` Rob Hoes
2013-11-28 16:46 ` Ian Jackson
2013-11-28 17:53 ` Rob Hoes
2013-11-06 17:49 ` [PATCH v4 19/27] libxl: ocaml: allow device operations to be called asynchronously Rob Hoes
2013-11-06 17:49 ` [PATCH v4 20/27] libxl: ocaml: add NIC helper functions Rob Hoes
2013-11-11 14:43 ` Ian Campbell
2013-11-06 17:49 ` [PATCH v4 21/27] libxl: ocaml: add PCI device " Rob Hoes
2013-11-06 17:50 ` [PATCH v4 22/27] libxl: ocaml: add disk and cdrom " Rob Hoes
2013-11-11 14:44 ` Ian Campbell
2013-11-06 17:50 ` [PATCH v4 23/27] libxl: ocaml: add VM lifecycle operations Rob Hoes
2013-11-11 14:50 ` Ian Campbell
2013-11-11 15:54 ` Rob Hoes
2013-11-11 15:58 ` Ian Campbell
2013-11-12 12:27 ` Rob Hoes
2013-11-12 13:54 ` Ian Campbell
2013-11-12 14:09 ` Rob Hoes
2013-11-12 14:16 ` Ian Campbell
2013-11-12 14:18 ` Ian Campbell
2013-11-06 17:50 ` [PATCH v4 24/27] libxl: ocaml: in send_debug_keys, clean up before raising exception Rob Hoes
2013-11-06 17:50 ` [PATCH v4 25/27] libxl: ocaml: provide defaults for libxl types Rob Hoes
2013-11-06 17:50 ` [PATCH v4 26/27] libxl: ocaml: use CAMLlocal1 macro rather than value-type in auto-generated C-code Rob Hoes
2013-11-06 17:50 ` [PATCH v4 27/27] libxl: ocaml: add console reader functions Rob Hoes
2013-11-11 15:47 ` [PATCH v4 00/27] libxl: ocaml: improve the bindings Ian Campbell
2013-11-12 11:28 ` Rob Hoes
2013-11-20 17:15 ` Ian Campbell
2013-11-20 17:43 ` Rob Hoes
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=52824DF1.2030404@eu.citrix.com \
--to=dave.scott@eu.citrix.com \
--cc=Ian.Jackson@eu.citrix.com \
--cc=Rob.Hoes@citrix.com \
--cc=ian.campbell@citrix.com \
--cc=xen-devel@lists.xen.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.