public class org.bouncycastle.crypto.digests.SHA512Digest extends org.bouncycastle.crypto.digests.LongDigest
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.crypto.digests.SHA512Digest
  super_class: org.bouncycastle.crypto.digests.LongDigest
{
  private static final int DIGEST_LENGTH;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 64

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
         0: .line 26
            aload 0 /* this */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.<init>:()V
         1: .line 28
            return
        end local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/bouncycastle/crypto/digests/SHA512Digest;

  public void <init>(org.bouncycastle.crypto.digests.SHA512Digest);
    descriptor: (Lorg/bouncycastle/crypto/digests/SHA512Digest;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
        start local 1 // org.bouncycastle.crypto.digests.SHA512Digest t
         0: .line 36
            aload 0 /* this */
            aload 1 /* t */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.<init>:(Lorg/bouncycastle/crypto/digests/LongDigest;)V
         1: .line 37
            return
        end local 1 // org.bouncycastle.crypto.digests.SHA512Digest t
        end local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/bouncycastle/crypto/digests/SHA512Digest;
            0    2     1     t  Lorg/bouncycastle/crypto/digests/SHA512Digest;
    MethodParameters:
      Name  Flags
      t     

  public void <init>(byte[]);
    descriptor: ([B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
        start local 1 // byte[] encodedState
         0: .line 44
            aload 0 /* this */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.<init>:()V
         1: .line 46
            aload 0 /* this */
            aload 1 /* encodedState */
            invokevirtual org.bouncycastle.crypto.digests.SHA512Digest.restoreState:([B)V
         2: .line 47
            return
        end local 1 // byte[] encodedState
        end local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    3     0          this  Lorg/bouncycastle/crypto/digests/SHA512Digest;
            0    3     1  encodedState  [B
    MethodParameters:
              Name  Flags
      encodedState  

  public java.lang.String getAlgorithmName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
         0: .line 51
            ldc "SHA-512"
            areturn
        end local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/crypto/digests/SHA512Digest;

  public int getDigestSize();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
         0: .line 56
            bipush 64
            ireturn
        end local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/crypto/digests/SHA512Digest;

  public int doFinal(byte[], int);
    descriptor: ([BI)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
        start local 1 // byte[] out
        start local 2 // int outOff
         0: .line 63
            aload 0 /* this */
            invokevirtual org.bouncycastle.crypto.digests.SHA512Digest.finish:()V
         1: .line 65
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA512Digest.H1:J
            aload 1 /* out */
            iload 2 /* outOff */
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         2: .line 66
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA512Digest.H2:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 8
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         3: .line 67
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA512Digest.H3:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 16
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         4: .line 68
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA512Digest.H4:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 24
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         5: .line 69
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA512Digest.H5:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 32
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         6: .line 70
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA512Digest.H6:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 40
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         7: .line 71
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA512Digest.H7:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 48
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         8: .line 72
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA512Digest.H8:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 56
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         9: .line 74
            aload 0 /* this */
            invokevirtual org.bouncycastle.crypto.digests.SHA512Digest.reset:()V
        10: .line 76
            bipush 64
            ireturn
        end local 2 // int outOff
        end local 1 // byte[] out
        end local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   11     0    this  Lorg/bouncycastle/crypto/digests/SHA512Digest;
            0   11     1     out  [B
            0   11     2  outOff  I
    MethodParameters:
        Name  Flags
      out     
      outOff  

  public void reset();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
         0: .line 84
            aload 0 /* this */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.reset:()V
         1: .line 90
            aload 0 /* this */
            ldc 7640891576956012808
            putfield org.bouncycastle.crypto.digests.SHA512Digest.H1:J
         2: .line 91
            aload 0 /* this */
            ldc -4942790177534073029
            putfield org.bouncycastle.crypto.digests.SHA512Digest.H2:J
         3: .line 92
            aload 0 /* this */
            ldc 4354685564936845355
            putfield org.bouncycastle.crypto.digests.SHA512Digest.H3:J
         4: .line 93
            aload 0 /* this */
            ldc -6534734903238641935
            putfield org.bouncycastle.crypto.digests.SHA512Digest.H4:J
         5: .line 94
            aload 0 /* this */
            ldc 5840696475078001361
            putfield org.bouncycastle.crypto.digests.SHA512Digest.H5:J
         6: .line 95
            aload 0 /* this */
            ldc -7276294671716946913
            putfield org.bouncycastle.crypto.digests.SHA512Digest.H6:J
         7: .line 96
            aload 0 /* this */
            ldc 2270897969802886507
            putfield org.bouncycastle.crypto.digests.SHA512Digest.H7:J
         8: .line 97
            aload 0 /* this */
            ldc 6620516959819538809
            putfield org.bouncycastle.crypto.digests.SHA512Digest.H8:J
         9: .line 98
            return
        end local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lorg/bouncycastle/crypto/digests/SHA512Digest;

  public org.bouncycastle.util.Memoable copy();
    descriptor: ()Lorg/bouncycastle/util/Memoable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
         0: .line 102
            new org.bouncycastle.crypto.digests.SHA512Digest
            dup
            aload 0 /* this */
            invokespecial org.bouncycastle.crypto.digests.SHA512Digest.<init>:(Lorg/bouncycastle/crypto/digests/SHA512Digest;)V
            areturn
        end local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/crypto/digests/SHA512Digest;

  public void reset(org.bouncycastle.util.Memoable);
    descriptor: (Lorg/bouncycastle/util/Memoable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
        start local 1 // org.bouncycastle.util.Memoable other
         0: .line 107
            aload 1 /* other */
            checkcast org.bouncycastle.crypto.digests.SHA512Digest
            astore 2 /* d */
        start local 2 // org.bouncycastle.crypto.digests.SHA512Digest d
         1: .line 109
            aload 0 /* this */
            aload 2 /* d */
            invokevirtual org.bouncycastle.crypto.digests.SHA512Digest.copyIn:(Lorg/bouncycastle/crypto/digests/LongDigest;)V
         2: .line 110
            return
        end local 2 // org.bouncycastle.crypto.digests.SHA512Digest d
        end local 1 // org.bouncycastle.util.Memoable other
        end local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Lorg/bouncycastle/crypto/digests/SHA512Digest;
            0    3     1  other  Lorg/bouncycastle/util/Memoable;
            1    3     2      d  Lorg/bouncycastle/crypto/digests/SHA512Digest;
    MethodParameters:
       Name  Flags
      other  

  public byte[] getEncodedState();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
         0: .line 114
            aload 0 /* this */
            invokevirtual org.bouncycastle.crypto.digests.SHA512Digest.getEncodedStateSize:()I
            newarray 8
            astore 1 /* encoded */
        start local 1 // byte[] encoded
         1: .line 115
            aload 0 /* this */
            aload 1 /* encoded */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.populateState:([B)V
         2: .line 116
            aload 1 /* encoded */
            areturn
        end local 1 // byte[] encoded
        end local 0 // org.bouncycastle.crypto.digests.SHA512Digest this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lorg/bouncycastle/crypto/digests/SHA512Digest;
            1    3     1  encoded  [B
}
SourceFile: "SHA512Digest.java"