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: #19680
Related: #20354

Signed-off-by: Babneet Singh <[email protected]>
  • Loading branch information
babsingh committed Dec 9, 2024
1 parent 5231fac commit d681f6b
Showing 1 changed file with 25 additions and 4 deletions.
29 changes: 25 additions & 4 deletions jcl/src/java.base/share/classes/java/lang/System.java
Original file line number Diff line number Diff line change
Expand Up @@ -1115,13 +1115,25 @@ public static int identityHashCode(Object anObject) {
/**
* Loads the specified file as a dynamic library.
*
* @param pathName the path of the file to be loaded
* @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 All @@ -1146,16 +1158,25 @@ public static void load(String pathName) {
/**
* Loads and links the library specified by the argument.
*
* @param libName the name of the library to load
* @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 UnsatisfiedLinkError if the library could not 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 d681f6b

Please sign in to comment.