<AWT Dev> RFR 8248532:Every time I change keyboard language at my MacBook, Java crashes

Prasanta Sadhukhan prasanta.sadhukhan at oracle.com
Mon Aug 31 12:26:50 UTC 2020


Hi All,

Please review a fix for an issue in jdk/client where it is seen that 
everytime the keyboard language is changed in macos, it results in crash 
in mucommander app

The crash log shows

6 libjvm.dylib 0x000000010b88d44b signalHandler(int, __siginfo*, void*) 
+ 47
7 libsystem_platform.dylib 0x00007fff62a83b5d _sigtramp + 29
8 ??? 0x0000000000000004 0 + 4
9 com.apple.CoreFoundation 0x00007fff3696e1a0 
___CFXRegistrationPost_block_invoke + 63
10 com.apple.CoreFoundation 0x00007fff3696e10a _CFXRegistrationPost + 404
11 com.apple.CoreFoundation 0x00007fff369765b8 
___CFXNotificationPost_block_invoke + 87
12 com.apple.CoreFoundation 0x00007fff368def44 
-[_CFXNotificationRegistrar find:object:observer:enumerator:] + 1642
13 com.apple.CoreFoundation 0x00007fff368de2f7 _CFXNotificationPost + 732
14 com.apple.Foundation 0x00007fff38b66a2b -[NSNotificationCenter 
postNotificationName:object:userInfo:] + 66
15 com.apple.CoreFoundation 0x00007fff3696e226 
__CFNOTIFICATIONCENTER_IS_CALLING_OUT_TO_AN_OBSERVER__ + 12

The crash seems to happen when Java is bundled with the app and

does not happen if Java is run with Java launcher.

This seems to be an after-effect of JDK-8214578 fix where NSNotification 
code is added to detect change of keyboard layout.

Proposed fix is to use NSDistributedNotificationCenter for the 
notification handler.

>From 
https://developer.apple.com/library/archive/documentation/Cocoa/Conceptual/Notifications/Articles/NotificationCenters.html

it is seen that "NSNotificationCenter" This notification center handles 
notifications within a single process

whereas "NSDistributedNotificationCenter" This distributed notification 
center handles notifications that can be sent between processes on a 
single machine.

Since, the app is bundled with Java, notifications needed to handled 
between different processes in such case.

It is confirmed to have fixed the crash by this fix.

8214578testcase, SwingSet2 and other client jtreg headful tests with JCK 
tests has passed (link in JBS)

Bug: https://bugs.openjdk.java.net/browse/JDK-8248532

webrev: http://cr.openjdk.java.net/~psadhukhan/8248532/webrev.0/

Regards

Prasanta



More information about the awt-dev mailing list