final class com.sun.crypto.provider.OutputFeedback extends com.sun.crypto.provider.FeedbackCipher
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: com.sun.crypto.provider.OutputFeedback
super_class: com.sun.crypto.provider.FeedbackCipher
{
private byte[] k;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
private byte[] register;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
private int numBytes;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private byte[] registerSave;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
void <init>(com.sun.crypto.provider.SymmetricCipher, int);
descriptor: (Lcom/sun/crypto/provider/SymmetricCipher;I)V
flags: (0x0000)
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
invokespecial com.sun.crypto.provider.FeedbackCipher.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;)V
1: aload 0
aconst_null
putfield com.sun.crypto.provider.OutputFeedback.k:[B
2: aload 0
aconst_null
putfield com.sun.crypto.provider.OutputFeedback.register:[B
3: aload 0
aconst_null
putfield com.sun.crypto.provider.OutputFeedback.registerSave:[B
4: iload 2
aload 0
getfield com.sun.crypto.provider.OutputFeedback.blockSize:I
if_icmple 6
5: aload 0
getfield com.sun.crypto.provider.OutputFeedback.blockSize:I
istore 2
6: StackMap locals: com.sun.crypto.provider.OutputFeedback com.sun.crypto.provider.SymmetricCipher int
StackMap stack:
aload 0
iload 2
putfield com.sun.crypto.provider.OutputFeedback.numBytes:I
7: aload 0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.blockSize:I
newarray 8
putfield com.sun.crypto.provider.OutputFeedback.k:[B
8: aload 0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.blockSize:I
newarray 8
putfield com.sun.crypto.provider.OutputFeedback.register:[B
9: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lcom/sun/crypto/provider/OutputFeedback;
0 10 1 embeddedCipher Lcom/sun/crypto/provider/SymmetricCipher;
0 10 2 numBytes I
MethodParameters:
Name Flags
embeddedCipher
numBytes
java.lang.String getFeedback();
descriptor: ()Ljava/lang/String;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: ldc "OFB"
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lcom/sun/crypto/provider/OutputFeedback;
void init(boolean, java.lang.String, byte[], byte[]);
descriptor: (ZLjava/lang/String;[B[B)V
flags: (0x0000)
Code:
stack=4, locals=5, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 3
ifnull 1
aload 4
ifnull 1
aload 4
arraylength
aload 0
getfield com.sun.crypto.provider.OutputFeedback.blockSize:I
if_icmpeq 2
1: StackMap locals:
StackMap stack:
new java.security.InvalidKeyException
dup
ldc "Internal error"
invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
aload 4
putfield com.sun.crypto.provider.OutputFeedback.iv:[B
3: aload 0
invokevirtual com.sun.crypto.provider.OutputFeedback.reset:()V
4: aload 0
getfield com.sun.crypto.provider.OutputFeedback.embeddedCipher:Lcom/sun/crypto/provider/SymmetricCipher;
iconst_0
aload 2
aload 3
invokevirtual com.sun.crypto.provider.SymmetricCipher.init:(ZLjava/lang/String;[B)V
5: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lcom/sun/crypto/provider/OutputFeedback;
0 6 1 decrypting Z
0 6 2 algorithm Ljava/lang/String;
0 6 3 key [B
0 6 4 iv [B
Exceptions:
throws java.security.InvalidKeyException
MethodParameters:
Name Flags
decrypting
algorithm
key
iv
void reset();
descriptor: ()V
flags: (0x0000)
Code:
stack=5, locals=1, args_size=1
start local 0 0: aload 0
getfield com.sun.crypto.provider.OutputFeedback.iv:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.blockSize:I
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lcom/sun/crypto/provider/OutputFeedback;
void save();
descriptor: ()V
flags: (0x0000)
Code:
stack=5, locals=1, args_size=1
start local 0 0: aload 0
getfield com.sun.crypto.provider.OutputFeedback.registerSave:[B
ifnonnull 2
1: aload 0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.blockSize:I
newarray 8
putfield com.sun.crypto.provider.OutputFeedback.registerSave:[B
2: StackMap locals:
StackMap stack:
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.registerSave:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.blockSize:I
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
3: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lcom/sun/crypto/provider/OutputFeedback;
void restore();
descriptor: ()V
flags: (0x0000)
Code:
stack=5, locals=1, args_size=1
start local 0 0: aload 0
getfield com.sun.crypto.provider.OutputFeedback.registerSave:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.blockSize:I
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lcom/sun/crypto/provider/OutputFeedback;
void encrypt(byte[], int, int, byte[], int);
descriptor: ([BII[BI)V
flags: (0x0000)
Code:
stack=6, locals=10, 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 com.sun.crypto.provider.OutputFeedback.blockSize:I
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
isub
istore 7
start local 7 1: iload 3
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
idiv
istore 8
start local 8 2: iload 3
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
irem
istore 9
start local 9 3: iload 7
ifne 40
4: goto 16
5: StackMap locals: com.sun.crypto.provider.OutputFeedback byte[] int int byte[] int top int int int
StackMap stack:
aload 0
getfield com.sun.crypto.provider.OutputFeedback.embeddedCipher:Lcom/sun/crypto/provider/SymmetricCipher;
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iconst_0
invokevirtual com.sun.crypto.provider.SymmetricCipher.encryptBlock:([BI[BI)V
6: iconst_0
istore 6
start local 6 7: goto 12
8: StackMap locals: com.sun.crypto.provider.OutputFeedback byte[] int int byte[] int int int int int
StackMap stack:
aload 4
iload 6
iload 5
iadd
9: aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iload 6
baload
aload 1
iload 6
iload 2
iadd
baload
ixor
i2b
10: bastore
11: iinc 6 1
StackMap locals:
StackMap stack:
12: iload 6
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
if_icmplt 8
13: aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
14: iload 2
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
iadd
istore 2
iload 5
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
iadd
istore 5
15: iinc 8 -1
end local 6 16: StackMap locals: com.sun.crypto.provider.OutputFeedback byte[] int int byte[] int top int int int
StackMap stack:
iload 8
ifgt 5
17: iload 9
ifle 52
18: aload 0
getfield com.sun.crypto.provider.OutputFeedback.embeddedCipher:Lcom/sun/crypto/provider/SymmetricCipher;
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iconst_0
invokevirtual com.sun.crypto.provider.SymmetricCipher.encryptBlock:([BI[BI)V
19: iconst_0
istore 6
start local 6 20: goto 25
21: StackMap locals: com.sun.crypto.provider.OutputFeedback byte[] int int byte[] int int int int int
StackMap stack:
aload 4
iload 6
iload 5
iadd
22: aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iload 6
baload
aload 1
iload 6
iload 2
iadd
baload
ixor
i2b
23: bastore
24: iinc 6 1
StackMap locals:
StackMap stack:
25: iload 6
iload 9
if_icmplt 21
26: aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
end local 6 27: goto 52
28: StackMap locals: com.sun.crypto.provider.OutputFeedback byte[] int int byte[] int top int int int
StackMap stack:
aload 0
getfield com.sun.crypto.provider.OutputFeedback.embeddedCipher:Lcom/sun/crypto/provider/SymmetricCipher;
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iconst_0
invokevirtual com.sun.crypto.provider.SymmetricCipher.encryptBlock:([BI[BI)V
29: iconst_0
istore 6
start local 6 30: goto 35
31: StackMap locals: com.sun.crypto.provider.OutputFeedback byte[] int int byte[] int int int int int
StackMap stack:
aload 4
iload 6
iload 5
iadd
32: aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iload 6
baload
aload 1
iload 6
iload 2
iadd
baload
ixor
i2b
33: bastore
34: iinc 6 1
StackMap locals:
StackMap stack:
35: iload 6
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
if_icmplt 31
36: aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
iload 7
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
37: aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iload 7
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
38: iload 2
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
iadd
istore 2
iload 5
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
iadd
istore 5
39: iinc 8 -1
end local 6 40: StackMap locals: com.sun.crypto.provider.OutputFeedback byte[] int int byte[] int top int int int
StackMap stack:
iload 8
ifgt 28
41: iload 9
ifle 52
42: aload 0
getfield com.sun.crypto.provider.OutputFeedback.embeddedCipher:Lcom/sun/crypto/provider/SymmetricCipher;
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iconst_0
invokevirtual com.sun.crypto.provider.SymmetricCipher.encryptBlock:([BI[BI)V
43: iconst_0
istore 6
start local 6 44: goto 49
45: StackMap locals: com.sun.crypto.provider.OutputFeedback byte[] int int byte[] int int int int int
StackMap stack:
aload 4
iload 6
iload 5
iadd
46: aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iload 6
baload
aload 1
iload 6
iload 2
iadd
baload
ixor
i2b
47: bastore
48: iinc 6 1
StackMap locals:
StackMap stack:
49: iload 6
iload 9
if_icmplt 45
50: aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iconst_0
iload 7
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
51: aload 0
getfield com.sun.crypto.provider.OutputFeedback.k:[B
iconst_0
aload 0
getfield com.sun.crypto.provider.OutputFeedback.register:[B
iload 7
aload 0
getfield com.sun.crypto.provider.OutputFeedback.numBytes:I
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
end local 6 52: StackMap locals: com.sun.crypto.provider.OutputFeedback byte[] int int byte[] int top int int int
StackMap stack:
return
end local 9 end local 8 end local 7 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 53 0 this Lcom/sun/crypto/provider/OutputFeedback;
0 53 1 plain [B
0 53 2 plainOffset I
0 53 3 plainLen I
0 53 4 cipher [B
0 53 5 cipherOffset I
7 16 6 i I
20 27 6 i I
30 40 6 i I
44 52 6 i I
1 53 7 len I
2 53 8 loopCount I
3 53 9 oddBytes I
MethodParameters:
Name Flags
plain
plainOffset
plainLen
cipher
cipherOffset
void decrypt(byte[], int, int, byte[], int);
descriptor: ([BII[BI)V
flags: (0x0000)
Code:
stack=6, 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
aload 1
iload 2
iload 3
aload 4
iload 5
invokevirtual com.sun.crypto.provider.OutputFeedback.encrypt:([BII[BI)V
1: 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 2 0 this Lcom/sun/crypto/provider/OutputFeedback;
0 2 1 cipher [B
0 2 2 cipherOffset I
0 2 3 cipherLen I
0 2 4 plain [B
0 2 5 plainOffset I
MethodParameters:
Name Flags
cipher
cipherOffset
cipherLen
plain
plainOffset
}
SourceFile: "OutputFeedback.java"