OpenSSL and panama-foreign
Rémy Maucherat
remm at apache.org
Wed Nov 10 19:09:35 UTC 2021
On Wed, Nov 10, 2021 at 7:19 PM Maurizio Cimadamore
<maurizio.cimadamore at oracle.com> wrote:
>
> I've been able to reproduce, with tomcat and all. Seeing all the crashes
> you are seeing.
>
> After some digging, it seems like the crash does not occur with these
> parameters:
>
> export
> JAVA_OPTS="-Djdk.internal.foreign.ProgrammableUpcallHandler.USE_INTRINSICS=false
> --enable-native-access=ALL-UNNAMED --add-modules jdk.incubator.foreign"
>
> In other words, the intrinsification support for _upcalls_ seems to be
> creating issues here.
>
> Please confirm that this setup works for you.
I can confirm the setting fixes the problem (using the PR, I didn't
switch back to the panama-foreign branch). Great job on catching it !
Rémy
>
> Cheers
> Maurizio
>
>
> On 10/11/2021 17:56, Maurizio Cimadamore wrote:
> >
> >> Ok, quick test then since this is very interesting. It cores (exact
> >> same ones).
> >>
> >> I'll work on all the other items now (thanks for all the homework ;) ).
> >
> > Thanks for testing. This leaves us with two options: some general JDK
> > change which brought some latent issue to the fore, or some specific
> > regression in the linker support. On top of my head the latter doesn't
> > make much sense - since the new panama changes only affect the API,
> > not the VM internals.
> >
> > But I'll keep testing on my end.
> >
> > Maurizio
> >
> >
> >>
> >> Rémy
> >>
> >>> Maurizio
> >>>
> >>> On 10/11/2021 11:20, Rémy Maucherat wrote:
> >>>> In gdb, the debug is:
> >>>>
> >>>> #10 ssl3_shutdown (s=0x0) at ssl/s3_lib.c:4420
> >>>> 4420 if (s->s3->alert_dispatch)
> >>>> (gdb) print s
> >>>> $1 = (SSL *) 0x0
> >>>>
> >>>> With the corresponding source:
> >>>> 4400 int ssl3_shutdown(SSL *s)
> >>>> 4401 {
> >>>> 4402 int ret;
> >>>> 4403
> >>>> 4404 /*
> >>>> 4405 * Don't do anything much if we have not done the
> >>>> handshake or we don't
> >>>> 4406 * want to send messages:-)
> >>>> 4407 */
> >>>> 4408 if (s->quiet_shutdown || SSL_in_before(s)) {
> >>>> 4409 s->shutdown = (SSL_SENT_SHUTDOWN |
> >>>> SSL_RECEIVED_SHUTDOWN);
> >>>> 4410 return 1;
> >>>> 4411 }
> >>>> 4412
> >>>> 4413 if (!(s->shutdown & SSL_SENT_SHUTDOWN)) {
> >>>> 4414 s->shutdown |= SSL_SENT_SHUTDOWN;
> >>>> 4415 ssl3_send_alert(s, SSL3_AL_WARNING,
> >>>> SSL_AD_CLOSE_NOTIFY);
> >>>> 4416 /*
> >>>> 4417 * our shutdown alert has been sent now, and if it
> >>>> still needs to be
> >>>> 4418 * written, s->s3->alert_dispatch will be true
> >>>> 4419 */
> >>>> 4420 if (s->s3->alert_dispatch)
> >>>> 4421 return -1; /* return WANT_WRITE */
> >>>> 4422 } else if (s->s3->alert_dispatch) {
> >>>> 4423 /* resend it if not sent */
> >>>> 4424 ret = s->method->ssl_dispatch_alert(s);
> >>>> 4425 if (ret == -1) {
> >>>> 4426 /*
> >>>> 4427 * we only get to return -1 here the 2nd/Nth
> >>>> invocation, we must
> >>>> 4428 * have already signalled return 0 upon a previous
> >>>> invocation,
> >>>> 4429 * return WANT_WRITE
> >>>> 4430 */
> >>>> 4431 return ret;
> >>>> 4432 }
More information about the panama-dev
mailing list