Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 30 Jun 2010 16:45:18 -0700
From:      Garrett Cooper <yanefbsd@gmail.com>
To:        Alexander Kabaev <kabaev@gmail.com>
Cc:        "Sam Fourman Jr." <sfourman@gmail.com>, Kostik Belousov <kostikbel@gmail.com>, freebsd-hackers@freebsd.org
Subject:   Re: kernel patch needed for wine?
Message-ID:  <AANLkTineENDg9MZwqJY44enyHqpfFxfVIdzS_6tG43TI@mail.gmail.com>
In-Reply-To: <20100630192350.105e8303@kan.dnsalias.net>
References:  <AANLkTik5Owwpk5O6eUbSKgHxpjvcEXwilGECgtX0hx5a@mail.gmail.com> <20100630105027.GJ13238@deviant.kiev.zoral.com.ua> <AANLkTikDxVGpc6LfYlqFZLo-QiJFr8lbj2MVZMUci-lI@mail.gmail.com> <AANLkTilusilVimfscZdj3QAOOFYs3Gh3pt5V6SXe3VHP@mail.gmail.com> <AANLkTinNMaMH_5TSUL8PN1D0J-IBjIZV8K_sBTeB1H64@mail.gmail.com> <AANLkTiksgnem7qiGzpJIVQp7Dxsu0dfasF10STzSwxBf@mail.gmail.com> <20100630192350.105e8303@kan.dnsalias.net>

next in thread | previous in thread | raw e-mail | index | archive | help
2010/6/30 Alexander Kabaev <kabaev@gmail.com>:
> On Wed, 30 Jun 2010 14:42:47 -0700
> Garrett Cooper <yanefbsd@gmail.com> wrote:
>
>> On Wed, Jun 30, 2010 at 2:22 PM, Sam Fourman Jr. <sfourman@gmail.com>
>> wrote:
>> > On Wed, Jun 30, 2010 at 11:26 AM, Garrett Cooper
>> > <yanefbsd@gmail.com> wrote:
>> >> On Wed, Jun 30, 2010 at 8:43 AM, Sam Fourman Jr.
>> >> <sfourman@gmail.com> wrote:
>> >>>> Which patch ? icebp generates the SIGTRAP on latest 8-stable,
>> >>>> verified by the following trivival assembler program:
>> >>>> =A0 =A0 =A0 =A0.text
>> >>>> =A0 =A0 =A0 =A0.globl =A0main
>> >>>> main:
>> >>>> =A0 =A0 =A0 =A0.byte =A0 0xf1
>> >>>> =A0 =A0 =A0 =A0xorl =A0 =A0%edi,%edi
>> >>>> =A0 =A0 =A0 =A0call =A0 =A0exit
>> >>>>
>> >>>
>> >
>> > Here is the C program that the linux people used as a test case.
>> >
>> > ***************************************************************
>> > #include <stdio.h>
>> > #include <signal.h>
>> >
>> >
>> >
>> > void trap_handler(int sig)
>> > {
>> > =A0 =A0 =A0 =A0printf("trapped\n");
>> > }
>> >
>> >
>> > /*
>> > =A0* icebp
>> > =A0* ret
>> > =A0*/
>> > char icebp_func[] =3D "\xf1\xc3";
>> > typedef void (*icebp_call)(void);
>> >
>> > int main(int argc, char **argv)
>> > {
>> > =A0 =A0 =A0 =A0icebp_call func =3D (icebp_call)icebp_func;
>> >
>> > =A0 =A0 =A0 =A0signal(SIGTRAP, trap_handler);
>> >
>> > =A0 =A0 =A0 =A0func();
>> >
>> > =A0 =A0 =A0 =A0return 0;
>> > }
>> >
>> > ***************************************************************
>> >
>> > My question is why doe the above code not print trapped on amd64?
>> >
>> > FreeBSD 8.1 i386 this code prints "Trapped" as intended
>> > FreeBSD 8.1 amd64 this code prints "Segmentation fault: 11"
>> > FreeBSD 8.1 amd64 chrooted to 32bit prints "Segmentation fault"
>> >
>> > I did verify that from Linux amd64 this works and prints "Trapped"
>> > uname -a
>> > Linux workstation 2.6.32-23-generic #37-Ubuntu SMP Fri Jun 11
>> > 08:03:28 UTC 2010 x86_64 GNU/Linux
>>
>> Hmmm... I've seen similar whackiness with Linux and signals, but
>> that's a different thing entirely (it was rt signals vs non-rt
>> signals).
>>
>> Here's a modified version of the testcase (wanted to make sure that
>> things were sane):
>>
>> $ cat test_sigtrap.c
>> #include <err.h>
>> #include <signal.h>
>> #include <stdio.h>
>>
>> int trapped =3D 0;
>>
>> void trap_handler(int sig)
>> {
>> =A0 =A0 =A0 trapped =3D 1;
>> }
>>
>>
>> /*
>> =A0* icebp
>> =A0* ret
>> =A0*/
>> char icebp_func[] =3D "\xf1\xc3";
>> typedef void (*icebp_call)(void);
>>
>> int main(int argc, char **argv)
>> {
>> =A0 =A0 =A0 icebp_call func =3D (icebp_call)icebp_func;
>>
>> =A0 =A0 =A0 if (signal(SIGTRAP, trap_handler) =3D=3D SIG_ERR)
>> =A0 =A0 =A0 =A0 =A0 =A0 =A0 err(1, "signal");
>>
>> =A0 =A0 =A0 func();
>>
>> =A0 =A0 =A0 if (trapped)
>> =A0 =A0 =A0 =A0 =A0 =A0 =A0 printf("Admiral Ackbar: it's a trap!\n");
>>
>> =A0 =A0 =A0 return 0;
>> }
>>
>> Ran it and it segfaulted on CURRENT:
>>
>
> Now make icebp_func const and observe the program start working. The
> test case is broken as written, because icebp_func array is writable,
> so in ends up in a non-const part of .bss, which is not marked as
> executable and rightfully causes SIGSEGV when jumped to.

Which means that Linux is broken in this regard because it's loading
data as text, not data as data and text as text?
Thanks,
-Garrett



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?AANLkTineENDg9MZwqJY44enyHqpfFxfVIdzS_6tG43TI>