From 312d66471ace8b5e4a46dbcc2a12633c6d27e2ea Mon Sep 17 00:00:00 2001 From: Phil Race Date: Thu, 30 May 2019 11:52:23 -0700 Subject: [PATCH] 8223271: SplashScreen is still shown if defaulting to headless on MacOS Reviewed-by: bpb, serb, kcr --- make/lib/Awt2dLibraries.gmk | 1 + src/java.base/share/native/libjli/java.c | 14 +++++++--- .../share/native/libjli/splashscreen.h | 2 +- .../share/native/libjli/splashscreen_stubs.c | 6 ++--- .../native/libsplashscreen/splashscreen_sys.m | 27 ++++++++++++++++++- .../libsplashscreen/splashscreen_impl.c | 5 ++-- .../libsplashscreen/splashscreen_impl.h | 4 +-- .../native/libsplashscreen/splashscreen_sys.c | 7 ++--- .../native/libsplashscreen/splashscreen_sys.c | 3 ++- 9 files changed, 52 insertions(+), 17 deletions(-) diff --git a/make/lib/Awt2dLibraries.gmk b/make/lib/Awt2dLibraries.gmk index 11c9eb70b04..54731ad7ffd 100644 --- a/make/lib/Awt2dLibraries.gmk +++ b/make/lib/Awt2dLibraries.gmk @@ -824,6 +824,7 @@ ifeq ($(ENABLE_HEADLESS_ONLY), false) $(LIBM) -lpthread -liconv -losxapp \ -framework ApplicationServices \ -framework Foundation \ + -framework Security \ -framework Cocoa \ -framework JavaNativeFoundation else ifeq ($(call isTargetOs, windows), true) diff --git a/src/java.base/share/native/libjli/java.c b/src/java.base/share/native/libjli/java.c index 4e1abf8d205..48ba994271c 100644 --- a/src/java.base/share/native/libjli/java.c +++ b/src/java.base/share/native/libjli/java.c @@ -1169,13 +1169,13 @@ SelectVersion(int argc, char **argv, char **main_class) * Passing on splash screen info in environment variables */ if (splash_file_name && !headlessflag) { - char* splash_file_entry = JLI_MemAlloc(JLI_StrLen(SPLASH_FILE_ENV_ENTRY "=")+JLI_StrLen(splash_file_name)+1); + splash_file_entry = JLI_MemAlloc(JLI_StrLen(SPLASH_FILE_ENV_ENTRY "=")+JLI_StrLen(splash_file_name)+1); JLI_StrCpy(splash_file_entry, SPLASH_FILE_ENV_ENTRY "="); JLI_StrCat(splash_file_entry, splash_file_name); putenv(splash_file_entry); } if (splash_jar_name && !headlessflag) { - char* splash_jar_entry = JLI_MemAlloc(JLI_StrLen(SPLASH_JAR_ENV_ENTRY "=")+JLI_StrLen(splash_jar_name)+1); + splash_jar_entry = JLI_MemAlloc(JLI_StrLen(SPLASH_JAR_ENV_ENTRY "=")+JLI_StrLen(splash_jar_name)+1); JLI_StrCpy(splash_jar_entry, SPLASH_JAR_ENV_ENTRY "="); JLI_StrCat(splash_jar_entry, splash_jar_name); putenv(splash_jar_entry); @@ -2241,6 +2241,11 @@ ShowSplashScreen() if (file_name == NULL){ return; } + + if (!DoSplashInit()) { + goto exit; + } + maxScaledImgNameLength = DoSplashGetScaledImgNameMaxPstfixLen(file_name); scaled_splash_name = JLI_MemAlloc( @@ -2261,13 +2266,13 @@ ShowSplashScreen() jar_name, file_name, &data_size); } if (image_data) { - DoSplashInit(); DoSplashSetScaleFactor(scale_factor); DoSplashLoadMemory(image_data, data_size); JLI_MemFree(image_data); + } else { + DoSplashClose(); } } else { - DoSplashInit(); if (isImageScaled) { DoSplashSetScaleFactor(scale_factor); DoSplashLoadFile(scaled_splash_name); @@ -2279,6 +2284,7 @@ ShowSplashScreen() DoSplashSetFileJarName(file_name, jar_name); + exit: /* * Done with all command line processing and potential re-execs so * clean up the environment. diff --git a/src/java.base/share/native/libjli/splashscreen.h b/src/java.base/share/native/libjli/splashscreen.h index 5fc296acfb3..ae5d0e632b7 100644 --- a/src/java.base/share/native/libjli/splashscreen.h +++ b/src/java.base/share/native/libjli/splashscreen.h @@ -26,7 +26,7 @@ int DoSplashLoadMemory(void* pdata, int size); /* requires preloading the file */ int DoSplashLoadFile(const char* filename); -void DoSplashInit(void); +int DoSplashInit(void); void DoSplashClose(void); void DoSplashSetFileJarName(const char* fileName, const char* jarName); void DoSplashSetScaleFactor(float scaleFactor); diff --git a/src/java.base/share/native/libjli/splashscreen_stubs.c b/src/java.base/share/native/libjli/splashscreen_stubs.c index 9ae76c95e58..54295833d2c 100644 --- a/src/java.base/share/native/libjli/splashscreen_stubs.c +++ b/src/java.base/share/native/libjli/splashscreen_stubs.c @@ -33,7 +33,7 @@ extern void* SplashProcAddress(const char* name); /* in java_md.c */ */ typedef int (*SplashLoadMemory_t)(void* pdata, int size); typedef int (*SplashLoadFile_t)(const char* filename); -typedef void (*SplashInit_t)(void); +typedef int (*SplashInit_t)(void); typedef void (*SplashClose_t)(void); typedef void (*SplashSetFileJarName_t)(const char* fileName, const char* jarName); @@ -71,8 +71,8 @@ int DoSplashLoadFile(const char* filename) { INVOKE(SplashLoadFile, 0)(filename); } -void DoSplashInit(void) { - INVOKEV(SplashInit)(); +int DoSplashInit(void) { + INVOKE(SplashInit, 0)(); } void DoSplashClose(void) { diff --git a/src/java.desktop/macosx/native/libsplashscreen/splashscreen_sys.m b/src/java.desktop/macosx/native/libsplashscreen/splashscreen_sys.m index ce5ea8b4e11..b8a5a8f0b0f 100644 --- a/src/java.desktop/macosx/native/libsplashscreen/splashscreen_sys.m +++ b/src/java.desktop/macosx/native/libsplashscreen/splashscreen_sys.m @@ -28,6 +28,7 @@ #import #import +#include #import #import "NSApplicationAWT.h" @@ -184,8 +185,31 @@ jboolean SplashGetScaledImageName(const char* jar, const char* file, return JNI_FALSE; } -void +static int isInAquaSession() { + // environment variable to bypass the aqua session check + char *ev = getenv("AWT_FORCE_HEADFUL"); + if (ev && (strncasecmp(ev, "true", 4) == 0)) { + // if "true" then tell the caller we're in + // an Aqua session without actually checking + return 1; + } + // Is the WindowServer available? + SecuritySessionId session_id; + SessionAttributeBits session_info; + OSStatus status = SessionGetInfo(callerSecuritySession, &session_id, &session_info); + if (status == noErr) { + if (session_info & sessionHasGraphicAccess) { + return 1; + } + } + return 0; +} + +int SplashInitPlatform(Splash * splash) { + if (!isInAquaSession()) { + return 0; + } pthread_mutex_init(&splash->lock, NULL); splash->maskRequired = 0; @@ -206,6 +230,7 @@ SplashInitPlatform(Splash * splash) { [NSApplicationAWT runAWTLoopWithApp:[NSApplicationAWT sharedApplication]]; }]; } + return 1; } void diff --git a/src/java.desktop/share/native/libsplashscreen/splashscreen_impl.c b/src/java.desktop/share/native/libsplashscreen/splashscreen_impl.c index e32378e9c91..5891a66d6ac 100644 --- a/src/java.desktop/share/native/libsplashscreen/splashscreen_impl.c +++ b/src/java.desktop/share/native/libsplashscreen/splashscreen_impl.c @@ -57,7 +57,7 @@ SplashSetFileJarName(const char* fileName, const char* jarName) { splash->jarName = SplashConvertStringAlloc(jarName, &splash->jarNameLen); } -JNIEXPORT void +JNIEXPORT int SplashInit() { Splash *splash = SplashGetInstance(); @@ -67,7 +67,7 @@ SplashInit() splash->scaleFactor = 1; initFormat(&splash->imageFormat, QUAD_RED_MASK, QUAD_GREEN_MASK, QUAD_BLUE_MASK, QUAD_ALPHA_MASK); - SplashInitPlatform(splash); + return SplashInitPlatform(splash); } JNIEXPORT void @@ -263,6 +263,7 @@ SplashLoadStream(SplashStream * stream) Splash *splash = SplashGetInstance(); if (splash->isVisible < 0) { + stream->close(stream); return 0; } diff --git a/src/java.desktop/share/native/libsplashscreen/splashscreen_impl.h b/src/java.desktop/share/native/libsplashscreen/splashscreen_impl.h index 007c87b2dbf..d1f8b5564d5 100644 --- a/src/java.desktop/share/native/libsplashscreen/splashscreen_impl.h +++ b/src/java.desktop/share/native/libsplashscreen/splashscreen_impl.h @@ -36,7 +36,7 @@ SplashLoadMemory(void *pdata, int size); /* requires preloading the file */ JNIEXPORT int SplashLoadFile(const char *filename); // FIXME: range checking for SplashLoadMemory -JNIEXPORT void +JNIEXPORT int SplashInit(void); JNIEXPORT void @@ -125,7 +125,7 @@ typedef struct Splash /* To be implemented in the platform-specific native code. */ -void SplashInitPlatform(Splash * splash); +int SplashInitPlatform(Splash * splash); void SplashCreateThread(Splash * splash); void SplashCleanupPlatform(Splash * splash); void SplashDonePlatform(Splash * splash); diff --git a/src/java.desktop/unix/native/libsplashscreen/splashscreen_sys.c b/src/java.desktop/unix/native/libsplashscreen/splashscreen_sys.c index 314f0a3d1f1..d36be69b5c6 100644 --- a/src/java.desktop/unix/native/libsplashscreen/splashscreen_sys.c +++ b/src/java.desktop/unix/native/libsplashscreen/splashscreen_sys.c @@ -405,7 +405,7 @@ HandleIOError(Display * display) { return 0; } -void +int SplashInitPlatform(Splash * splash) { int shapeVersionMajor, shapeVersionMinor; @@ -424,7 +424,7 @@ SplashInitPlatform(Splash * splash) { splash->display = XOpenDisplay(NULL); if (!splash->display) { splash->isVisible = -1; - return; + return 0; } shapeSupported = XShapeQueryExtension(splash->display, &shapeEventBase, @@ -474,7 +474,7 @@ SplashInitPlatform(Splash * splash) { splash->screen = NULL; splash->visual = NULL; fprintf(stderr, "Warning: unable to initialize the splashscreen. Not enough available color cells.\n"); - return; + return 0; } splash->cmap = AllocColors(splash->display, splash->screen, numColors, colorIndex); @@ -506,6 +506,7 @@ SplashInitPlatform(Splash * splash) { default: ; /* FIXME: should probably be fixed, but javaws splash screen doesn't support other visuals either */ } + return 1; } diff --git a/src/java.desktop/windows/native/libsplashscreen/splashscreen_sys.c b/src/java.desktop/windows/native/libsplashscreen/splashscreen_sys.c index 20693fa5e91..688fd533399 100644 --- a/src/java.desktop/windows/native/libsplashscreen/splashscreen_sys.c +++ b/src/java.desktop/windows/native/libsplashscreen/splashscreen_sys.c @@ -437,7 +437,7 @@ SplashUnlock(Splash * splash) LeaveCriticalSection(&splash->lock); } -void +int SplashInitPlatform(Splash * splash) { HDC hdc; @@ -486,6 +486,7 @@ SplashInitPlatform(Splash * splash) } } ReleaseDC(NULL, hdc); + return 1; } void