[PATCH] 8170639: [Linux] jsig is limited to a maximum of 64 signals

Ioi Lam ioi.lam at oracle.com
Wed Mar 13 02:19:10 UTC 2019


I reviewed this version.

http://cr.openjdk.java.net/~aoqi/8170639/webrev.03

For David's testing, I assume both BSD (macos) and Linux have been 
tested. The AIX code is essentially unchanged. So I think this change is 
good.

Thanks
- Ioi



On 3/11/19 4:57 AM, David Holmes wrote:
> On 11/03/2019 6:09 pm, Ao Qi wrote:
>> Hi David,
>>
>> On Mon, Mar 11, 2019 at 3:59 PM David Holmes 
>> <david.holmes at oracle.com> wrote:
>>>
>>> On 11/03/2019 4:10 pm, David Holmes wrote:
>>>> Hi,
>>>>
>>>> Sorry was on a few days vacation.
>>>>
>>>> I will run this through our test system and report back.
>>
>> Thank you very much!
>>
>>>
>>> All passed.
>>
>> Happy to hear that. David, are you okay with this patch? Do I need
>> another review?
>
> Yes a second review is needed.
>
> Thanks,
> David
>
>>
>> Ao Qi
>>
>>>
>>> David
>>> -----
>>>
>>>> David
>>>>
>>>> On 5/03/2019 8:59 pm, Ao Qi wrote:
>>>>> On Tue, Mar 5, 2019 at 6:35 PM David Holmes <david.holmes at oracle.com>
>>>>> wrote:
>>>>>>
>>>>>> On 5/03/2019 8:25 pm, Ao Qi wrote:
>>>>>>> Hi David,
>>>>>>>
>>>>>>> Webrev: http://cr.openjdk.java.net/~aoqi/8170639/webrev.03
>>>>>>>
>>>>>>> What about this version? Am I understanding correctly? I think this
>>>>>>> version is indeed much better.
>>>>>>
>>>>>> Yes that's what I meant.
>>>>>>
>>>>>>> I also fixed a problem in my previous
>>>>>>> version:( The code was only put into #ifdef 
>>>>>>> SUPPORTS_CLOCK_MONOTONIC
>>>>>>> block.
>>>>>>
>>>>>> Oops missed that. Surprised the declarations in the .hpp file 
>>>>>> don't also
>>>>>> need to be in #ifndef SOLARIS.
>>>>>>
>>>>>>> Done tests:
>>>>>>> build: linux-x86_64-{server, minimal, zero}-{fastdebug, release},
>>>>>>> solaris-x86_64-server-release
>>>>>>> jtreg: linux-x86_64-server-release: hotspot:tier1
>>>>>>>
>>>>>>> I am doing other tests. Seems good so far.
>>>>>>
>>>>>> Please run through the submit repo if you can.
>>>>>>
>>>>>
>>>>> I am afraid I cannot, because I am not a Committer. Maybe I need some
>>>>> Committer to help me to run the tests. Could someone help?
>>>>>
>>>>> Thanks,
>>>>> Ao Qi
>>>>>
>>>>>> Thanks,
>>>>>> David
>>>>>>
>>>>>>> Thanks,
>>>>>>> Ao Qi
>>>>>>>
>>>>>>> On Tue, Mar 5, 2019 at 10:45 AM David Holmes
>>>>>>> <david.holmes at oracle.com> wrote:
>>>>>>>>
>>>>>>>> On 5/03/2019 12:22 pm, Ao Qi wrote:
>>>>>>>>>
>>>>>>>>>
>>>>>>>>> David Holmes <david.holmes at oracle.com
>>>>>>>>> <mailto:david.holmes at oracle.com>>
>>>>>>>>> 于2019年3月1日 周五下午12:18写道:
>>>>>>>>>
>>>>>>>>>        Hi,
>>>>>>>>>
>>>>>>>>>        On 28/02/2019 9:01 pm, Ao Qi wrote:
>>>>>>>>>         > Hi,
>>>>>>>>>         >
>>>>>>>>>         > This version is more consolidated than my first version
>>>>>>>>> in this
>>>>>>>>>         > thread:
>>>>>>>>> http://cr.openjdk.java.net/~aoqi/8170639/webrev.01/. I filed
>>>>>>>>>         > my first version here:
>>>>>>>>>         > http://cr.openjdk.java.net/~aoqi/8170639/webrev.00/
>>>>>>>>>         >
>>>>>>>>>         > I fixed the linux and bsd using sigset_t, so jsig is 
>>>>>>>>> not
>>>>>>>>> limited to a
>>>>>>>>>         > maximum of 64 signals for linux and bsd. The logic 
>>>>>>>>> of aix
>>>>>>>>> and solaris
>>>>>>>>>         > is not changed.
>>>>>>>>>
>>>>>>>>>        Thanks for doing this. Overall this is a much better 
>>>>>>>>> approach.
>>>>>>>>>
>>>>>>>>>        I have two requests.
>>>>>>>>>
>>>>>>>>>        There are too many ifdefs for solaris in the os_posix.cpp
>>>>>>>>> code. I
>>>>>>>>>        hadn't
>>>>>>>>>        realized the difference between Solaris and the other *NIX
>>>>>>>>> platforms in
>>>>>>>>>        this area (allowing for real-time signal chaining). Please
>>>>>>>>> restore the
>>>>>>>>>        Solaris code and put one ifndef solaris around the new 
>>>>>>>>> code is
>>>>>>>>>        os_posix.[ch]pp.
>>>>>>>>>
>>>>>>>>>
>>>>>>>>> Hi David,
>>>>>>>>>
>>>>>>>>> Thanks for your review and advice.
>>>>>>>>>
>>>>>>>>> I think the best way is to eliminate ifdefs for solaris, but as
>>>>>>>>> you said
>>>>>>>>> in a previous email [1]: "SIGRTMAX is a macro not a constant 
>>>>>>>>> so you
>>>>>>>>> can't declare a static array  using it. You would need to 
>>>>>>>>> malloc the
>>>>>>>>> array as done on Solaris." So I have to use ifdefs for 
>>>>>>>>> solaris, I did
>>>>>>>>> not find a way to eliminate it. I have used one ifndef solaris 
>>>>>>>>> as you
>>>>>>>>> request.
>>>>>>>>
>>>>>>>> What I was suggesting was to leave os_solaris.cpp alone 
>>>>>>>> completely for
>>>>>>>> this change, and have the new os_posix.* functions defined in an
>>>>>>>> "#ifndef SOLARIS" block.
>>>>>>>>
>>>>>>>> Thanks,
>>>>>>>> David
>>>>>>>>
>>>>>>>> PS. I will be away for a few days after today.
>>>>>>>>
>>>>>>>>>        There's no need for a separate os::posix::init_sigs() API,
>>>>>>>>> just do the
>>>>>>>>>        signal set initialization in os::posix::init_2();
>>>>>>>>>
>>>>>>>>>
>>>>>>>>> I have done it.
>>>>>>>>>
>>>>>>>>> Webrev: http://cr.openjdk.java.net/~aoqi/8170639/webrev.02/
>>>>>>>>>
>>>>>>>>> Tested:
>>>>>>>>> build tests
>>>>>>>>>       linux-x86_64-minimal-fastdebug
>>>>>>>>>       linux-x86_64-zero-fastdebug
>>>>>>>>>       linux-x86_64-server-fastdebug
>>>>>>>>>       linux-x86_64-minimal-release
>>>>>>>>>       linux-x86_64-zero-release
>>>>>>>>>       linux-x86_64-server-release
>>>>>>>>>       solaris-x86_64-server-release
>>>>>>>>>       solaris-x86_64-server-fastdebug
>>>>>>>>>       linux-mips64el-zero-release
>>>>>>>>>       linux-mips64el-zero-fastdebug
>>>>>>>>>
>>>>>>>>> jtreg tests
>>>>>>>>>       linux-x86_64-server-release: tier1,
>>>>>>>>> hotspot-tier1(JAVA_OPTIONS=-XX:-UseSignalChaining),
>>>>>>>>> hotspot-tier1(JAVA_OPTIONS=-XX:+AllowUserSignalHandlers)
>>>>>>>>>       solaris-x86_64-server-release: hotspot-tier1,
>>>>>>>>> hotspot-tier1(JAVA_OPTIONS=-XX:-UseSignalChaining)
>>>>>>>>>
>>>>>>>>> Thanks,
>>>>>>>>> Ao Qi
>>>>>>>>>
>>>>>>>>> [1]
>>>>>>>>> https://mail.openjdk.java.net/pipermail/hotspot-runtime-dev/2018-March/027219.html 
>>>>>>>>>
>>>>>>>>>
>>>>>>>>>
>>>>>>>>>
>>>>>>>>>        Thanks,
>>>>>>>>>        David
>>>>>>>>>        -----
>>>>>>>>>
>>>>>>>>>         > The tests I did:
>>>>>>>>>         >
>>>>>>>>>         > build tests:
>>>>>>>>>         > linux-x86_64-server-release
>>>>>>>>>         > linux-x86_64-server-fastdebug
>>>>>>>>>         > linux-x86_64-zero-release
>>>>>>>>>         > linux-x86_64-zero-fastdebug
>>>>>>>>>         > linux-x86_64-minimal-release
>>>>>>>>>         > linux-x86_64-minimal-fastdebug
>>>>>>>>>         > solaris-x86_64-server-release
>>>>>>>>>         > solaris-x86_64-server-fastdebug
>>>>>>>>>         > linux-mips64el-zero-release
>>>>>>>>>         > linux-mips64el-zero-fastdebug
>>>>>>>>>         >
>>>>>>>>>         > jtreg tests:
>>>>>>>>>         > linux-x86_64-server-release: tier1, tier2, tier3
>>>>>>>>>         > linux-x86_64-server-fastdebug: tier1
>>>>>>>>>         > solaris-x86_64-server-release: hotspot-tier1
>>>>>>>>>         >
>>>>>>>>>         > No regression was found. Could you please review this
>>>>>>>>> version?
>>>>>>>>>         >
>>>>>>>>>         > On Fri, Jan 25, 2019 at 10:56 PM Magnus Ihse Bursie
>>>>>>>>>         > <magnus.ihse.bursie at oracle.com
>>>>>>>>> <mailto:magnus.ihse.bursie at oracle.com>> wrote:
>>>>>>>>>         >>
>>>>>>>>>         >> On 2018-12-18 01:33, David Holmes wrote:
>>>>>>>>>         >>> On 18/12/2018 9:57 am, Ao Qi wrote:
>>>>>>>>>         >>>> Hi,
>>>>>>>>>         >>>>
>>>>>>>>>         >>>> On Tue, Dec 18, 2018 at 4:32 AM David Holmes
>>>>>>>>>         >>>> <david.holmes at oracle.com
>>>>>>>>> <mailto:david.holmes at oracle.com>> wrote:
>>>>>>>>>         >>>>>
>>>>>>>>>         >>>>> On 17/12/2018 9:48 pm, Ao Qi wrote:
>>>>>>>>>         >>>>>> Hi David Holmes,
>>>>>>>>>         >>>>>>
>>>>>>>>>         >>>>>> Thanks for your reply. It makes sense. Is it
>>>>>>>>> possible to create
>>>>>>>>>         >>>>>> another bug ID to fix the problem?
>>>>>>>>>         >>>>>
>>>>>>>>>         >>>>> I'd prefer to see this fixed properly than point
>>>>>>>>> fixed on
>>>>>>>>>        linux for an
>>>>>>>>>         >>>>> unsupported platform.
>>>>>>>>>         >>>>
>>>>>>>>>         >>>> I thought the problem is "[Linux] jsig is limited 
>>>>>>>>> to a
>>>>>>>>> maximum
>>>>>>>>>        of 64
>>>>>>>>>         >>>> signals" and the patch was intended to fixed this
>>>>>>>>> problem. It just
>>>>>>>>>         >>>> didn't use "A better solution", but I think it is
>>>>>>>>> better than the
>>>>>>>>>         >>>> current situation.
>>>>>>>>>         >>>
>>>>>>>>>         >>> Better for you but I would prefer to see an 
>>>>>>>>> overall better
>>>>>>>>>        solution.
>>>>>>>>>         >>> It really shouldn't be very difficult. Compare the 
>>>>>>>>> AIX
>>>>>>>>> version with
>>>>>>>>>         >>> your improved Linux version, reconcile any 
>>>>>>>>> differences,
>>>>>>>>> and
>>>>>>>>>        make it a
>>>>>>>>>         >>> shared posix version, then confirm it works on OS 
>>>>>>>>> X and
>>>>>>>>> Solaris.
>>>>>>>>>         >>>
>>>>>>>>>         >>>> Is zero/mips (or all platforms having more than 64
>>>>>>>>> signals) a
>>>>>>>>>         >>>> unsupported platform?
>>>>>>>>>         >>>
>>>>>>>>>         >>> Yes. We make allowances for Zero as it can support a
>>>>>>>>> vast range of
>>>>>>>>>         >>> platforms for which no native OpenJDK port exists (in
>>>>>>>>> the case
>>>>>>>>>        of MIPS
>>>>>>>>>         >>> that port seems inactive), but in general we don't go
>>>>>>>>> out of
>>>>>>>>>        our way
>>>>>>>>>         >>> to make changes in the main code that only benefit 
>>>>>>>>> such
>>>>>>>>> platforms.
>>>>>>>>>         >>>
>>>>>>>>>         >>> I'm subtly trying to coerce you into making the 
>>>>>>>>> change
>>>>>>>>> I'd like
>>>>>>>>>        to see
>>>>>>>>>         >>> here. ;-) I can assist with build/test on other POSIX
>>>>>>>>> platforms.
>>>>>>>>>         >> If you are going down that route, I recommend 
>>>>>>>>> looking at
>>>>>>>>>         >> src/java.base/unix/native/libjsig/jsig.c for
>>>>>>>>> inspiration. It was
>>>>>>>>>         >> recently unified across all unix platforms we 
>>>>>>>>> currently
>>>>>>>>> support,
>>>>>>>>>        so any
>>>>>>>>>         >> special treatment there for a specific platform (I 
>>>>>>>>> think
>>>>>>>>>        solaris, macosx
>>>>>>>>>         >> and aix have some special stuff going on), is 
>>>>>>>>> likely to
>>>>>>>>> apply to the
>>>>>>>>>         >> signal handling inside the VM as well. On the other
>>>>>>>>> hand, general
>>>>>>>>>         >> solutions that worked in jsig.c is likely to work as
>>>>>>>>> well in the VM.
>>>>>>>>>         >>
>>>>>>>>>         >
>>>>>>>>>         > Hi Magnus,
>>>>>>>>>         >
>>>>>>>>>         > Thanks for you information and advise. That is very 
>>>>>>>>> helpful.
>>>>>>>>>         > Difference between
>>>>>>>>> hotspot/os/${os_name}/os_${os_name}.cpp is much
>>>>>>>>>         > more than the difference between
>>>>>>>>> ${os_name}/native/libjsig/jsig.c, so
>>>>>>>>>         > it is difficult to unify all the jsig related codes 
>>>>>>>>> into
>>>>>>>>> os_posix.hpp
>>>>>>>>>         > and os_posix.cpp. Maybe I would try to do it in another
>>>>>>>>> issue.
>>>>>>>>>         >
>>>>>>>>>         > Cheers,
>>>>>>>>>         > Ao Qi
>>>>>>>>>         >
>>>>>>>>>         >> /Magnus
>>>>>>>>>         >>>
>>>>>>>>>         >>> Cheers,
>>>>>>>>>         >>> David
>>>>>>>>>         >>>
>>>>>>>>>         >>>> Cheers,
>>>>>>>>>         >>>> Ao Qi
>>>>>>>>>         >>>>>
>>>>>>>>>         >>>>> Thanks,
>>>>>>>>>         >>>>> David
>>>>>>>>>         >>>>>
>>>>>>>>>         >>>>>> Cheers,
>>>>>>>>>         >>>>>> Ao Qi
>>>>>>>>>         >>>>>>
>>>>>>>>>         >>>>>> On Mon, Dec 17, 2018 at 7:30 PM David Holmes
>>>>>>>>>         >>>>>> <david.holmes at oracle.com
>>>>>>>>> <mailto:david.holmes at oracle.com>>
>>>>>>>>>        wrote:
>>>>>>>>>         >>>>>>>
>>>>>>>>>         >>>>>>> Thanks for reminding me about the rest of the
>>>>>>>>> discussion. The
>>>>>>>>>         >>>>>>> point of
>>>>>>>>>         >>>>>>> the RFE I filed was to examine if we could get a
>>>>>>>>>        consolidated POSIX
>>>>>>>>>         >>>>>>> version using sigset_t. I'd rather see that 
>>>>>>>>> than a
>>>>>>>>> point
>>>>>>>>>        fix for
>>>>>>>>>         >>>>>>> Linux.
>>>>>>>>>         >>>>>>>
>>>>>>>>>         >>>>>>> Thanks,
>>>>>>>>>         >>>>>>> David
>>>>>>>>>         >>>>>>>
>>>>>>>>>         >>>>>>> On 17/12/2018 6:50 pm, Ao Qi wrote:
>>>>>>>>>         >>>>>>>> Hi David Holmes,
>>>>>>>>>         >>>>>>>>
>>>>>>>>>         >>>>>>>> I am not sure what is the specific issue of 
>>>>>>>>> "NSIG
>>>>>>>>> not being
>>>>>>>>>         >>>>>>>> defined".
>>>>>>>>>         >>>>>>>> Do you mean the issue mentioned in "but I found
>>>>>>>>> that NSIG was
>>>>>>>>>         >>>>>>>> missing
>>>>>>>>>         >>>>>>>> from signal.h on some architectures, mips 
>>>>>>>>> being among
>>>>>>>>>        them"[1]? If
>>>>>>>>>         >>>>>>>> yes, James Cowgill answered this in [2]. I check
>>>>>>>>> it on
>>>>>>>>>        MIPS, NSIG is
>>>>>>>>>         >>>>>>>> defined in signal.h and it is 128.
>>>>>>>>>         >>>>>>>>
>>>>>>>>>         >>>>>>>> Cheers,
>>>>>>>>>         >>>>>>>> Ao Qi
>>>>>>>>>         >>>>>>>>
>>>>>>>>>         >>>>>>>> [1]
>>>>>>>>>         >>>>>>>>
>>>>>>>>>
>>>>>>>>> http://mail.openjdk.java.net/pipermail/hotspot-dev/2016-November/025401.html 
>>>>>>>>>
>>>>>>>>>
>>>>>>>>>         >>>>>>>> [2]
>>>>>>>>>         >>>>>>>>
>>>>>>>>>
>>>>>>>>> http://mail.openjdk.java.net/pipermail/hotspot-dev/2016-December/025416.html 
>>>>>>>>>
>>>>>>>>>
>>>>>>>>>         >>>>>>>>
>>>>>>>>>         >>>>>>>> On Mon, Dec 17, 2018 at 8:02 AM David Holmes
>>>>>>>>>         >>>>>>>> <david.holmes at oracle.com
>>>>>>>>> <mailto:david.holmes at oracle.com>>
>>>>>>>>>        wrote:
>>>>>>>>>         >>>>>>>>>
>>>>>>>>>         >>>>>>>>> Hi,
>>>>>>>>>         >>>>>>>>>
>>>>>>>>>         >>>>>>>>> Was the issue of NSIG not being defined 
>>>>>>>>> resolved?
>>>>>>>>>         >>>>>>>>>
>>>>>>>>>         >>>>>>>>> Thanks,
>>>>>>>>>         >>>>>>>>> David
>>>>>>>>>         >>>>>>>>>
>>>>>>>>>         >>>>>>>>> On 14/12/2018 10:23 pm, Ao Qi wrote:
>>>>>>>>>         >>>>>>>>>> Hi all,
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>         >>>>>>>>>> Zero does not build on Linux MIPS (actually 
>>>>>>>>> all
>>>>>>>>> Linux of
>>>>>>>>>        NSIG >
>>>>>>>>>         >>>>>>>>>> 64)
>>>>>>>>>         >>>>>>>>>> since OpenJDK 9, because NISG is 128 on 
>>>>>>>>> MIPS and
>>>>>>>>> can not be
>>>>>>>>>         >>>>>>>>>> encoded in
>>>>>>>>>         >>>>>>>>>> uint64_t sigs. James Cowgill from Debian tried
>>>>>>>>> to push a
>>>>>>>>>        patch
>>>>>>>>>         >>>>>>>>>> fixing
>>>>>>>>>         >>>>>>>>>> this[1] but it seems he failed. I would 
>>>>>>>>> like to
>>>>>>>>> try again to
>>>>>>>>>         >>>>>>>>>> request
>>>>>>>>>         >>>>>>>>>> fixing this in
>>>>>>>>> http://hg.openjdk.java.net/jdk/jdk. This was
>>>>>>>>>         >>>>>>>>>> fixed in
>>>>>>>>>         >>>>>>>>>> AIX implementation.
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>         >>>>>>>>>> After applying this patch, zero can be 
>>>>>>>>> built on
>>>>>>>>> MIPS (Debian
>>>>>>>>>         >>>>>>>>>> testing).
>>>>>>>>>         >>>>>>>>>> I've run the jtreg tests [2] on x86 Linux.
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>         >>>>>>>>>> [1]
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>
>>>>>>>>> http://mail.openjdk.java.net/pipermail/hotspot-dev/2016-November/025399.html 
>>>>>>>>>
>>>>>>>>>
>>>>>>>>>         >>>>>>>>>> [2]
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>
>>>>>>>>> https://download.java.net/openjdk/testresults/12/docs/howtoruntests.html 
>>>>>>>>>
>>>>>>>>>
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>         >>>>>>>>>> Cheers,
>>>>>>>>>         >>>>>>>>>> Ao Qi
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>         >>>>>>>>>> $ hg export -r 52869
>>>>>>>>>         >>>>>>>>>> # HG changeset patch
>>>>>>>>>         >>>>>>>>>> # User aoqi
>>>>>>>>>         >>>>>>>>>> # Date 1544089853 0
>>>>>>>>>         >>>>>>>>>> #      Thu Dec 06 09:50:53 2018 +0000
>>>>>>>>>         >>>>>>>>>> # Node ID 
>>>>>>>>> 3eea22b79dc3a4bf26616bde1acb587e3f56e6fe
>>>>>>>>>         >>>>>>>>>> # Parent  
>>>>>>>>> b4982a22926b4ddf1a7b1f770e4d42ce8c1dd575
>>>>>>>>>         >>>>>>>>>> 8170639: [Linux] jsig is limited to a 
>>>>>>>>> maximum of
>>>>>>>>> 64 signals
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>         >>>>>>>>>> diff -r b4982a22926b -r 3eea22b79dc3
>>>>>>>>>         >>>>>>>>>> src/hotspot/os/linux/os_linux.cpp
>>>>>>>>>         >>>>>>>>>> --- a/src/hotspot/os/linux/os_linux.cpp Thu 
>>>>>>>>> Dec
>>>>>>>>> 06 11:54:39
>>>>>>>>>         >>>>>>>>>> 2018 +0530
>>>>>>>>>         >>>>>>>>>> +++ b/src/hotspot/os/linux/os_linux.cpp Thu 
>>>>>>>>> Dec
>>>>>>>>> 06 09:50:53
>>>>>>>>>         >>>>>>>>>> 2018 +0000
>>>>>>>>>         >>>>>>>>>> @@ -4434,10 +4434,7 @@
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>> >>>>>>>>>>       // For signal-chaining
>>>>>>>>> >>>>>>>>>> struct sigaction sigact[NSIG];
>>>>>>>>>         >>>>>>>>>> -uint64_t sigs = 0;
>>>>>>>>>         >>>>>>>>>> -#if (64 < NSIG-1)
>>>>>>>>>         >>>>>>>>>> -#error "Not all signals can be encoded in 
>>>>>>>>> sigs.
>>>>>>>>> Adapt
>>>>>>>>>        its type!"
>>>>>>>>>         >>>>>>>>>> -#endif
>>>>>>>>>         >>>>>>>>>> +sigset_t sigs;
>>>>>>>>> >>>>>>>>>> bool os::Linux::libjsig_is_loaded = false;
>>>>>>>>> >>>>>>>>>> typedef struct sigaction
>>>>>>>>> *(*get_signal_t)(int);
>>>>>>>>> >>>>>>>>>> get_signal_t os::Linux::get_signal_action
>>>>>>>>> = NULL;
>>>>>>>>>         >>>>>>>>>> @@ -4516,7 +4513,7 @@
>>>>>>>>> >>>>>>>>>>       }
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>> >>>>>>>>>> struct sigaction*
>>>>>>>>>        os::Linux::get_preinstalled_handler(int
>>>>>>>>>         >>>>>>>>>> sig) {
>>>>>>>>>         >>>>>>>>>> -  if ((((uint64_t)1 << (sig-1)) & sigs) != 
>>>>>>>>> 0) {
>>>>>>>>>         >>>>>>>>>> +  if (sigismember(&sigs, sig)) {
>>>>>>>>> >>>>>>>>>> return &sigact[sig];
>>>>>>>>> >>>>>>>>>>         }
>>>>>>>>> >>>>>>>>>> return NULL;
>>>>>>>>>         >>>>>>>>>> @@ -4525,7 +4522,7 @@
>>>>>>>>> >>>>>>>>>> void
>>>>>>>>> os::Linux::save_preinstalled_handler(int sig,
>>>>>>>>>        struct
>>>>>>>>>         >>>>>>>>>> sigaction& oldAct) {
>>>>>>>>> >>>>>>>>>> assert(sig > 0 && sig < NSIG, "vm signal
>>>>>>>>> out of
>>>>>>>>>        expected
>>>>>>>>>         >>>>>>>>>> range");
>>>>>>>>> >>>>>>>>>> sigact[sig] = oldAct;
>>>>>>>>>         >>>>>>>>>> -  sigs |= (uint64_t)1 << (sig-1);
>>>>>>>>>         >>>>>>>>>> +  sigaddset(&sigs, sig);
>>>>>>>>> >>>>>>>>>>       }
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>> >>>>>>>>>>       // for diagnostic
>>>>>>>>>         >>>>>>>>>> @@ -4616,6 +4613,7 @@
>>>>>>>>> >>>>>>>>>> (*begin_signal_setting)();
>>>>>>>>> >>>>>>>>>> }
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>         >>>>>>>>>> +    ::sigemptyset(&sigs);
>>>>>>>>> >>>>>>>>>> set_signal_handler(SIGSEGV, true);
>>>>>>>>> >>>>>>>>>> set_signal_handler(SIGPIPE, true);
>>>>>>>>> >>>>>>>>>> set_signal_handler(SIGBUS, true);
>>>>>>>>>         >>>>>>>>>>
>>>>>>>>>         >>
>>>>>>>>>



More information about the hotspot-runtime-dev mailing list