mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-28 15:24:43 +02:00
7092821: java.security.Provider.getService() is synchronized and became scalability bottleneck
Changed Provider class to use ConcurrentHashMap and default providers to use putService() Reviewed-by: weijun, mullan
This commit is contained in:
parent
f47bd19cbc
commit
0b05ebed2e
8 changed files with 1019 additions and 1152 deletions
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright (c) 2003, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
|
@ -29,7 +29,6 @@ import java.util.*;
|
|||
|
||||
import java.security.*;
|
||||
|
||||
import sun.security.action.PutAllAction;
|
||||
import static sun.security.util.SecurityConstants.PROVIDER_VER;
|
||||
|
||||
/**
|
||||
|
@ -46,17 +45,24 @@ public final class SunRsaSign extends Provider {
|
|||
public SunRsaSign() {
|
||||
super("SunRsaSign", PROVIDER_VER, "Sun RSA signature provider");
|
||||
|
||||
// if there is no security manager installed, put directly into
|
||||
// the provider. Otherwise, create a temporary map and use a
|
||||
// doPrivileged() call at the end to transfer the contents
|
||||
Provider p = this;
|
||||
Iterator<Provider.Service> serviceIter = new SunRsaSignEntries(p).iterator();
|
||||
|
||||
if (System.getSecurityManager() == null) {
|
||||
SunRsaSignEntries.putEntries(this);
|
||||
putEntries(serviceIter);
|
||||
} else {
|
||||
// use LinkedHashMap to preserve the order of the PRNGs
|
||||
Map<Object, Object> map = new HashMap<>();
|
||||
SunRsaSignEntries.putEntries(map);
|
||||
AccessController.doPrivileged(new PutAllAction(this, map));
|
||||
AccessController.doPrivileged(new PrivilegedAction<Void>() {
|
||||
@Override
|
||||
public Void run() {
|
||||
putEntries(serviceIter);
|
||||
return null;
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
void putEntries(Iterator<Provider.Service> i) {
|
||||
while (i.hasNext()) {
|
||||
putService(i.next());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -25,7 +25,9 @@
|
|||
|
||||
package sun.security.rsa;
|
||||
|
||||
import java.util.Map;
|
||||
import java.util.*;
|
||||
import java.security.Provider;
|
||||
import static sun.security.provider.SunEntries.createAliasesWithOid;
|
||||
|
||||
/**
|
||||
* Defines the entries of the SunRsaSign provider.
|
||||
|
@ -34,102 +36,81 @@ import java.util.Map;
|
|||
*/
|
||||
public final class SunRsaSignEntries {
|
||||
|
||||
private SunRsaSignEntries() {
|
||||
// empty
|
||||
private void add(Provider p, String type, String algo, String cn,
|
||||
List<String> aliases, HashMap<String, String> attrs) {
|
||||
services.add(new Provider.Service(p, type, algo, cn, aliases, attrs));
|
||||
}
|
||||
|
||||
public static void putEntries(Map<Object, Object> map) {
|
||||
// extend LinkedHashSet for consistency with SunEntries
|
||||
// used by sun.security.provider.VerificationProvider
|
||||
public SunRsaSignEntries(Provider p) {
|
||||
services = new LinkedHashSet<>(20, 0.9f);
|
||||
|
||||
// main algorithms
|
||||
map.put("KeyFactory.RSA",
|
||||
"sun.security.rsa.RSAKeyFactory$Legacy");
|
||||
map.put("KeyPairGenerator.RSA",
|
||||
"sun.security.rsa.RSAKeyPairGenerator$Legacy");
|
||||
map.put("Signature.MD2withRSA",
|
||||
"sun.security.rsa.RSASignature$MD2withRSA");
|
||||
map.put("Signature.MD5withRSA",
|
||||
"sun.security.rsa.RSASignature$MD5withRSA");
|
||||
map.put("Signature.SHA1withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA1withRSA");
|
||||
map.put("Signature.SHA224withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA224withRSA");
|
||||
map.put("Signature.SHA256withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA256withRSA");
|
||||
map.put("Signature.SHA384withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA384withRSA");
|
||||
map.put("Signature.SHA512withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA512withRSA");
|
||||
map.put("Signature.SHA512/224withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA512_224withRSA");
|
||||
map.put("Signature.SHA512/256withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA512_256withRSA");
|
||||
// start populating content using the specified provider
|
||||
|
||||
map.put("KeyFactory.RSASSA-PSS",
|
||||
"sun.security.rsa.RSAKeyFactory$PSS");
|
||||
map.put("KeyPairGenerator.RSASSA-PSS",
|
||||
"sun.security.rsa.RSAKeyPairGenerator$PSS");
|
||||
map.put("Signature.RSASSA-PSS",
|
||||
"sun.security.rsa.RSAPSSSignature");
|
||||
map.put("AlgorithmParameters.RSASSA-PSS",
|
||||
"sun.security.rsa.PSSParameters");
|
||||
// common oids
|
||||
String rsaOid = "1.2.840.113549.1.1";
|
||||
List<String> rsaAliases = createAliasesWithOid(rsaOid);
|
||||
List<String> rsapssAliases = createAliasesWithOid(rsaOid + ".10");
|
||||
String sha1withRSAOid2 = "1.3.14.3.2.29";
|
||||
|
||||
// attributes for supported key classes
|
||||
String rsaKeyClasses = "java.security.interfaces.RSAPublicKey" +
|
||||
"|java.security.interfaces.RSAPrivateKey";
|
||||
map.put("Signature.MD2withRSA SupportedKeyClasses", rsaKeyClasses);
|
||||
map.put("Signature.MD5withRSA SupportedKeyClasses", rsaKeyClasses);
|
||||
map.put("Signature.SHA1withRSA SupportedKeyClasses", rsaKeyClasses);
|
||||
map.put("Signature.SHA224withRSA SupportedKeyClasses", rsaKeyClasses);
|
||||
map.put("Signature.SHA256withRSA SupportedKeyClasses", rsaKeyClasses);
|
||||
map.put("Signature.SHA384withRSA SupportedKeyClasses", rsaKeyClasses);
|
||||
map.put("Signature.SHA512withRSA SupportedKeyClasses", rsaKeyClasses);
|
||||
map.put("Signature.SHA512/224withRSA SupportedKeyClasses", rsaKeyClasses);
|
||||
map.put("Signature.SHA512/256withRSA SupportedKeyClasses", rsaKeyClasses);
|
||||
map.put("Signature.RSASSA-PSS SupportedKeyClasses", rsaKeyClasses);
|
||||
// common attribute map
|
||||
HashMap<String, String> attrs = new HashMap<>(3);
|
||||
attrs.put("SupportedKeyClasses",
|
||||
"java.security.interfaces.RSAPublicKey" +
|
||||
"|java.security.interfaces.RSAPrivateKey");
|
||||
|
||||
// aliases
|
||||
map.put("Alg.Alias.KeyFactory.1.2.840.113549.1.1", "RSA");
|
||||
map.put("Alg.Alias.KeyFactory.OID.1.2.840.113549.1.1", "RSA");
|
||||
add(p, "KeyFactory", "RSA",
|
||||
"sun.security.rsa.RSAKeyFactory$Legacy",
|
||||
rsaAliases, null);
|
||||
add(p, "KeyPairGenerator", "RSA",
|
||||
"sun.security.rsa.RSAKeyPairGenerator$Legacy",
|
||||
rsaAliases, null);
|
||||
add(p, "Signature", "MD2withRSA",
|
||||
"sun.security.rsa.RSASignature$MD2withRSA",
|
||||
createAliasesWithOid(rsaOid + ".2"), attrs);
|
||||
add(p, "Signature", "MD5withRSA",
|
||||
"sun.security.rsa.RSASignature$MD5withRSA",
|
||||
createAliasesWithOid(rsaOid + ".4"), attrs);
|
||||
add(p, "Signature", "SHA1withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA1withRSA",
|
||||
createAliasesWithOid(rsaOid + ".5", sha1withRSAOid2), attrs);
|
||||
add(p, "Signature", "SHA224withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA224withRSA",
|
||||
createAliasesWithOid(rsaOid + ".14"), attrs);
|
||||
add(p, "Signature", "SHA256withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA256withRSA",
|
||||
createAliasesWithOid(rsaOid + ".11"), attrs);
|
||||
add(p, "Signature", "SHA384withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA384withRSA",
|
||||
createAliasesWithOid(rsaOid + ".12"), attrs);
|
||||
add(p, "Signature", "SHA512withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA512withRSA",
|
||||
createAliasesWithOid(rsaOid + ".13"), attrs);
|
||||
add(p, "Signature", "SHA512/224withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA512_224withRSA",
|
||||
createAliasesWithOid(rsaOid + ".15"), attrs);
|
||||
add(p, "Signature", "SHA512/256withRSA",
|
||||
"sun.security.rsa.RSASignature$SHA512_256withRSA",
|
||||
createAliasesWithOid(rsaOid + ".16"), attrs);
|
||||
|
||||
map.put("Alg.Alias.KeyPairGenerator.1.2.840.113549.1.1", "RSA");
|
||||
map.put("Alg.Alias.KeyPairGenerator.OID.1.2.840.113549.1.1", "RSA");
|
||||
|
||||
map.put("Alg.Alias.Signature.1.2.840.113549.1.1.2", "MD2withRSA");
|
||||
map.put("Alg.Alias.Signature.OID.1.2.840.113549.1.1.2", "MD2withRSA");
|
||||
|
||||
map.put("Alg.Alias.Signature.1.2.840.113549.1.1.4", "MD5withRSA");
|
||||
map.put("Alg.Alias.Signature.OID.1.2.840.113549.1.1.4", "MD5withRSA");
|
||||
|
||||
map.put("Alg.Alias.Signature.1.2.840.113549.1.1.5", "SHA1withRSA");
|
||||
map.put("Alg.Alias.Signature.OID.1.2.840.113549.1.1.5", "SHA1withRSA");
|
||||
map.put("Alg.Alias.Signature.1.3.14.3.2.29", "SHA1withRSA");
|
||||
|
||||
map.put("Alg.Alias.Signature.1.2.840.113549.1.1.14", "SHA224withRSA");
|
||||
map.put("Alg.Alias.Signature.OID.1.2.840.113549.1.1.14", "SHA224withRSA");
|
||||
|
||||
map.put("Alg.Alias.Signature.1.2.840.113549.1.1.11", "SHA256withRSA");
|
||||
map.put("Alg.Alias.Signature.OID.1.2.840.113549.1.1.11", "SHA256withRSA");
|
||||
|
||||
map.put("Alg.Alias.Signature.1.2.840.113549.1.1.12", "SHA384withRSA");
|
||||
map.put("Alg.Alias.Signature.OID.1.2.840.113549.1.1.12", "SHA384withRSA");
|
||||
|
||||
map.put("Alg.Alias.Signature.1.2.840.113549.1.1.13", "SHA512withRSA");
|
||||
map.put("Alg.Alias.Signature.OID.1.2.840.113549.1.1.13", "SHA512withRSA");
|
||||
map.put("Alg.Alias.Signature.1.2.840.113549.1.1.15", "SHA512/224withRSA");
|
||||
map.put("Alg.Alias.Signature.OID.1.2.840.113549.1.1.15", "SHA512/224withRSA");
|
||||
map.put("Alg.Alias.Signature.1.2.840.113549.1.1.16", "SHA512/256withRSA");
|
||||
map.put("Alg.Alias.Signature.OID.1.2.840.113549.1.1.16", "SHA512/256withRSA");
|
||||
|
||||
map.put("Alg.Alias.KeyFactory.1.2.840.113549.1.1.10", "RSASSA-PSS");
|
||||
map.put("Alg.Alias.KeyFactory.OID.1.2.840.113549.1.1.10", "RSASSA-PSS");
|
||||
|
||||
map.put("Alg.Alias.KeyPairGenerator.1.2.840.113549.1.1.10", "RSASSA-PSS");
|
||||
map.put("Alg.Alias.KeyPairGenerator.OID.1.2.840.113549.1.1.10", "RSASSA-PSS");
|
||||
|
||||
map.put("Alg.Alias.Signature.1.2.840.113549.1.1.10", "RSASSA-PSS");
|
||||
map.put("Alg.Alias.Signature.OID.1.2.840.113549.1.1.10", "RSASSA-PSS");
|
||||
|
||||
map.put("Alg.Alias.AlgorithmParameters.1.2.840.113549.1.1.10", "RSASSA-PSS");
|
||||
map.put("Alg.Alias.AlgorithmParameters.OID.1.2.840.113549.1.1.10", "RSASSA-PSS");
|
||||
add(p, "KeyFactory", "RSASSA-PSS",
|
||||
"sun.security.rsa.RSAKeyFactory$PSS",
|
||||
rsapssAliases, null);
|
||||
add(p, "KeyPairGenerator", "RSASSA-PSS",
|
||||
"sun.security.rsa.RSAKeyPairGenerator$PSS",
|
||||
rsapssAliases, null);
|
||||
add(p, "Signature", "RSASSA-PSS",
|
||||
"sun.security.rsa.RSAPSSSignature",
|
||||
rsapssAliases, attrs);
|
||||
add(p, "AlgorithmParameters", "RSASSA-PSS",
|
||||
"sun.security.rsa.PSSParameters",
|
||||
rsapssAliases, null);
|
||||
}
|
||||
|
||||
public Iterator<Provider.Service> iterator() {
|
||||
return services.iterator();
|
||||
}
|
||||
|
||||
private LinkedHashSet<Provider.Service> services;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue