Skip to content

Commit

Permalink
[JDK24] Add native access checks in System.load/loadLibrary
Browse files Browse the repository at this point in the history
Add native access checks in System.load/loadLibrary to comply with
JEP472 (Prepare to Restrict the Use of JNI).

Related: eclipse-openj9#19680
Related: eclipse-openj9#20354

Signed-off-by: Babneet Singh <[email protected]>
  • Loading branch information
babsingh committed Dec 9, 2024
1 parent 5231fac commit 3457eb8
Showing 1 changed file with 22 additions and 1 deletion.
23 changes: 22 additions & 1 deletion jcl/src/java.base/share/classes/java/lang/System.java
Original file line number Diff line number Diff line change
Expand Up @@ -1116,12 +1116,24 @@ public static int identityHashCode(Object anObject) {
* Loads the specified file as a dynamic library.
*
* @param pathName the path of the file to be loaded
*
* @throws UnsatisfiedLinkError if the library could not be loaded
* @throws SecurityException if the library was not allowed to be loaded
* @throws NullPointerException if pathName is null
/*[IF JAVA_SPEC_VERSION >= 24]
* @throws IllegalCallerException if the caller belongs to a module where native access is not enabled
/*[ENDIF] JAVA_SPEC_VERSION >= 24
*/
@CallerSensitive
/*[IF JAVA_SPEC_VERSION >= 24]*/
@Restricted
/*[ENDIF] JAVA_SPEC_VERSION >= 24 */
public static void load(String pathName) {
/*[IF JAVA_SPEC_VERSION >= 24]*/
Class<?> caller = Reflection.getCallerClass();
Reflection.ensureNativeAccess(caller, System.class, "load", false);
/*[ENDIF] JAVA_SPEC_VERSION >= 24 */

@SuppressWarnings("removal")
SecurityManager smngr = System.getSecurityManager();
if (smngr != null) {
Expand Down Expand Up @@ -1149,13 +1161,22 @@ public static void load(String pathName) {
* @param libName the name of the library to load
*
* @throws UnsatisfiedLinkError if the library could not be loaded
* @throws SecurityException if the library was not allowed to be loaded
* @throws SecurityException if the library was not allowed to be loaded
* @throws NullPointerException if libName is null
/*[IF JAVA_SPEC_VERSION >= 24]
* @throws IllegalCallerException if the caller belongs to a module where native access is not enabled
/*[ENDIF] JAVA_SPEC_VERSION >= 24
*/
@CallerSensitive
/*[IF JAVA_SPEC_VERSION >= 24]*/
@Restricted
/*[ENDIF] JAVA_SPEC_VERSION >= 24 */
public static void loadLibrary(String libName) {
/*[IF JAVA_SPEC_VERSION >= 24]*/
Class<?> caller = Reflection.getCallerClass();
Reflection.ensureNativeAccess(caller, System.class, "loadLibrary", false);
/*[ENDIF] JAVA_SPEC_VERSION >= 24 */

if (libName.indexOf(File.pathSeparator) >= 0) {
/*[MSG "K0B01", "Library name must not contain a file path: {0}"]*/
throw new UnsatisfiedLinkError(Msg.getString("K0B01", libName)); //$NON-NLS-1$
Expand Down

0 comments on commit 3457eb8

Please sign in to comment.