public final class sun.security.ec.ECKeyPairGenerator extends java.security.KeyPairGeneratorSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: sun.security.ec.ECKeyPairGenerator
  super_class: java.security.KeyPairGeneratorSpi
{
  private static final int KEY_SIZE_MIN;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 112

  private static final int KEY_SIZE_MAX;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 571

  private java.security.SecureRandom random;
    descriptor: Ljava/security/SecureRandom;
    flags: (0x0002) ACC_PRIVATE

  private int keySize;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private java.security.spec.AlgorithmParameterSpec params;
    descriptor: Ljava/security/spec/AlgorithmParameterSpec;
    flags: (0x0002) ACC_PRIVATE

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.ec.ECKeyPairGenerator this
         0: .line 68
            aload 0 /* this */
            invokespecial java.security.KeyPairGeneratorSpi.<init>:()V
         1: .line 63
            aload 0 /* this */
            aconst_null
            putfield sun.security.ec.ECKeyPairGenerator.params:Ljava/security/spec/AlgorithmParameterSpec;
         2: .line 70
            aload 0 /* this */
            getstatic sun.security.util.SecurityProviderConstants.DEF_EC_KEY_SIZE:I
            aconst_null
            invokevirtual sun.security.ec.ECKeyPairGenerator.initialize:(ILjava/security/SecureRandom;)V
         3: .line 71
            return
        end local 0 // sun.security.ec.ECKeyPairGenerator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/ec/ECKeyPairGenerator;

  public void initialize(int, java.security.SecureRandom);
    descriptor: (ILjava/security/SecureRandom;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // sun.security.ec.ECKeyPairGenerator this
        start local 1 // int keySize
        start local 2 // java.security.SecureRandom random
         0: .line 77
            aload 0 /* this */
            iload 1 /* keySize */
            invokevirtual sun.security.ec.ECKeyPairGenerator.checkKeySize:(I)V
         1: .line 78
            aload 0 /* this */
            aconst_null
            iload 1 /* keySize */
            invokestatic sun.security.util.ECUtil.getECParameterSpec:(Ljava/security/Provider;I)Ljava/security/spec/ECParameterSpec;
            putfield sun.security.ec.ECKeyPairGenerator.params:Ljava/security/spec/AlgorithmParameterSpec;
         2: .line 79
            aload 0 /* this */
            getfield sun.security.ec.ECKeyPairGenerator.params:Ljava/security/spec/AlgorithmParameterSpec;
            ifnonnull 6
         3: .line 80
            new java.security.InvalidParameterException
            dup
         4: .line 81
            new java.lang.StringBuilder
            dup
            ldc "No EC parameters available for key size "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 1 /* keySize */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bits"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 80
            invokespecial java.security.InvalidParameterException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 83
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* random */
            putfield sun.security.ec.ECKeyPairGenerator.random:Ljava/security/SecureRandom;
         7: .line 84
            return
        end local 2 // java.security.SecureRandom random
        end local 1 // int keySize
        end local 0 // sun.security.ec.ECKeyPairGenerator this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0     this  Lsun/security/ec/ECKeyPairGenerator;
            0    8     1  keySize  I
            0    8     2   random  Ljava/security/SecureRandom;
    MethodParameters:
         Name  Flags
      keySize  
      random   

  public void initialize(java.security.spec.AlgorithmParameterSpec, java.security.SecureRandom);
    descriptor: (Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // sun.security.ec.ECKeyPairGenerator this
        start local 1 // java.security.spec.AlgorithmParameterSpec params
        start local 2 // java.security.SecureRandom random
         0: .line 91
            aconst_null
            astore 3 /* ecSpec */
        start local 3 // java.security.spec.ECParameterSpec ecSpec
         1: .line 93
            aload 1 /* params */
            instanceof java.security.spec.ECParameterSpec
            ifeq 8
         2: .line 94
            aload 1 /* params */
            checkcast java.security.spec.ECParameterSpec
            astore 4 /* ecParams */
        start local 4 // java.security.spec.ECParameterSpec ecParams
         3: .line 95
            aconst_null
            aload 4 /* ecParams */
            invokestatic sun.security.util.ECUtil.getECParameterSpec:(Ljava/security/Provider;Ljava/security/spec/ECParameterSpec;)Ljava/security/spec/ECParameterSpec;
            astore 3 /* ecSpec */
         4: .line 96
            aload 3 /* ecSpec */
            ifnonnull 18
         5: .line 97
            new java.security.InvalidAlgorithmParameterException
            dup
         6: .line 98
            new java.lang.StringBuilder
            dup
            ldc "Curve not supported: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* params */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         7: .line 97
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.security.spec.ECParameterSpec ecParams
         8: .line 100
      StackMap locals: java.security.spec.ECParameterSpec
      StackMap stack:
            aload 1 /* params */
            instanceof java.security.spec.ECGenParameterSpec
            ifeq 15
         9: .line 101
            aload 1 /* params */
            checkcast java.security.spec.ECGenParameterSpec
            invokevirtual java.security.spec.ECGenParameterSpec.getName:()Ljava/lang/String;
            astore 4 /* name */
        start local 4 // java.lang.String name
        10: .line 102
            aconst_null
            aload 4 /* name */
            invokestatic sun.security.util.ECUtil.getECParameterSpec:(Ljava/security/Provider;Ljava/lang/String;)Ljava/security/spec/ECParameterSpec;
            astore 3 /* ecSpec */
        11: .line 103
            aload 3 /* ecSpec */
            ifnonnull 18
        12: .line 104
            new java.security.InvalidAlgorithmParameterException
            dup
        13: .line 105
            new java.lang.StringBuilder
            dup
            ldc "Unknown curve name: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        14: .line 104
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.lang.String name
        15: .line 108
      StackMap locals:
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        16: .line 109
            ldc "ECParameterSpec or ECGenParameterSpec required for EC"
        17: .line 108
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 113
      StackMap locals:
      StackMap stack:
            aload 3 /* ecSpec */
            invokestatic sun.security.ec.ECKeyPairGenerator.ensureCurveIsSupported:(Ljava/security/spec/ECParameterSpec;)V
        19: .line 114
            aload 0 /* this */
            aload 3 /* ecSpec */
            putfield sun.security.ec.ECKeyPairGenerator.params:Ljava/security/spec/AlgorithmParameterSpec;
        20: .line 116
            aload 0 /* this */
            aload 3 /* ecSpec */
            invokevirtual java.security.spec.ECParameterSpec.getCurve:()Ljava/security/spec/EllipticCurve;
            invokevirtual java.security.spec.EllipticCurve.getField:()Ljava/security/spec/ECField;
            invokeinterface java.security.spec.ECField.getFieldSize:()I
            putfield sun.security.ec.ECKeyPairGenerator.keySize:I
        21: .line 117
            aload 0 /* this */
            aload 2 /* random */
            putfield sun.security.ec.ECKeyPairGenerator.random:Ljava/security/SecureRandom;
        22: .line 118
            return
        end local 3 // java.security.spec.ECParameterSpec ecSpec
        end local 2 // java.security.SecureRandom random
        end local 1 // java.security.spec.AlgorithmParameterSpec params
        end local 0 // sun.security.ec.ECKeyPairGenerator this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   23     0      this  Lsun/security/ec/ECKeyPairGenerator;
            0   23     1    params  Ljava/security/spec/AlgorithmParameterSpec;
            0   23     2    random  Ljava/security/SecureRandom;
            1   23     3    ecSpec  Ljava/security/spec/ECParameterSpec;
            3    8     4  ecParams  Ljava/security/spec/ECParameterSpec;
           10   15     4      name  Ljava/lang/String;
    Exceptions:
      throws java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      params  
      random  

  private static void ensureCurveIsSupported(java.security.spec.ECParameterSpec);
    descriptor: (Ljava/security/spec/ECParameterSpec;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // java.security.spec.ECParameterSpec ecSpec
         0: .line 124
            aconst_null
            invokestatic sun.security.util.ECUtil.getECParameters:(Ljava/security/Provider;)Ljava/security/AlgorithmParameters;
            astore 1 /* ecParams */
        start local 1 // java.security.AlgorithmParameters ecParams
         1: .line 126
            aload 1 /* ecParams */
            aload 0 /* ecSpec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
         2: .line 127
            goto 7
      StackMap locals: java.security.spec.ECParameterSpec java.security.AlgorithmParameters
      StackMap stack: java.security.spec.InvalidParameterSpecException
         3: pop
         4: .line 128
            new java.security.InvalidAlgorithmParameterException
            dup
         5: .line 129
            new java.lang.StringBuilder
            dup
            ldc "Curve not supported: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* ecSpec */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         6: .line 128
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 133
      StackMap locals:
      StackMap stack:
            aload 0 /* ecSpec */
            invokestatic sun.security.ec.ECOperations.forParameters:(Ljava/security/spec/ECParameterSpec;)Ljava/util/Optional;
            invokevirtual java.util.Optional.isEmpty:()Z
            ifeq 11
         8: .line 134
            new java.security.InvalidAlgorithmParameterException
            dup
         9: .line 135
            new java.lang.StringBuilder
            dup
            ldc "Curve not supported: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* ecSpec */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 134
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 137
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.security.AlgorithmParameters ecParams
        end local 0 // java.security.spec.ECParameterSpec ecSpec
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   12     0    ecSpec  Ljava/security/spec/ECParameterSpec;
            1   12     1  ecParams  Ljava/security/AlgorithmParameters;
      Exception table:
        from    to  target  type
           1     2       3  Class java.security.spec.InvalidParameterSpecException
    Exceptions:
      throws java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      ecSpec  

  public java.security.KeyPair generateKeyPair();
    descriptor: ()Ljava/security/KeyPair;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // sun.security.ec.ECKeyPairGenerator this
         0: .line 143
            aload 0 /* this */
            getfield sun.security.ec.ECKeyPairGenerator.random:Ljava/security/SecureRandom;
            ifnonnull 2
         1: .line 144
            aload 0 /* this */
            invokestatic sun.security.jca.JCAUtil.getSecureRandom:()Ljava/security/SecureRandom;
            putfield sun.security.ec.ECKeyPairGenerator.random:Ljava/security/SecureRandom;
         2: .line 148
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.ec.ECKeyPairGenerator.random:Ljava/security/SecureRandom;
            invokevirtual sun.security.ec.ECKeyPairGenerator.generateKeyPairImpl:(Ljava/security/SecureRandom;)Ljava/util/Optional;
            astore 1 /* kp */
        start local 1 // java.util.Optional kp
         3: .line 149
            aload 1 /* kp */
            invokevirtual java.util.Optional.isPresent:()Z
            ifeq 8
         4: .line 150
            aload 1 /* kp */
            invokevirtual java.util.Optional.get:()Ljava/lang/Object;
            checkcast java.security.KeyPair
         5: areturn
        end local 1 // java.util.Optional kp
         6: .line 152
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 1 /* ex */
        start local 1 // java.lang.Exception ex
         7: .line 153
            new java.security.ProviderException
            dup
            aload 1 /* ex */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.lang.Exception ex
         8: .line 155
      StackMap locals:
      StackMap stack:
            new java.security.ProviderException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Curve not supported:  "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         9: .line 156
            aload 0 /* this */
            getfield sun.security.ec.ECKeyPairGenerator.params:Ljava/security/spec/AlgorithmParameterSpec;
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 155
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
        end local 0 // sun.security.ec.ECKeyPairGenerator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lsun/security/ec/ECKeyPairGenerator;
            3    6     1    kp  Ljava/util/Optional<Ljava/security/KeyPair;>;
            7    8     1    ex  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2     5       6  Class java.lang.Exception

  private byte[] generatePrivateScalar(java.security.SecureRandom, sun.security.ec.ECOperations, int);
    descriptor: (Ljava/security/SecureRandom;Lsun/security/ec/ECOperations;I)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=7, args_size=4
        start local 0 // sun.security.ec.ECKeyPairGenerator this
        start local 1 // java.security.SecureRandom random
        start local 2 // sun.security.ec.ECOperations ecOps
        start local 3 // int seedSize
         0: .line 164
            sipush 128
            istore 4 /* numAttempts */
        start local 4 // int numAttempts
         1: .line 165
            iload 3 /* seedSize */
            newarray 8
            astore 5 /* seedArr */
        start local 5 // byte[] seedArr
         2: .line 166
            iconst_0
            istore 6 /* i */
        start local 6 // int i
         3: goto 9
         4: .line 167
      StackMap locals: int byte[] int
      StackMap stack:
            aload 1 /* random */
            aload 5 /* seedArr */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
         5: .line 169
            aload 2 /* ecOps */
            aload 5 /* seedArr */
            invokevirtual sun.security.ec.ECOperations.seedToScalar:([B)[B
         6: areturn
         7: .line 170
      StackMap locals:
      StackMap stack: sun.security.ec.ECOperations$IntermediateValueException
            pop
         8: .line 166
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
         9: iload 6 /* i */
            iload 4 /* numAttempts */
            if_icmplt 4
        end local 6 // int i
        10: .line 175
            new java.security.ProviderException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unable to produce private key after "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        11: .line 176
            iload 4 /* numAttempts */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " attempts"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        12: .line 175
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // byte[] seedArr
        end local 4 // int numAttempts
        end local 3 // int seedSize
        end local 2 // sun.security.ec.ECOperations ecOps
        end local 1 // java.security.SecureRandom random
        end local 0 // sun.security.ec.ECKeyPairGenerator this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   13     0         this  Lsun/security/ec/ECKeyPairGenerator;
            0   13     1       random  Ljava/security/SecureRandom;
            0   13     2        ecOps  Lsun/security/ec/ECOperations;
            0   13     3     seedSize  I
            1   13     4  numAttempts  I
            2   13     5      seedArr  [B
            3   10     6            i  I
      Exception table:
        from    to  target  type
           5     6       7  Class sun.security.ec.ECOperations$IntermediateValueException
    MethodParameters:
          Name  Flags
      random    
      ecOps     
      seedSize  

  private java.util.Optional<java.security.KeyPair> generateKeyPairImpl(java.security.SecureRandom);
    descriptor: (Ljava/security/SecureRandom;)Ljava/util/Optional;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=19, args_size=2
        start local 0 // sun.security.ec.ECKeyPairGenerator this
        start local 1 // java.security.SecureRandom random
         0: .line 182
            aload 0 /* this */
            getfield sun.security.ec.ECKeyPairGenerator.params:Ljava/security/spec/AlgorithmParameterSpec;
            checkcast java.security.spec.ECParameterSpec
            astore 2 /* ecParams */
        start local 2 // java.security.spec.ECParameterSpec ecParams
         1: .line 184
            aload 2 /* ecParams */
            invokestatic sun.security.ec.ECOperations.forParameters:(Ljava/security/spec/ECParameterSpec;)Ljava/util/Optional;
            astore 3 /* opsOpt */
        start local 3 // java.util.Optional opsOpt
         2: .line 185
            aload 3 /* opsOpt */
            invokevirtual java.util.Optional.isEmpty:()Z
            ifeq 4
         3: .line 186
            invokestatic java.util.Optional.empty:()Ljava/util/Optional;
            areturn
         4: .line 188
      StackMap locals: java.security.spec.ECParameterSpec java.util.Optional
      StackMap stack:
            aload 3 /* opsOpt */
            invokevirtual java.util.Optional.get:()Ljava/lang/Object;
            checkcast sun.security.ec.ECOperations
            astore 4 /* ops */
        start local 4 // sun.security.ec.ECOperations ops
         5: .line 189
            aload 4 /* ops */
            invokevirtual sun.security.ec.ECOperations.getField:()Lsun/security/util/math/IntegerFieldModuloP;
            astore 5 /* field */
        start local 5 // sun.security.util.math.IntegerFieldModuloP field
         6: .line 190
            aload 2 /* ecParams */
            invokevirtual java.security.spec.ECParameterSpec.getOrder:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.bitLength:()I
            istore 6 /* numBits */
        start local 6 // int numBits
         7: .line 191
            iload 6 /* numBits */
            bipush 64
            iadd
            istore 7 /* seedBits */
        start local 7 // int seedBits
         8: .line 192
            iload 7 /* seedBits */
            bipush 7
            iadd
            bipush 8
            idiv
            istore 8 /* seedSize */
        start local 8 // int seedSize
         9: .line 193
            aload 0 /* this */
            aload 1 /* random */
            aload 4 /* ops */
            iload 8 /* seedSize */
            invokevirtual sun.security.ec.ECKeyPairGenerator.generatePrivateScalar:(Ljava/security/SecureRandom;Lsun/security/ec/ECOperations;I)[B
            astore 9 /* privArr */
        start local 9 // byte[] privArr
        10: .line 195
            aload 2 /* ecParams */
            invokevirtual java.security.spec.ECParameterSpec.getGenerator:()Ljava/security/spec/ECPoint;
            astore 10 /* genPoint */
        start local 10 // java.security.spec.ECPoint genPoint
        11: .line 196
            aload 5 /* field */
            aload 10 /* genPoint */
            invokevirtual java.security.spec.ECPoint.getAffineX:()Ljava/math/BigInteger;
            invokeinterface sun.security.util.math.IntegerFieldModuloP.getElement:(Ljava/math/BigInteger;)Lsun/security/util/math/ImmutableIntegerModuloP;
            astore 11 /* x */
        start local 11 // sun.security.util.math.ImmutableIntegerModuloP x
        12: .line 197
            aload 5 /* field */
            aload 10 /* genPoint */
            invokevirtual java.security.spec.ECPoint.getAffineY:()Ljava/math/BigInteger;
            invokeinterface sun.security.util.math.IntegerFieldModuloP.getElement:(Ljava/math/BigInteger;)Lsun/security/util/math/ImmutableIntegerModuloP;
            astore 12 /* y */
        start local 12 // sun.security.util.math.ImmutableIntegerModuloP y
        13: .line 198
            new sun.security.ec.point.AffinePoint
            dup
            aload 11 /* x */
            aload 12 /* y */
            invokespecial sun.security.ec.point.AffinePoint.<init>:(Lsun/security/util/math/ImmutableIntegerModuloP;Lsun/security/util/math/ImmutableIntegerModuloP;)V
            astore 13 /* affGen */
        start local 13 // sun.security.ec.point.AffinePoint affGen
        14: .line 199
            aload 4 /* ops */
            aload 13 /* affGen */
            aload 9 /* privArr */
            invokevirtual sun.security.ec.ECOperations.multiply:(Lsun/security/ec/point/AffinePoint;[B)Lsun/security/ec/point/MutablePoint;
            astore 14 /* pub */
        start local 14 // sun.security.ec.point.Point pub
        15: .line 200
            aload 14 /* pub */
            invokeinterface sun.security.ec.point.Point.asAffine:()Lsun/security/ec/point/AffinePoint;
            astore 15 /* affPub */
        start local 15 // sun.security.ec.point.AffinePoint affPub
        16: .line 202
            new sun.security.ec.ECPrivateKeyImpl
            dup
            aload 9 /* privArr */
            aload 2 /* ecParams */
            invokespecial sun.security.ec.ECPrivateKeyImpl.<init>:([BLjava/security/spec/ECParameterSpec;)V
            astore 16 /* privateKey */
        start local 16 // java.security.PrivateKey privateKey
        17: .line 204
            new java.security.spec.ECPoint
            dup
            aload 15 /* affPub */
            invokevirtual sun.security.ec.point.AffinePoint.getX:()Lsun/security/util/math/ImmutableIntegerModuloP;
            invokeinterface sun.security.util.math.ImmutableIntegerModuloP.asBigInteger:()Ljava/math/BigInteger;
        18: .line 205
            aload 15 /* affPub */
            invokevirtual sun.security.ec.point.AffinePoint.getY:()Lsun/security/util/math/ImmutableIntegerModuloP;
            invokeinterface sun.security.util.math.ImmutableIntegerModuloP.asBigInteger:()Ljava/math/BigInteger;
        19: .line 204
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            astore 17 /* w */
        start local 17 // java.security.spec.ECPoint w
        20: .line 206
            new sun.security.ec.ECPublicKeyImpl
            dup
            aload 17 /* w */
            aload 2 /* ecParams */
            invokespecial sun.security.ec.ECPublicKeyImpl.<init>:(Ljava/security/spec/ECPoint;Ljava/security/spec/ECParameterSpec;)V
            astore 18 /* publicKey */
        start local 18 // java.security.PublicKey publicKey
        21: .line 208
            new java.security.KeyPair
            dup
            aload 18 /* publicKey */
            aload 16 /* privateKey */
            invokespecial java.security.KeyPair.<init>:(Ljava/security/PublicKey;Ljava/security/PrivateKey;)V
            invokestatic java.util.Optional.of:(Ljava/lang/Object;)Ljava/util/Optional;
            areturn
        end local 18 // java.security.PublicKey publicKey
        end local 17 // java.security.spec.ECPoint w
        end local 16 // java.security.PrivateKey privateKey
        end local 15 // sun.security.ec.point.AffinePoint affPub
        end local 14 // sun.security.ec.point.Point pub
        end local 13 // sun.security.ec.point.AffinePoint affGen
        end local 12 // sun.security.util.math.ImmutableIntegerModuloP y
        end local 11 // sun.security.util.math.ImmutableIntegerModuloP x
        end local 10 // java.security.spec.ECPoint genPoint
        end local 9 // byte[] privArr
        end local 8 // int seedSize
        end local 7 // int seedBits
        end local 6 // int numBits
        end local 5 // sun.security.util.math.IntegerFieldModuloP field
        end local 4 // sun.security.ec.ECOperations ops
        end local 3 // java.util.Optional opsOpt
        end local 2 // java.security.spec.ECParameterSpec ecParams
        end local 1 // java.security.SecureRandom random
        end local 0 // sun.security.ec.ECKeyPairGenerator this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   22     0        this  Lsun/security/ec/ECKeyPairGenerator;
            0   22     1      random  Ljava/security/SecureRandom;
            1   22     2    ecParams  Ljava/security/spec/ECParameterSpec;
            2   22     3      opsOpt  Ljava/util/Optional<Lsun/security/ec/ECOperations;>;
            5   22     4         ops  Lsun/security/ec/ECOperations;
            6   22     5       field  Lsun/security/util/math/IntegerFieldModuloP;
            7   22     6     numBits  I
            8   22     7    seedBits  I
            9   22     8    seedSize  I
           10   22     9     privArr  [B
           11   22    10    genPoint  Ljava/security/spec/ECPoint;
           12   22    11           x  Lsun/security/util/math/ImmutableIntegerModuloP;
           13   22    12           y  Lsun/security/util/math/ImmutableIntegerModuloP;
           14   22    13      affGen  Lsun/security/ec/point/AffinePoint;
           15   22    14         pub  Lsun/security/ec/point/Point;
           16   22    15      affPub  Lsun/security/ec/point/AffinePoint;
           17   22    16  privateKey  Ljava/security/PrivateKey;
           20   22    17           w  Ljava/security/spec/ECPoint;
           21   22    18   publicKey  Ljava/security/PublicKey;
    Exceptions:
      throws java.security.InvalidKeyException
    Signature: (Ljava/security/SecureRandom;)Ljava/util/Optional<Ljava/security/KeyPair;>;
    MethodParameters:
        Name  Flags
      random  

  private void checkKeySize(int);
    descriptor: (I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.ec.ECKeyPairGenerator this
        start local 1 // int keySize
         0: .line 212
            iload 1 /* keySize */
            bipush 112
            if_icmpge 4
         1: .line 213
            new java.security.InvalidParameterException
            dup
         2: .line 214
            ldc "Key size must be at least 112 bits"
         3: .line 213
            invokespecial java.security.InvalidParameterException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 216
      StackMap locals:
      StackMap stack:
            iload 1 /* keySize */
            sipush 571
            if_icmple 8
         5: .line 217
            new java.security.InvalidParameterException
            dup
         6: .line 218
            ldc "Key size must be at most 571 bits"
         7: .line 217
            invokespecial java.security.InvalidParameterException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 220
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* keySize */
            putfield sun.security.ec.ECKeyPairGenerator.keySize:I
         9: .line 221
            return
        end local 1 // int keySize
        end local 0 // sun.security.ec.ECKeyPairGenerator this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   10     0     this  Lsun/security/ec/ECKeyPairGenerator;
            0   10     1  keySize  I
    Exceptions:
      throws java.security.InvalidParameterException
    MethodParameters:
         Name  Flags
      keySize  
}
SourceFile: "ECKeyPairGenerator.java"
InnerClasses:
  IntermediateValueException = sun.security.ec.ECOperations$IntermediateValueException of sun.security.ec.ECOperations