public class org.bouncycastle.crypto.digests.GOST3411Digest implements org.bouncycastle.crypto.ExtendedDigest
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.bouncycastle.crypto.digests.GOST3411Digest
super_class: java.lang.Object
{
private static final int DIGEST_LENGTH;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 32
private byte[] H;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
private byte[] L;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
private byte[] M;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
private byte[] Sum;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
private byte[][] C;
descriptor: [[B
flags: (0x0002) ACC_PRIVATE
private byte[] xBuf;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
private int xBufOff;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private long byteCount;
descriptor: J
flags: (0x0002) ACC_PRIVATE
private org.bouncycastle.crypto.BlockCipher cipher;
descriptor: Lorg/bouncycastle/crypto/BlockCipher;
flags: (0x0002) ACC_PRIVATE
private byte[] sBox;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
private byte[] K;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
byte[] a;
descriptor: [B
flags: (0x0000)
short[] wS;
descriptor: [S
flags: (0x0000)
short[] w_S;
descriptor: [S
flags: (0x0000)
byte[] S;
descriptor: [B
flags: (0x0000)
byte[] U;
descriptor: [B
flags: (0x0000)
byte[] V;
descriptor: [B
flags: (0x0000)
byte[] W;
descriptor: [B
flags: (0x0000)
private static final byte[] C2;
descriptor: [B
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=4, locals=0, args_size=0
0: bipush 32
newarray 8
dup
iconst_1
1: iconst_m1
bastore
dup
iconst_3
iconst_m1
bastore
dup
iconst_5
iconst_m1
bastore
dup
bipush 7
iconst_m1
bastore
dup
bipush 8
2: iconst_m1
bastore
dup
bipush 10
iconst_m1
bastore
dup
bipush 12
iconst_m1
bastore
dup
bipush 14
iconst_m1
bastore
dup
bipush 17
3: iconst_m1
bastore
dup
bipush 18
iconst_m1
bastore
dup
bipush 20
iconst_m1
bastore
dup
bipush 23
iconst_m1
bastore
dup
bipush 24
4: iconst_m1
bastore
dup
bipush 28
iconst_m1
bastore
dup
bipush 29
iconst_m1
bastore
dup
bipush 31
iconst_m1
bastore
5: putstatic org.bouncycastle.crypto.digests.GOST3411Digest.C2:[B
6: return
LocalVariableTable:
Start End Slot Name Signature
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.L:[B
2: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
3: aload 0
iconst_4
bipush 32
multianewarray [[B 2
putfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
4: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
5: aload 0
new org.bouncycastle.crypto.engines.GOST28147Engine
dup
invokespecial org.bouncycastle.crypto.engines.GOST28147Engine.<init>:()V
putfield org.bouncycastle.crypto.digests.GOST3411Digest.cipher:Lorg/bouncycastle/crypto/BlockCipher;
6: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.K:[B
7: aload 0
bipush 8
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.a:[B
8: aload 0
bipush 16
newarray 9
putfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
aload 0
bipush 16
newarray 9
putfield org.bouncycastle.crypto.digests.GOST3411Digest.w_S:[S
9: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
10: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.U:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.V:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.W:[B
11: aload 0
ldc "D-A"
invokestatic org.bouncycastle.crypto.engines.GOST28147Engine.getSBox:(Ljava/lang/String;)[B
putfield org.bouncycastle.crypto.digests.GOST3411Digest.sBox:[B
12: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.cipher:Lorg/bouncycastle/crypto/BlockCipher;
iconst_1
new org.bouncycastle.crypto.params.ParametersWithSBox
dup
aconst_null
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.sBox:[B
invokespecial org.bouncycastle.crypto.params.ParametersWithSBox.<init>:(Lorg/bouncycastle/crypto/CipherParameters;[B)V
invokeinterface org.bouncycastle.crypto.BlockCipher.init:(ZLorg/bouncycastle/crypto/CipherParameters;)V
13: aload 0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.reset:()V
14: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
public void <init>(byte[]);
descriptor: ([B)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.L:[B
2: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
3: aload 0
iconst_4
bipush 32
multianewarray [[B 2
putfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
4: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
5: aload 0
new org.bouncycastle.crypto.engines.GOST28147Engine
dup
invokespecial org.bouncycastle.crypto.engines.GOST28147Engine.<init>:()V
putfield org.bouncycastle.crypto.digests.GOST3411Digest.cipher:Lorg/bouncycastle/crypto/BlockCipher;
6: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.K:[B
7: aload 0
bipush 8
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.a:[B
8: aload 0
bipush 16
newarray 9
putfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
aload 0
bipush 16
newarray 9
putfield org.bouncycastle.crypto.digests.GOST3411Digest.w_S:[S
9: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
10: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.U:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.V:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.W:[B
11: aload 0
aload 1
invokestatic org.bouncycastle.util.Arrays.clone:([B)[B
putfield org.bouncycastle.crypto.digests.GOST3411Digest.sBox:[B
12: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.cipher:Lorg/bouncycastle/crypto/BlockCipher;
iconst_1
new org.bouncycastle.crypto.params.ParametersWithSBox
dup
aconst_null
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.sBox:[B
invokespecial org.bouncycastle.crypto.params.ParametersWithSBox.<init>:(Lorg/bouncycastle/crypto/CipherParameters;[B)V
invokeinterface org.bouncycastle.crypto.BlockCipher.init:(ZLorg/bouncycastle/crypto/CipherParameters;)V
13: aload 0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.reset:()V
14: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 15 1 sBoxParam [B
MethodParameters:
Name Flags
sBoxParam
public void <init>(org.bouncycastle.crypto.digests.GOST3411Digest);
descriptor: (Lorg/bouncycastle/crypto/digests/GOST3411Digest;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.L:[B
2: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
3: aload 0
iconst_4
bipush 32
multianewarray [[B 2
putfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
4: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
5: aload 0
new org.bouncycastle.crypto.engines.GOST28147Engine
dup
invokespecial org.bouncycastle.crypto.engines.GOST28147Engine.<init>:()V
putfield org.bouncycastle.crypto.digests.GOST3411Digest.cipher:Lorg/bouncycastle/crypto/BlockCipher;
6: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.K:[B
7: aload 0
bipush 8
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.a:[B
8: aload 0
bipush 16
newarray 9
putfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
aload 0
bipush 16
newarray 9
putfield org.bouncycastle.crypto.digests.GOST3411Digest.w_S:[S
9: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
10: aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.U:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.V:[B
aload 0
bipush 32
newarray 8
putfield org.bouncycastle.crypto.digests.GOST3411Digest.W:[B
11: aload 0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.sBox:[B
putfield org.bouncycastle.crypto.digests.GOST3411Digest.sBox:[B
12: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.cipher:Lorg/bouncycastle/crypto/BlockCipher;
iconst_1
new org.bouncycastle.crypto.params.ParametersWithSBox
dup
aconst_null
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.sBox:[B
invokespecial org.bouncycastle.crypto.params.ParametersWithSBox.<init>:(Lorg/bouncycastle/crypto/CipherParameters;[B)V
invokeinterface org.bouncycastle.crypto.BlockCipher.init:(ZLorg/bouncycastle/crypto/CipherParameters;)V
13: aload 0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.reset:()V
14: aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
iconst_0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
15: aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.L:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.L:[B
iconst_0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.L:[B
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
16: aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
iconst_0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
17: aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
iconst_0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
18: aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_1
aaload
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_1
aaload
iconst_0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_1
aaload
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
19: aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_2
aaload
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_2
aaload
iconst_0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_2
aaload
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
20: aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_3
aaload
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_3
aaload
iconst_0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_3
aaload
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
21: aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
iconst_0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
22: aload 0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBufOff:I
putfield org.bouncycastle.crypto.digests.GOST3411Digest.xBufOff:I
23: aload 0
aload 1
getfield org.bouncycastle.crypto.digests.GOST3411Digest.byteCount:J
putfield org.bouncycastle.crypto.digests.GOST3411Digest.byteCount:J
24: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 25 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 25 1 t Lorg/bouncycastle/crypto/digests/GOST3411Digest;
MethodParameters:
Name Flags
t
public java.lang.String getAlgorithmName();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: ldc "GOST3411"
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
public int getDigestSize();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: bipush 32
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
public void update(byte);
descriptor: (B)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
aload 0
dup
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBufOff:I
dup_x1
iconst_1
iadd
putfield org.bouncycastle.crypto.digests.GOST3411Digest.xBufOff:I
iload 1
bastore
1: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBufOff:I
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
arraylength
if_icmpne 5
2: aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.sumByteArray:([B)V
3: aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
iconst_0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.processBlock:([BI)V
4: aload 0
iconst_0
putfield org.bouncycastle.crypto.digests.GOST3411Digest.xBufOff:I
5: StackMap locals:
StackMap stack:
aload 0
dup
getfield org.bouncycastle.crypto.digests.GOST3411Digest.byteCount:J
lconst_1
ladd
putfield org.bouncycastle.crypto.digests.GOST3411Digest.byteCount:J
6: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 7 1 in B
MethodParameters:
Name Flags
in
public void update(byte[], int, int);
descriptor: ([BII)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: goto 4
1: StackMap locals:
StackMap stack:
aload 0
aload 1
iload 2
baload
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.update:(B)V
2: iinc 2 1
3: iinc 3 -1
4: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBufOff:I
ifeq 12
iload 3
ifgt 1
5: goto 12
6: StackMap locals:
StackMap stack:
aload 1
iload 2
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
7: aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.sumByteArray:([B)V
8: aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
iconst_0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.processBlock:([BI)V
9: iload 2
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
arraylength
iadd
istore 2
10: iload 3
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
arraylength
isub
istore 3
11: aload 0
dup
getfield org.bouncycastle.crypto.digests.GOST3411Digest.byteCount:J
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
arraylength
i2l
ladd
putfield org.bouncycastle.crypto.digests.GOST3411Digest.byteCount:J
12: StackMap locals:
StackMap stack:
iload 3
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
arraylength
if_icmpgt 6
13: goto 17
14: StackMap locals:
StackMap stack:
aload 0
aload 1
iload 2
baload
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.update:(B)V
15: iinc 2 1
16: iinc 3 -1
17: StackMap locals:
StackMap stack:
iload 3
ifgt 14
18: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 19 1 in [B
0 19 2 inOff I
0 19 3 len I
MethodParameters:
Name Flags
in
inOff
len
private byte[] P(byte[]);
descriptor: ([B)[B
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=3, args_size=2
start local 0 start local 1 0: iconst_0
istore 2
start local 2 1: goto 7
2: StackMap locals: int
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.K:[B
iconst_4
iload 2
imul
aload 1
iload 2
baload
bastore
3: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.K:[B
iconst_1
iconst_4
iload 2
imul
iadd
aload 1
bipush 8
iload 2
iadd
baload
bastore
4: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.K:[B
iconst_2
iconst_4
iload 2
imul
iadd
aload 1
bipush 16
iload 2
iadd
baload
bastore
5: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.K:[B
iconst_3
iconst_4
iload 2
imul
iadd
aload 1
bipush 24
iload 2
iadd
baload
bastore
6: iinc 2 1
StackMap locals:
StackMap stack:
7: iload 2
bipush 8
if_icmplt 2
end local 2 8: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.K:[B
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 9 1 in [B
1 8 2 k I
MethodParameters:
Name Flags
in
private byte[] A(byte[]);
descriptor: ([B)[B
flags: (0x0002) ACC_PRIVATE
Code:
stack=6, locals=3, args_size=2
start local 0 start local 1 0: iconst_0
istore 2
start local 2 1: goto 4
2: StackMap locals: int
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.a:[B
iload 2
aload 1
iload 2
baload
aload 1
iload 2
bipush 8
iadd
baload
ixor
i2b
bastore
3: iinc 2 1
StackMap locals:
StackMap stack:
4: iload 2
bipush 8
if_icmplt 2
end local 2 5: aload 1
bipush 8
aload 1
iconst_0
bipush 24
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
6: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.a:[B
iconst_0
aload 1
bipush 24
bipush 8
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
7: aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 8 1 in [B
1 5 2 j I
MethodParameters:
Name Flags
in
private void E(byte[], byte[], int, byte[], int);
descriptor: ([B[BI[BI)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=6, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.cipher:Lorg/bouncycastle/crypto/BlockCipher;
iconst_1
new org.bouncycastle.crypto.params.KeyParameter
dup
aload 1
invokespecial org.bouncycastle.crypto.params.KeyParameter.<init>:([B)V
invokeinterface org.bouncycastle.crypto.BlockCipher.init:(ZLorg/bouncycastle/crypto/CipherParameters;)V
1: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.cipher:Lorg/bouncycastle/crypto/BlockCipher;
aload 4
iload 5
aload 2
iload 3
invokeinterface org.bouncycastle.crypto.BlockCipher.processBlock:([BI[BI)I
pop
2: return
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 3 1 key [B
0 3 2 s [B
0 3 3 sOff I
0 3 4 in [B
0 3 5 inOff I
MethodParameters:
Name Flags
key
s
sOff
in
inOff
private void fw(byte[]);
descriptor: ([B)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.cpyBytesToShort:([B[S)V
1: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.w_S:[S
bipush 15
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
iconst_0
saload
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
iconst_1
saload
ixor
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
iconst_2
saload
ixor
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
iconst_3
saload
ixor
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
bipush 12
saload
ixor
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
bipush 15
saload
ixor
i2s
sastore
2: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.wS:[S
iconst_1
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.w_S:[S
iconst_0
bipush 15
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
3: aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.w_S:[S
aload 1
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.cpyShortToBytes:([S[B)V
4: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 5 1 in [B
MethodParameters:
Name Flags
in
protected void processBlock(byte[], int);
descriptor: ([BI)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=7, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 1
iload 2
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
iconst_0
bipush 32
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
1: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.U:[B
iconst_0
bipush 32
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
2: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.V:[B
iconst_0
bipush 32
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
3: iconst_0
istore 3
start local 3 4: goto 7
5: StackMap locals: int
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.W:[B
iload 3
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.U:[B
iload 3
baload
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.V:[B
iload 3
baload
ixor
i2b
bastore
6: iinc 3 1
StackMap locals:
StackMap stack:
7: iload 3
bipush 32
if_icmplt 5
end local 3 8: aload 0
aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.W:[B
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.P:([B)[B
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
iconst_0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.E:([B[BI[BI)V
9: iconst_1
istore 3
start local 3 10: goto 25
11: StackMap locals:
StackMap stack:
aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.U:[B
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.A:([B)[B
astore 4
start local 4 12: iconst_0
istore 5
start local 5 13: goto 16
14: StackMap locals: byte[] int
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.U:[B
iload 5
aload 4
iload 5
baload
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iload 3
aaload
iload 5
baload
ixor
i2b
bastore
15: iinc 5 1
StackMap locals:
StackMap stack:
16: iload 5
bipush 32
if_icmplt 14
end local 5 17: aload 0
aload 0
aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.V:[B
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.A:([B)[B
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.A:([B)[B
putfield org.bouncycastle.crypto.digests.GOST3411Digest.V:[B
18: iconst_0
istore 5
start local 5 19: goto 22
20: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.W:[B
iload 5
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.U:[B
iload 5
baload
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.V:[B
iload 5
baload
ixor
i2b
bastore
21: iinc 5 1
StackMap locals:
StackMap stack:
22: iload 5
bipush 32
if_icmplt 20
end local 5 23: aload 0
aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.W:[B
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.P:([B)[B
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
iload 3
bipush 8
imul
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
iload 3
bipush 8
imul
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.E:([B[BI[BI)V
end local 4 24: iinc 3 1
StackMap locals:
StackMap stack:
25: iload 3
iconst_4
if_icmplt 11
end local 3 26: iconst_0
istore 3
start local 3 27: goto 30
28: StackMap locals:
StackMap stack:
aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.fw:([B)V
29: iinc 3 1
StackMap locals:
StackMap stack:
30: iload 3
bipush 12
if_icmplt 28
end local 3 31: iconst_0
istore 3
start local 3 32: goto 35
33: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
iload 3
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
iload 3
baload
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
iload 3
baload
ixor
i2b
bastore
34: iinc 3 1
StackMap locals:
StackMap stack:
35: iload 3
bipush 32
if_icmplt 33
end local 3 36: aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.fw:([B)V
37: iconst_0
istore 3
start local 3 38: goto 41
39: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
iload 3
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
iload 3
baload
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
iload 3
baload
ixor
i2b
bastore
40: iinc 3 1
StackMap locals:
StackMap stack:
41: iload 3
bipush 32
if_icmplt 39
end local 3 42: iconst_0
istore 3
start local 3 43: goto 46
44: StackMap locals:
StackMap stack:
aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.fw:([B)V
45: iinc 3 1
StackMap locals:
StackMap stack:
46: iload 3
bipush 61
if_icmplt 44
end local 3 47: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.S:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
48: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 49 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 49 1 in [B
0 49 2 inOff I
4 8 3 j I
10 26 3 i I
12 24 4 tmpA [B
13 17 5 j I
19 23 5 j I
27 31 3 n I
32 36 3 n I
38 42 3 n I
43 47 3 n I
MethodParameters:
Name Flags
in
inOff
private void finish();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=1, args_size=1
start local 0 0: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.byteCount:J
ldc 8
lmul
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.L:[B
iconst_0
invokestatic org.bouncycastle.crypto.util.Pack.longToLittleEndian:(J[BI)V
1: goto 3
2: StackMap locals:
StackMap stack:
aload 0
iconst_0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.update:(B)V
3: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBufOff:I
ifne 2
4: aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.L:[B
iconst_0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.processBlock:([BI)V
5: aload 0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
iconst_0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.processBlock:([BI)V
6: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
public int doFinal(byte[], int);
descriptor: ([BI)I
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.finish:()V
1: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
iconst_0
aload 1
iload 2
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
2: aload 0
invokevirtual org.bouncycastle.crypto.digests.GOST3411Digest.reset:()V
3: bipush 32
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 4 1 out [B
0 4 2 outOff I
MethodParameters:
Name Flags
out
outOff
public void reset();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=2, args_size=1
start local 0 0: aload 0
lconst_0
putfield org.bouncycastle.crypto.digests.GOST3411Digest.byteCount:J
1: aload 0
iconst_0
putfield org.bouncycastle.crypto.digests.GOST3411Digest.xBufOff:I
2: iconst_0
istore 1
start local 1 3: goto 6
4: StackMap locals: int
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
iload 1
iconst_0
bastore
5: iinc 1 1
StackMap locals:
StackMap stack:
6: iload 1
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.H:[B
arraylength
if_icmplt 4
end local 1 7: iconst_0
istore 1
start local 1 8: goto 11
9: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.L:[B
iload 1
iconst_0
bastore
10: iinc 1 1
StackMap locals:
StackMap stack:
11: iload 1
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.L:[B
arraylength
if_icmplt 9
end local 1 12: iconst_0
istore 1
start local 1 13: goto 16
14: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
iload 1
iconst_0
bastore
15: iinc 1 1
StackMap locals:
StackMap stack:
16: iload 1
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.M:[B
arraylength
if_icmplt 14
end local 1 17: iconst_0
istore 1
start local 1 18: goto 21
19: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_1
aaload
iload 1
iconst_0
bastore
20: iinc 1 1
StackMap locals:
StackMap stack:
21: iload 1
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_1
aaload
arraylength
if_icmplt 19
end local 1 22: iconst_0
istore 1
start local 1 23: goto 26
24: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_3
aaload
iload 1
iconst_0
bastore
25: iinc 1 1
StackMap locals:
StackMap stack:
26: iload 1
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_3
aaload
arraylength
if_icmplt 24
end local 1 27: iconst_0
istore 1
start local 1 28: goto 31
29: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
iload 1
iconst_0
bastore
30: iinc 1 1
StackMap locals:
StackMap stack:
31: iload 1
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
arraylength
if_icmplt 29
end local 1 32: iconst_0
istore 1
start local 1 33: goto 36
34: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
iload 1
iconst_0
bastore
35: iinc 1 1
StackMap locals:
StackMap stack:
36: iload 1
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.xBuf:[B
arraylength
if_icmplt 34
end local 1 37: getstatic org.bouncycastle.crypto.digests.GOST3411Digest.C2:[B
iconst_0
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.C:[[B
iconst_2
aaload
iconst_0
getstatic org.bouncycastle.crypto.digests.GOST3411Digest.C2:[B
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
38: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 39 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
3 7 1 i I
8 12 1 i I
13 17 1 i I
18 22 1 i I
23 27 1 i I
28 32 1 i I
33 37 1 i I
private void sumByteArray(byte[]);
descriptor: ([B)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=5, args_size=2
start local 0 start local 1 0: iconst_0
istore 2
start local 2 1: iconst_0
istore 3
start local 3 2: goto 7
3: StackMap locals: int int
StackMap stack:
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
iload 3
baload
sipush 255
iand
aload 1
iload 3
baload
sipush 255
iand
iadd
iload 2
iadd
istore 4
start local 4 4: aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
iload 3
iload 4
i2b
bastore
5: iload 4
bipush 8
iushr
istore 2
end local 4 6: iinc 3 1
StackMap locals:
StackMap stack:
7: iload 3
aload 0
getfield org.bouncycastle.crypto.digests.GOST3411Digest.Sum:[B
arraylength
if_icmpne 3
end local 3 8: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 9 1 in [B
1 9 2 carry I
2 8 3 i I
4 6 4 sum I
MethodParameters:
Name Flags
in
private void cpyBytesToShort(byte[], short[]);
descriptor: ([B[S)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=6, locals=4, args_size=3
start local 0 start local 1 start local 2 0: iconst_0
istore 3
start local 3 1: goto 4
2: StackMap locals: int
StackMap stack:
aload 2
iload 3
aload 1
iload 3
iconst_2
imul
iconst_1
iadd
baload
bipush 8
ishl
ldc 65280
iand
aload 1
iload 3
iconst_2
imul
baload
sipush 255
iand
ior
i2s
sastore
3: iinc 3 1
StackMap locals:
StackMap stack:
4: iload 3
aload 1
arraylength
iconst_2
idiv
if_icmplt 2
end local 3 5: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 6 1 S [B
0 6 2 wS [S
1 5 3 i I
MethodParameters:
Name Flags
S
wS
private void cpyShortToBytes(short[], byte[]);
descriptor: ([S[B)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=4, args_size=3
start local 0 start local 1 start local 2 0: iconst_0
istore 3
start local 3 1: goto 5
2: StackMap locals: int
StackMap stack:
aload 2
iload 3
iconst_2
imul
iconst_1
iadd
aload 1
iload 3
saload
bipush 8
ishr
i2b
bastore
3: aload 2
iload 3
iconst_2
imul
aload 1
iload 3
saload
i2b
bastore
4: iinc 3 1
StackMap locals:
StackMap stack:
5: iload 3
aload 2
arraylength
iconst_2
idiv
if_icmplt 2
end local 3 6: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
0 7 1 wS [S
0 7 2 S [B
1 6 3 i I
MethodParameters:
Name Flags
wS
S
public int getByteLength();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: bipush 32
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/bouncycastle/crypto/digests/GOST3411Digest;
}
SourceFile: "GOST3411Digest.java"