[vlc-devel] [PATCH 1/2] compat: Workaround sendmsg bug on some ArmV8 Android devices
Hugo Beauzée-Luyssen
hugo at beauzee.fr
Thu Apr 4 14:21:30 CEST 2019
On Thu, Apr 4, 2019, at 2:07 PM, Rémi Denis-Courmont wrote:
> I can only think of three ways to solve this:
> 1) Custom headers pretending that return type is int (will potentially
> break non-buggy devices tough).
> 2) Interposed wrappers for all affected calls.
> 3) Replacement (asm) implementation for all affected calls.
>
> It can't be done in VLC build system as the problem affects contribs too.
>
> Le 4 avril 2019 14:45:53 GMT+03:00, "Hugo Beauzée-Luyssen"
> <hugo at beauzee.fr> a écrit : On Thu, Apr 4, 2019, at 1:42 PM, Rémi
> Denis-Courmont wrote:
> >> Hi all,
> >>
> >> 5 minutes git archeology through bionic repo leads to this:
> >> https://android.googlesource.com/platform/bionic.git/+/3d19a8319b9c27af8aa5cfbf495da0fe7fa62d3e
> >>
> >> The bug affect basically all system call wrappers with a signed 64-bits
> >> return value type (including ssize_t).
> >>
> >> Clearly this patch ain't going to work.
> >>
> >> Le 4 avril 2019 10:54:44 GMT+03:00, "Hugo Beauzée-Luyssen"
> >> <hugo at beauzee.fr> a écrit : On Wed, Apr 3, 2019, at 9:24 PM, Rémi
> >> Denis-Courmont wrote:
> >>>> I don't know what you did or did not imply. When somebody states that a patch
> >>>> is ugly, I tend to assume that they dislike the form rather than the essence.
> >>>>
> >>>> My chief concerns are that, on the one hand, other system calls may also
> >>>> exhibit the bug, and on the other hand, contribs may be affected as well. In
> >>>> other words, I am concerned not that the patch is ugly, but that does not
> >>>> solve the problem(s).
> >>> It solves the observed problem, but it doesn't solve problems I don't know about indeed.
> >
> > Hi,
> >
> > Let aside the passive aggressiveness of the reply, this is exactly what I was hoping for by submitting the patch, that someone who knows libc/kernel more than I do figures out what the problem is.
> > I looked at the syscall wrapper but did not check the __set_errno it called, that's my bad.
> >
> > Thanks for finding the actual error.
>
I think it can be solved in the same way we use libwinstorecompat to remove forbidden calls on WinRT, including in the contribs.
I'll try to take a look at this sometime soon
--
Hugo Beauzée-Luyssen
hugo at beauzee.fr
More information about the vlc-devel
mailing list