RSAKeyPairGenerator.smali
.class public Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;
.super Ljava/lang/Object;
.source "RSAKeyPairGenerator.java"
# interfaces
.implements Lorg/spongycastle/crypto/AsymmetricCipherKeyPairGenerator;
# static fields
.field private static final ONE:Ljava/math/BigInteger;
# instance fields
.field private iterations:I
.field private param:Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;
# direct methods
.method static constructor <clinit>()V
.registers 2
.prologue
.line 20
const-wide/16 v0, 0x1
invoke-static {v0, v1}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v0
sput-object v0, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->ONE:Ljava/math/BigInteger;
return-void
.end method
.method public constructor <init>()V
.registers 1
.prologue
.line 17
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private static getNumberOfIterations(II)I
.registers 7
.prologue
const/16 v4, 0x50
const/4 v1, 0x5
const/4 v0, 0x4
const/16 v3, 0x64
.line 207
const/16 v2, 0x600
if-lt p0, v2, :cond_1b
.line 209
if-gt p1, v3, :cond_e
const/4 v0, 0x3
.line 227
:cond_d
:goto_d
return v0
.line 209
:cond_e
const/16 v1, 0x80
if-le p1, v1, :cond_d
add-int/lit8 v0, p1, -0x80
add-int/lit8 v0, v0, 0x1
div-int/lit8 v0, v0, 0x2
add-int/lit8 v0, v0, 0x4
goto :goto_d
.line 213
:cond_1b
const/16 v2, 0x400
if-lt p0, v2, :cond_30
.line 215
if-le p1, v3, :cond_d
const/16 v0, 0x70
if-gt p1, v0, :cond_27
move v0, v1
goto :goto_d
:cond_27
add-int/lit8 v0, p1, -0x70
add-int/lit8 v0, v0, 0x1
div-int/lit8 v0, v0, 0x2
add-int/lit8 v0, v0, 0x5
goto :goto_d
.line 219
:cond_30
const/16 v0, 0x200
if-lt p0, v0, :cond_45
.line 221
if-gt p1, v4, :cond_38
move v0, v1
goto :goto_d
:cond_38
if-gt p1, v3, :cond_3c
const/4 v0, 0x7
goto :goto_d
:cond_3c
add-int/lit8 v0, p1, -0x64
add-int/lit8 v0, v0, 0x1
div-int/lit8 v0, v0, 0x2
add-int/lit8 v0, v0, 0x7
goto :goto_d
.line 227
:cond_45
if-gt p1, v4, :cond_4a
const/16 v0, 0x28
goto :goto_d
:cond_4a
add-int/lit8 v0, p1, -0x50
add-int/lit8 v0, v0, 0x1
div-int/lit8 v0, v0, 0x2
add-int/lit8 v0, v0, 0x28
goto :goto_d
.end method
# virtual methods
.method protected chooseRandomPrime(ILjava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
.registers 8
.prologue
.line 162
const/4 v0, 0x0
:goto_1
mul-int/lit8 v1, p1, 0x5
if-eq v0, v1, :cond_43
.line 164
new-instance v1, Ljava/math/BigInteger;
const/4 v2, 0x1
iget-object v3, p0, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->param:Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;
invoke-virtual {v3}, Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;->getRandom()Ljava/security/SecureRandom;
move-result-object v3
invoke-direct {v1, p1, v2, v3}, Ljava/math/BigInteger;-><init>(IILjava/util/Random;)V
.line 166
invoke-virtual {v1, p2}, Ljava/math/BigInteger;->mod(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v2
sget-object v3, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->ONE:Ljava/math/BigInteger;
invoke-virtual {v2, v3}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result v2
if-nez v2, :cond_40
.line 171
invoke-virtual {v1, v1}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v2
invoke-virtual {v2, p3}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v2
if-ltz v2, :cond_40
.line 176
invoke-virtual {p0, v1}, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->isProbablePrime(Ljava/math/BigInteger;)Z
move-result v2
if-eqz v2, :cond_40
.line 181
sget-object v2, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->ONE:Ljava/math/BigInteger;
invoke-virtual {v1, v2}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v2
invoke-virtual {p2, v2}, Ljava/math/BigInteger;->gcd(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v2
sget-object v3, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->ONE:Ljava/math/BigInteger;
invoke-virtual {v2, v3}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_40
.line 186
return-object v1
.line 162
:cond_40
add-int/lit8 v0, v0, 0x1
goto :goto_1
.line 189
:cond_43
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "unable to generate prime number for RSA key"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public generateKeyPair()Lorg/spongycastle/crypto/AsymmetricCipherKeyPair;
.registers 25
.prologue
.line 33
const/4 v6, 0x0
.line 34
const/4 v5, 0x0
.line 39
move-object/from16 v0, p0
iget-object v4, v0, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->param:Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;
invoke-virtual {v4}, Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;->getStrength()I
move-result v16
.line 40
add-int/lit8 v4, v16, 0x1
div-int/lit8 v17, v4, 0x2
.line 41
sub-int v18, v16, v17
.line 42
div-int/lit8 v4, v16, 0x2
add-int/lit8 v4, v4, -0x64
.line 44
div-int/lit8 v7, v16, 0x3
if-ge v4, v7, :cond_e5
.line 46
div-int/lit8 v4, v16, 0x3
move v13, v4
.line 49
:goto_1b
shr-int/lit8 v19, v16, 0x2
.line 52
const-wide/16 v8, 0x2
invoke-static {v8, v9}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v4
div-int/lit8 v7, v16, 0x2
invoke-virtual {v4, v7}, Ljava/math/BigInteger;->pow(I)Ljava/math/BigInteger;
move-result-object v20
.line 54
sget-object v4, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->ONE:Ljava/math/BigInteger;
add-int/lit8 v7, v16, -0x1
invoke-virtual {v4, v7}, Ljava/math/BigInteger;->shiftLeft(I)Ljava/math/BigInteger;
move-result-object v21
.line 56
sget-object v4, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->ONE:Ljava/math/BigInteger;
invoke-virtual {v4, v13}, Ljava/math/BigInteger;->shiftLeft(I)Ljava/math/BigInteger;
move-result-object v22
move v10, v5
move-object v11, v6
.line 58
:cond_39
:goto_39
if-nez v10, :cond_e2
.line 62
move-object/from16 v0, p0
iget-object v4, v0, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->param:Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;
invoke-virtual {v4}, Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;->getPublicExponent()Ljava/math/BigInteger;
move-result-object v6
.line 64
move-object/from16 v0, p0
move/from16 v1, v17
move-object/from16 v2, v21
invoke-virtual {v0, v1, v6, v2}, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->chooseRandomPrime(ILjava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
.line 71
:cond_4d
:goto_4d
move-object/from16 v0, p0
move/from16 v1, v18
move-object/from16 v2, v21
invoke-virtual {v0, v1, v6, v2}, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->chooseRandomPrime(ILjava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v9
.line 74
invoke-virtual {v9, v4}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v5
invoke-virtual {v5}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v5
.line 75
invoke-virtual {v5}, Ljava/math/BigInteger;->bitLength()I
move-result v7
if-lt v7, v13, :cond_4d
move-object/from16 v0, v22
invoke-virtual {v5, v0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v5
if-lez v5, :cond_4d
.line 83
invoke-virtual {v4, v9}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v5
.line 85
invoke-virtual {v5}, Ljava/math/BigInteger;->bitLength()I
move-result v7
move/from16 v0, v16
if-eq v7, v0, :cond_7e
.line 91
invoke-virtual {v4, v9}, Ljava/math/BigInteger;->max(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
goto :goto_4d
.line 101
:cond_7e
invoke-static {v5}, Lorg/spongycastle/math/ec/WNafUtil;->getNafWeight(Ljava/math/BigInteger;)I
move-result v7
move/from16 v0, v19
if-ge v7, v0, :cond_91
.line 103
move-object/from16 v0, p0
move/from16 v1, v17
move-object/from16 v2, v21
invoke-virtual {v0, v1, v6, v2}, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->chooseRandomPrime(ILjava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
goto :goto_4d
.line 110
:cond_91
invoke-virtual {v4, v9}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v7
if-gez v7, :cond_e3
move-object v8, v9
move-object v9, v4
.line 117
:goto_99
sget-object v4, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->ONE:Ljava/math/BigInteger;
invoke-virtual {v8, v4}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
.line 118
sget-object v7, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->ONE:Ljava/math/BigInteger;
invoke-virtual {v9, v7}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v12
.line 119
invoke-virtual {v4, v12}, Ljava/math/BigInteger;->gcd(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v7
.line 120
invoke-virtual {v4, v7}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v7
invoke-virtual {v7, v12}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v7
.line 125
invoke-virtual {v6, v7}, Ljava/math/BigInteger;->modInverse(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v7
.line 127
move-object/from16 v0, v20
invoke-virtual {v7, v0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v14
if-lez v14, :cond_39
.line 133
const/4 v14, 0x1
.line 141
invoke-virtual {v7, v4}, Ljava/math/BigInteger;->remainder(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v10
.line 142
invoke-virtual {v7, v12}, Ljava/math/BigInteger;->remainder(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v11
.line 143
invoke-virtual {v9, v8}, Ljava/math/BigInteger;->modInverse(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v12
.line 145
new-instance v15, Lorg/spongycastle/crypto/AsymmetricCipherKeyPair;
new-instance v23, Lorg/spongycastle/crypto/params/RSAKeyParameters;
const/4 v4, 0x0
move-object/from16 v0, v23
invoke-direct {v0, v4, v5, v6}, Lorg/spongycastle/crypto/params/RSAKeyParameters;-><init>(ZLjava/math/BigInteger;Ljava/math/BigInteger;)V
new-instance v4, Lorg/spongycastle/crypto/params/RSAPrivateCrtKeyParameters;
invoke-direct/range {v4 .. v12}, Lorg/spongycastle/crypto/params/RSAPrivateCrtKeyParameters;-><init>(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
move-object/from16 v0, v23
invoke-direct {v15, v0, v4}, Lorg/spongycastle/crypto/AsymmetricCipherKeyPair;-><init>(Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;)V
move v10, v14
move-object v11, v15
.line 148
goto/16 :goto_39
.line 150
:cond_e2
return-object v11
:cond_e3
move-object v8, v4
goto :goto_99
:cond_e5
move v13, v4
goto/16 :goto_1b
.end method
.method public init(Lorg/spongycastle/crypto/KeyGenerationParameters;)V
.registers 4
.prologue
.line 27
check-cast p1, Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;
iput-object p1, p0, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->param:Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;
.line 28
iget-object v0, p0, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->param:Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;->getStrength()I
move-result v0
iget-object v1, p0, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->param:Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;
invoke-virtual {v1}, Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;->getCertainty()I
move-result v1
invoke-static {v0, v1}, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->getNumberOfIterations(II)I
move-result v0
iput v0, p0, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->iterations:I
.line 29
return-void
.end method
.method protected isProbablePrime(Ljava/math/BigInteger;)Z
.registers 4
.prologue
.line 197
invoke-static {p1}, Lorg/spongycastle/math/Primes;->hasAnySmallFactors(Ljava/math/BigInteger;)Z
move-result v0
if-nez v0, :cond_16
iget-object v0, p0, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->param:Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/RSAKeyGenerationParameters;->getRandom()Ljava/security/SecureRandom;
move-result-object v0
iget v1, p0, Lorg/spongycastle/crypto/generators/RSAKeyPairGenerator;->iterations:I
invoke-static {p1, v0, v1}, Lorg/spongycastle/math/Primes;->isMRProbablePrime(Ljava/math/BigInteger;Ljava/security/SecureRandom;I)Z
move-result v0
if-eqz v0, :cond_16
const/4 v0, 0x1
:goto_15
return v0
:cond_16
const/4 v0, 0x0
goto :goto_15
.end method