Re: [PATCH v2 0/4] [RFC] Implement Trampoline File Descriptor
From: Florian Weimer
Date: Wed Sep 16 2020 - 21:11:04 EST
> Examples of trampolines
> libffi (A Portable Foreign Function Interface Library):
> libffi allows a user to define functions with an arbitrary list of
> arguments and return value through a feature called "Closures".
> Closures use trampolines to jump to ABI handlers that handle calling
> conventions and call a target function. libffi is used by a lot
> of different applications. To name a few:
> - Python
> - Java
> - Ruby FFI
> - Lisp
> - Objective C
libffi does not actually need this. It currently collocates
trampolines and the data they need on the same page, but that's
actually unecessary. It's possible to avoid doing this just by
changing libffi, without any kernel changes.
I think this has already been done for the iOS port.
> The code for trampoline X in the trampoline table is:
> load &code_table[X], code_reg
> load (code_reg), code_reg
> load &data_table[X], data_reg
> load (data_reg), data_reg
> jump code_reg
> The addresses &code_table[X] and &data_table[X] are baked into the
> trampoline code. So, PC-relative data references are not needed. The user
> can modify code_table[X] and data_table[X] dynamically.
You can put this code into the libffi shared object and map it from
there, just like the rest of the libffi code. To get more
trampolines, you can map the page containing the trampolines multiple
times, each instance preceded by a separate data page with the control
I think the previous patch submission has also resulted in several
comments along those lines, so I'm not sure why you are reposting
> I have implemented my solution for libffi and provided the changes for
> X86 and ARM, 32-bit and 64-bit. Here is the reference patch:
The URL does not appear to work, I get a 403 error.
> If the trampfd patchset gets accepted, I will send the libffi changes
> to the maintainers for a review. BTW, I have also successfully executed
> the libffi self tests.
I have not seen your libffi changes, but I expect that the complexity
is about the same as a userspace-only solution.
Cc:ing libffi upstream for awareness. The start of the thread is