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

Ao Qi aoqi at loongson.cn
Wed Mar 13 09:01:00 UTC 2019


Thanks loi and David. zero can be built on MIPS finally:)

Thanks,
Ao Qi


On Wed, Mar 13, 2019 at 12:43 PM David Holmes <david.holmes at oracle.com> wrote:
>
> On 13/03/2019 12:19 pm, Ioi Lam wrote:
> > I reviewed this version.
> >
> > http://cr.openjdk.java.net/~aoqi/8170639/webrev.03
>
> Thanks Ioi.
>
> > 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.
>
> I tested mach5 tier 1 - 3, default platforms.
>
> I will sponsor this change.
>
> Thanks,
> David
>
> > 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