<AWT Dev> [16] RFR 8232114: JVM crashed at imjpapi.dll in native code
Dmitry Markov
dmitry.markov at oracle.com
Tue Aug 11 08:07:13 UTC 2020
Hello,
Could you review the fix for JDK 16, please?
bug: https://bugs.openjdk.java.net/browse/JDK-8232114 <https://bugs.openjdk.java.net/browse/JDK-8232114>
webrev: http://cr.openjdk.java.net/~dmarkov/8232114/webrev.00/ <http://cr.openjdk.java.net/~dmarkov/8232114/webrev.00/>
Problem description:
The root cause of the crash is the lack of synchronisation in imjpapi.dll. In particular when IME messages are processed in the message loop and another message triggered through a SendMessage() call, this clears the buffer context so on further processing the message loop in IME context will point to invalid memory buffer. Microsoft article devoted to this issue: https://docs.microsoft.com/en-us/troubleshoot/windows/win32/ime-crash-processing-cross-thread-sent-message <https://docs.microsoft.com/en-us/troubleshoot/windows/win32/ime-crash-processing-cross-thread-sent-message>
Fix:
Replace SendMessage() with PostMessage() for IME messages and implement event based mechanism to notify the sender that the message processing is completed.
Testing:
mach5 client tests (jtreg headful, jck, etc.) are green.
Regards,
Dmitry
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mail.openjdk.java.net/pipermail/awt-dev/attachments/20200811/b98b714a/attachment.htm>
More information about the awt-dev
mailing list