public final class org.apache.cassandra.net.MessagingService implements org.apache.cassandra.net.MessagingServiceMBean
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.apache.cassandra.net.MessagingService
  super_class: java.lang.Object
{
  public static final boolean FORCE_3_0_PROTOCOL_VERSION;
    descriptor: Z
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final java.lang.String MBEAN_NAME;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "org.apache.cassandra.net:type=MessagingService"

  public static final int VERSION_12;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 6

  public static final int VERSION_20;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 7

  public static final int VERSION_21;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 8

  public static final int VERSION_22;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 9

  public static final int VERSION_30;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 10

  public static final int VERSION_3014;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 11

  public static final int current_version;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final java.lang.String FAILURE_CALLBACK_PARAM;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "CAL_BAC"

  public static final byte[] ONE_BYTE;
    descriptor: [B
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final java.lang.String FAILURE_RESPONSE_PARAM;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "FAIL"

  public static final java.lang.String FAILURE_REASON_PARAM;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "FAIL_REASON"

  public static final int PROTOCOL_MAGIC;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: -900387334

  private boolean allNodesAtLeast22;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private boolean allNodesAtLeast30;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  public final org.apache.cassandra.metrics.MessagingMetrics metrics;
    descriptor: Lorg/apache/cassandra/metrics/MessagingMetrics;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  public static final org.apache.cassandra.net.MessagingService$Verb[] verbValues;
    descriptor: [Lorg/apache/cassandra/net/MessagingService$Verb;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final java.util.EnumMap<org.apache.cassandra.net.MessagingService$Verb, org.apache.cassandra.concurrent.Stage> verbStages;
    descriptor: Ljava/util/EnumMap;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/EnumMap<Lorg/apache/cassandra/net/MessagingService$Verb;Lorg/apache/cassandra/concurrent/Stage;>;

  public final java.util.EnumMap<org.apache.cassandra.net.MessagingService$Verb, org.apache.cassandra.io.IVersionedSerializer<?>> verbSerializers;
    descriptor: Ljava/util/EnumMap;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Signature: Ljava/util/EnumMap<Lorg/apache/cassandra/net/MessagingService$Verb;Lorg/apache/cassandra/io/IVersionedSerializer<*>;>;

  public static final java.util.EnumMap<org.apache.cassandra.net.MessagingService$Verb, org.apache.cassandra.io.IVersionedSerializer<?>> callbackDeserializers;
    descriptor: Ljava/util/EnumMap;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/EnumMap<Lorg/apache/cassandra/net/MessagingService$Verb;Lorg/apache/cassandra/io/IVersionedSerializer<*>;>;

  private final org.apache.cassandra.utils.ExpiringMap<java.lang.Integer, org.apache.cassandra.net.CallbackInfo> callbacks;
    descriptor: Lorg/apache/cassandra/utils/ExpiringMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lorg/apache/cassandra/utils/ExpiringMap<Ljava/lang/Integer;Lorg/apache/cassandra/net/CallbackInfo;>;

  private final java.util.Map<org.apache.cassandra.net.MessagingService$Verb, org.apache.cassandra.net.IVerbHandler> verbHandlers;
    descriptor: Ljava/util/Map;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Map<Lorg/apache/cassandra/net/MessagingService$Verb;Lorg/apache/cassandra/net/IVerbHandler;>;

  private final java.util.concurrent.ConcurrentMap<java.net.InetAddress, org.apache.cassandra.net.OutboundTcpConnectionPool> connectionManagers;
    descriptor: Ljava/util/concurrent/ConcurrentMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentMap<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;

  private static final org.slf4j.Logger logger;
    descriptor: Lorg/slf4j/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

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

  private final java.util.List<org.apache.cassandra.net.MessagingService$SocketThread> socketThreads;
    descriptor: Ljava/util/List;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/List<Lorg/apache/cassandra/net/MessagingService$SocketThread;>;

  private final org.apache.cassandra.utils.concurrent.SimpleCondition listenGate;
    descriptor: Lorg/apache/cassandra/utils/concurrent/SimpleCondition;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public static final java.util.EnumSet<org.apache.cassandra.net.MessagingService$Verb> DROPPABLE_VERBS;
    descriptor: Ljava/util/EnumSet;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/EnumSet<Lorg/apache/cassandra/net/MessagingService$Verb;>;

  private final java.util.Map<org.apache.cassandra.net.MessagingService$Verb, org.apache.cassandra.net.MessagingService$DroppedMessages> droppedMessagesMap;
    descriptor: Ljava/util/Map;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Map<Lorg/apache/cassandra/net/MessagingService$Verb;Lorg/apache/cassandra/net/MessagingService$DroppedMessages;>;

  private final java.util.List<org.apache.cassandra.locator.ILatencySubscriber> subscribers;
    descriptor: Ljava/util/List;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/List<Lorg/apache/cassandra/locator/ILatencySubscriber;>;

  private final java.util.concurrent.ConcurrentMap<java.net.InetAddress, java.lang.Integer> versions;
    descriptor: Ljava/util/concurrent/ConcurrentMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentMap<Ljava/net/InetAddress;Ljava/lang/Integer;>;

  private final java.util.Set<org.apache.cassandra.net.IMessageSink> messageSinks;
    descriptor: Ljava/util/Set;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Set<Lorg/apache/cassandra/net/IMessageSink;>;

  private final org.apache.cassandra.net.BackPressureStrategy backPressure;
    descriptor: Lorg/apache/cassandra/net/BackPressureStrategy;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private static final java.util.concurrent.atomic.AtomicInteger idGen;
    descriptor: Ljava/util/concurrent/atomic/AtomicInteger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=0, args_size=0
         0: .line 84
            ldc Lorg/apache/cassandra/net/MessagingService;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
         3: .line 88
            ldc "cassandra.force_3_0_protocol_version"
            invokestatic java.lang.Boolean.getBoolean:(Ljava/lang/String;)Z
            putstatic org.apache.cassandra.net.MessagingService.FORCE_3_0_PROTOCOL_VERSION:Z
         4: .line 99
            getstatic org.apache.cassandra.net.MessagingService.FORCE_3_0_PROTOCOL_VERSION:Z
            ifeq 5
            bipush 10
            goto 6
      StackMap locals:
      StackMap stack:
         5: bipush 11
      StackMap locals:
      StackMap stack: int
         6: putstatic org.apache.cassandra.net.MessagingService.current_version:I
         7: .line 102
            iconst_1
            newarray 8
            putstatic org.apache.cassandra.net.MessagingService.ONE_BYTE:[B
         8: .line 264
            invokestatic org.apache.cassandra.net.MessagingService$Verb.values:()[Lorg/apache/cassandra/net/MessagingService$Verb;
            putstatic org.apache.cassandra.net.MessagingService.verbValues:[Lorg/apache/cassandra/net/MessagingService$Verb;
         9: .line 266
            new org.apache.cassandra.net.MessagingService$1
            dup
            ldc Lorg/apache/cassandra/net/MessagingService$Verb;
            invokespecial org.apache.cassandra.net.MessagingService$1.<init>:(Ljava/lang/Class;)V
            putstatic org.apache.cassandra.net.MessagingService.verbStages:Ljava/util/EnumMap;
        10: .line 358
            new org.apache.cassandra.net.MessagingService$3
            dup
            ldc Lorg/apache/cassandra/net/MessagingService$Verb;
            invokespecial org.apache.cassandra.net.MessagingService$3.<init>:(Ljava/lang/Class;)V
            putstatic org.apache.cassandra.net.MessagingService.callbackDeserializers:Ljava/util/EnumMap;
        11: .line 414
            ldc Lorg/apache/cassandra/net/MessagingService;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
            putstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
        12: .line 425
            getstatic org.apache.cassandra.net.MessagingService$Verb._TRACE:Lorg/apache/cassandra/net/MessagingService$Verb;
            bipush 10
            anewarray org.apache.cassandra.net.MessagingService$Verb
            dup
            iconst_0
        13: .line 426
            getstatic org.apache.cassandra.net.MessagingService$Verb.MUTATION:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
            dup
            iconst_1
        14: .line 427
            getstatic org.apache.cassandra.net.MessagingService$Verb.COUNTER_MUTATION:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
            dup
            iconst_2
        15: .line 428
            getstatic org.apache.cassandra.net.MessagingService$Verb.HINT:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
            dup
            iconst_3
        16: .line 429
            getstatic org.apache.cassandra.net.MessagingService$Verb.READ_REPAIR:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
            dup
            iconst_4
        17: .line 430
            getstatic org.apache.cassandra.net.MessagingService$Verb.READ:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
            dup
            iconst_5
        18: .line 431
            getstatic org.apache.cassandra.net.MessagingService$Verb.RANGE_SLICE:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
            dup
            bipush 6
        19: .line 432
            getstatic org.apache.cassandra.net.MessagingService$Verb.PAGED_RANGE:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
            dup
            bipush 7
        20: .line 433
            getstatic org.apache.cassandra.net.MessagingService$Verb.REQUEST_RESPONSE:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
            dup
            bipush 8
        21: .line 434
            getstatic org.apache.cassandra.net.MessagingService$Verb.BATCH_STORE:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
            dup
            bipush 9
        22: .line 435
            getstatic org.apache.cassandra.net.MessagingService$Verb.BATCH_REMOVE:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
        23: .line 425
            invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;[Ljava/lang/Enum;)Ljava/util/EnumSet;
            putstatic org.apache.cassandra.net.MessagingService.DROPPABLE_VERBS:Ljava/util/EnumSet;
        24: .line 863
            new java.util.concurrent.atomic.AtomicInteger
            dup
            iconst_0
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:(I)V
            putstatic org.apache.cassandra.net.MessagingService.idGen:Ljava/util/concurrent/atomic/AtomicInteger;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void resetDroppedMessagesMap(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.lang.String scope
         0: .line 459
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.droppedMessagesMap:Ljava/util/Map;
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 3
      StackMap locals: org.apache.cassandra.net.MessagingService java.lang.String top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.MessagingService$Verb
            astore 2 /* verb */
        start local 2 // org.apache.cassandra.net.MessagingService$Verb verb
         2: .line 460
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.droppedMessagesMap:Ljava/util/Map;
            aload 2 /* verb */
            new org.apache.cassandra.net.MessagingService$DroppedMessages
            dup
            new org.apache.cassandra.metrics.DroppedMessageMetrics
            dup
            aload 1 /* scope */
            invokedynamic createMetricName(Ljava/lang/String;)Lorg/apache/cassandra/metrics/MetricNameFactory;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/String;)Lorg/apache/cassandra/metrics/CassandraMetricsRegistry$MetricName;
                  org/apache/cassandra/net/MessagingService.lambda$0(Ljava/lang/String;Ljava/lang/String;)Lorg/apache/cassandra/metrics/CassandraMetricsRegistry$MetricName; (6)
                  (Ljava/lang/String;)Lorg/apache/cassandra/metrics/CassandraMetricsRegistry$MetricName;
            invokespecial org.apache.cassandra.metrics.DroppedMessageMetrics.<init>:(Lorg/apache/cassandra/metrics/MetricNameFactory;)V
            invokespecial org.apache.cassandra.net.MessagingService$DroppedMessages.<init>:(Lorg/apache/cassandra/metrics/DroppedMessageMetrics;)V
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // org.apache.cassandra.net.MessagingService$Verb verb
         3: .line 459
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 463
            return
        end local 1 // java.lang.String scope
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lorg/apache/cassandra/net/MessagingService;
            0    5     1  scope  Ljava/lang/String;
            2    3     2   verb  Lorg/apache/cassandra/net/MessagingService$Verb;
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()
    MethodParameters:
       Name  Flags
      scope  

  public static org.apache.cassandra.net.MessagingService instance();
    descriptor: ()Lorg/apache/cassandra/net/MessagingService;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 486
            getstatic org.apache.cassandra.net.MessagingService$MSHandle.instance:Lorg/apache/cassandra/net/MessagingService;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static org.apache.cassandra.net.MessagingService test();
    descriptor: ()Lorg/apache/cassandra/net/MessagingService;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 496
            getstatic org.apache.cassandra.net.MessagingService$MSTestHandle.instance:Lorg/apache/cassandra/net/MessagingService;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>(boolean);
    descriptor: (Z)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=4, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // boolean testOnly
         0: .line 499
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 111
            aload 0 /* this */
            iconst_1
            putfield org.apache.cassandra.net.MessagingService.allNodesAtLeast22:Z
         2: .line 112
            aload 0 /* this */
            iconst_1
            putfield org.apache.cassandra.net.MessagingService.allNodesAtLeast30:Z
         3: .line 114
            aload 0 /* this */
            new org.apache.cassandra.metrics.MessagingMetrics
            dup
            invokespecial org.apache.cassandra.metrics.MessagingMetrics.<init>:()V
            putfield org.apache.cassandra.net.MessagingService.metrics:Lorg/apache/cassandra/metrics/MessagingMetrics;
         4: .line 325
            aload 0 /* this */
            new org.apache.cassandra.net.MessagingService$2
            dup
            aload 0 /* this */
            ldc Lorg/apache/cassandra/net/MessagingService$Verb;
            invokespecial org.apache.cassandra.net.MessagingService$2.<init>:(Lorg/apache/cassandra/net/MessagingService;Ljava/lang/Class;)V
            putfield org.apache.cassandra.net.MessagingService.verbSerializers:Ljava/util/EnumMap;
         5: .line 412
            aload 0 /* this */
            new org.cliffc.high_scale_lib.NonBlockingHashMap
            dup
            invokespecial org.cliffc.high_scale_lib.NonBlockingHashMap.<init>:()V
            putfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
         6: .line 417
            aload 0 /* this */
            invokestatic com.google.common.collect.Lists.newArrayList:()Ljava/util/ArrayList;
            putfield org.apache.cassandra.net.MessagingService.socketThreads:Ljava/util/List;
         7: .line 466
            aload 0 /* this */
            new java.util.EnumMap
            dup
            ldc Lorg/apache/cassandra/net/MessagingService$Verb;
            invokespecial java.util.EnumMap.<init>:(Ljava/lang/Class;)V
            putfield org.apache.cassandra.net.MessagingService.droppedMessagesMap:Ljava/util/Map;
         8: .line 468
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield org.apache.cassandra.net.MessagingService.subscribers:Ljava/util/List;
         9: .line 471
            aload 0 /* this */
            new org.cliffc.high_scale_lib.NonBlockingHashMap
            dup
            invokespecial org.cliffc.high_scale_lib.NonBlockingHashMap.<init>:()V
            putfield org.apache.cassandra.net.MessagingService.versions:Ljava/util/concurrent/ConcurrentMap;
        10: .line 474
            aload 0 /* this */
            new java.util.concurrent.CopyOnWriteArraySet
            dup
            invokespecial java.util.concurrent.CopyOnWriteArraySet.<init>:()V
            putfield org.apache.cassandra.net.MessagingService.messageSinks:Ljava/util/Set;
        11: .line 477
            aload 0 /* this */
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getBackPressureStrategy:()Lorg/apache/cassandra/net/BackPressureStrategy;
            putfield org.apache.cassandra.net.MessagingService.backPressure:Lorg/apache/cassandra/net/BackPressureStrategy;
        12: .line 501
            getstatic org.apache.cassandra.net.MessagingService.DROPPABLE_VERBS:Ljava/util/EnumSet;
            invokevirtual java.util.EnumSet.iterator:()Ljava/util/Iterator;
            astore 3
            goto 15
      StackMap locals: org.apache.cassandra.net.MessagingService int top java.util.Iterator
      StackMap stack:
        13: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.MessagingService$Verb
            astore 2 /* verb */
        start local 2 // org.apache.cassandra.net.MessagingService$Verb verb
        14: .line 502
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.droppedMessagesMap:Ljava/util/Map;
            aload 2 /* verb */
            new org.apache.cassandra.net.MessagingService$DroppedMessages
            dup
            aload 2 /* verb */
            invokespecial org.apache.cassandra.net.MessagingService$DroppedMessages.<init>:(Lorg/apache/cassandra/net/MessagingService$Verb;)V
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // org.apache.cassandra.net.MessagingService$Verb verb
        15: .line 501
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 13
        16: .line 504
            aload 0 /* this */
            new org.apache.cassandra.utils.concurrent.SimpleCondition
            dup
            invokespecial org.apache.cassandra.utils.concurrent.SimpleCondition.<init>:()V
            putfield org.apache.cassandra.net.MessagingService.listenGate:Lorg/apache/cassandra/utils/concurrent/SimpleCondition;
        17: .line 505
            aload 0 /* this */
            new java.util.EnumMap
            dup
            ldc Lorg/apache/cassandra/net/MessagingService$Verb;
            invokespecial java.util.EnumMap.<init>:(Ljava/lang/Class;)V
            putfield org.apache.cassandra.net.MessagingService.verbHandlers:Ljava/util/Map;
        18: .line 506
            iload 1 /* testOnly */
            ifne 21
        19: .line 508
            new org.apache.cassandra.net.MessagingService$4
            dup
            aload 0 /* this */
            invokespecial org.apache.cassandra.net.MessagingService$4.<init>:(Lorg/apache/cassandra/net/MessagingService;)V
            astore 2 /* logDropped */
        start local 2 // java.lang.Runnable logDropped
        20: .line 515
            getstatic org.apache.cassandra.concurrent.ScheduledExecutors.scheduledTasks:Lorg/apache/cassandra/concurrent/DebuggableScheduledThreadPoolExecutor;
            aload 2 /* logDropped */
            ldc 5000
            ldc 5000
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual org.apache.cassandra.concurrent.DebuggableScheduledThreadPoolExecutor.scheduleWithFixedDelay:(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
            pop
        end local 2 // java.lang.Runnable logDropped
        21: .line 518
      StackMap locals: org.apache.cassandra.net.MessagingService int
      StackMap stack:
            new org.apache.cassandra.net.MessagingService$5
            dup
            aload 0 /* this */
            invokespecial org.apache.cassandra.net.MessagingService$5.<init>:(Lorg/apache/cassandra/net/MessagingService;)V
            astore 2 /* timeoutReporter */
        start local 2 // com.google.common.base.Function timeoutReporter
        22: .line 556
            aload 0 /* this */
            new org.apache.cassandra.utils.ExpiringMap
            dup
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getMinRpcTimeout:()J
            aload 2 /* timeoutReporter */
            invokespecial org.apache.cassandra.utils.ExpiringMap.<init>:(JLcom/google/common/base/Function;)V
            putfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
        23: .line 558
            iload 1 /* testOnly */
            ifne 25
        24: .line 560
            getstatic org.apache.cassandra.utils.MBeanWrapper.instance:Lorg/apache/cassandra/utils/MBeanWrapper;
            aload 0 /* this */
            ldc "org.apache.cassandra.net:type=MessagingService"
            invokeinterface org.apache.cassandra.utils.MBeanWrapper.registerMBean:(Ljava/lang/Object;Ljava/lang/String;)V
        25: .line 562
      StackMap locals: com.google.common.base.Function
      StackMap stack:
            return
        end local 2 // com.google.common.base.Function timeoutReporter
        end local 1 // boolean testOnly
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   26     0             this  Lorg/apache/cassandra/net/MessagingService;
            0   26     1         testOnly  Z
           14   15     2             verb  Lorg/apache/cassandra/net/MessagingService$Verb;
           20   21     2       logDropped  Ljava/lang/Runnable;
           22   26     2  timeoutReporter  Lcom/google/common/base/Function<Lorg/apache/cassandra/utils/Pair<Ljava/lang/Integer;Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<Lorg/apache/cassandra/net/CallbackInfo;>;>;*>;
    MethodParameters:
          Name  Flags
      testOnly  

  public void addMessageSink(org.apache.cassandra.net.IMessageSink);
    descriptor: (Lorg/apache/cassandra/net/IMessageSink;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.IMessageSink sink
         0: .line 566
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.messageSinks:Ljava/util/Set;
            aload 1 /* sink */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         1: .line 567
            return
        end local 1 // org.apache.cassandra.net.IMessageSink sink
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/net/MessagingService;
            0    2     1  sink  Lorg/apache/cassandra/net/IMessageSink;
    MethodParameters:
      Name  Flags
      sink  

  public void removeMessageSink(org.apache.cassandra.net.IMessageSink);
    descriptor: (Lorg/apache/cassandra/net/IMessageSink;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.IMessageSink sink
         0: .line 571
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.messageSinks:Ljava/util/Set;
            aload 1 /* sink */
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
         1: .line 572
            return
        end local 1 // org.apache.cassandra.net.IMessageSink sink
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/net/MessagingService;
            0    2     1  sink  Lorg/apache/cassandra/net/IMessageSink;
    MethodParameters:
      Name  Flags
      sink  

  public void clearMessageSinks();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 576
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.messageSinks:Ljava/util/Set;
            invokeinterface java.util.Set.clear:()V
         1: .line 577
            return
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/net/MessagingService;

  public void updateBackPressureOnSend(java.net.InetAddress, org.apache.cassandra.net.IAsyncCallback, org.apache.cassandra.net.MessageOut<?>);
    descriptor: (Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/net/MessageOut;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=4
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress host
        start local 2 // org.apache.cassandra.net.IAsyncCallback callback
        start local 3 // org.apache.cassandra.net.MessageOut message
         0: .line 588
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.backPressureEnabled:()Z
            ifeq 3
            aload 2 /* callback */
            invokeinterface org.apache.cassandra.net.IAsyncCallback.supportsBackPressure:()Z
            ifeq 3
         1: .line 590
            aload 0 /* this */
            aload 1 /* host */
            invokevirtual org.apache.cassandra.net.MessagingService.getConnectionPool:(Ljava/net/InetAddress;)Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.getBackPressureState:()Lorg/apache/cassandra/net/BackPressureState;
            astore 4 /* backPressureState */
        start local 4 // org.apache.cassandra.net.BackPressureState backPressureState
         2: .line 591
            aload 4 /* backPressureState */
            aload 3 /* message */
            invokeinterface org.apache.cassandra.net.BackPressureState.onMessageSent:(Lorg/apache/cassandra/net/MessageOut;)V
        end local 4 // org.apache.cassandra.net.BackPressureState backPressureState
         3: .line 593
      StackMap locals:
      StackMap stack:
            return
        end local 3 // org.apache.cassandra.net.MessageOut message
        end local 2 // org.apache.cassandra.net.IAsyncCallback callback
        end local 1 // java.net.InetAddress host
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    4     0               this  Lorg/apache/cassandra/net/MessagingService;
            0    4     1               host  Ljava/net/InetAddress;
            0    4     2           callback  Lorg/apache/cassandra/net/IAsyncCallback;
            0    4     3            message  Lorg/apache/cassandra/net/MessageOut<*>;
            2    3     4  backPressureState  Lorg/apache/cassandra/net/BackPressureState;
    Signature: (Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/net/MessageOut<*>;)V
    MethodParameters:
          Name  Flags
      host      
      callback  
      message   

  public void updateBackPressureOnReceive(java.net.InetAddress, org.apache.cassandra.net.IAsyncCallback, boolean);
    descriptor: (Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=4
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress host
        start local 2 // org.apache.cassandra.net.IAsyncCallback callback
        start local 3 // boolean timeout
         0: .line 604
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.backPressureEnabled:()Z
            ifeq 5
            aload 2 /* callback */
            invokeinterface org.apache.cassandra.net.IAsyncCallback.supportsBackPressure:()Z
            ifeq 5
         1: .line 606
            aload 0 /* this */
            aload 1 /* host */
            invokevirtual org.apache.cassandra.net.MessagingService.getConnectionPool:(Ljava/net/InetAddress;)Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.getBackPressureState:()Lorg/apache/cassandra/net/BackPressureState;
            astore 4 /* backPressureState */
        start local 4 // org.apache.cassandra.net.BackPressureState backPressureState
         2: .line 607
            iload 3 /* timeout */
            ifne 4
         3: .line 608
            aload 4 /* backPressureState */
            invokeinterface org.apache.cassandra.net.BackPressureState.onResponseReceived:()V
            goto 5
         4: .line 610
      StackMap locals: org.apache.cassandra.net.BackPressureState
      StackMap stack:
            aload 4 /* backPressureState */
            invokeinterface org.apache.cassandra.net.BackPressureState.onResponseTimeout:()V
        end local 4 // org.apache.cassandra.net.BackPressureState backPressureState
         5: .line 612
      StackMap locals:
      StackMap stack:
            return
        end local 3 // boolean timeout
        end local 2 // org.apache.cassandra.net.IAsyncCallback callback
        end local 1 // java.net.InetAddress host
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    6     0               this  Lorg/apache/cassandra/net/MessagingService;
            0    6     1               host  Ljava/net/InetAddress;
            0    6     2           callback  Lorg/apache/cassandra/net/IAsyncCallback;
            0    6     3            timeout  Z
            2    5     4  backPressureState  Lorg/apache/cassandra/net/BackPressureState;
    MethodParameters:
          Name  Flags
      host      
      callback  
      timeout   

  public void applyBackPressure(java.lang.Iterable<java.net.InetAddress>, );
    descriptor: (Ljava/lang/Iterable;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.lang.Iterable hosts
        start local 2 // long timeoutInNanos
         0: .line 625
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.backPressureEnabled:()Z
            ifeq 6
         1: .line 627
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.backPressure:Lorg/apache/cassandra/net/BackPressureStrategy;
            aload 1 /* hosts */
            invokeinterface java.lang.Iterable.spliterator:()Ljava/util/Spliterator;
            iconst_0
            invokestatic java.util.stream.StreamSupport.stream:(Ljava/util/Spliterator;Z)Ljava/util/stream/Stream;
         2: .line 628
            invokedynamic test()Ljava/util/function/Predicate;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)Z
                  org/apache/cassandra/net/MessagingService.lambda$1(Ljava/net/InetAddress;)Z (6)
                  (Ljava/net/InetAddress;)Z
            invokeinterface java.util.stream.Stream.filter:(Ljava/util/function/Predicate;)Ljava/util/stream/Stream;
         3: .line 629
            aload 0 /* this */
            invokedynamic apply(Lorg/apache/cassandra/net/MessagingService;)Ljava/util/function/Function;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)Ljava/lang/Object;
                  org/apache/cassandra/net/MessagingService.lambda$2(Ljava/net/InetAddress;)Lorg/apache/cassandra/net/BackPressureState; (7)
                  (Ljava/net/InetAddress;)Lorg/apache/cassandra/net/BackPressureState;
            invokeinterface java.util.stream.Stream.map:(Ljava/util/function/Function;)Ljava/util/stream/Stream;
         4: .line 630
            invokestatic java.util.stream.Collectors.toSet:()Ljava/util/stream/Collector;
            invokeinterface java.util.stream.Stream.collect:(Ljava/util/stream/Collector;)Ljava/lang/Object;
            checkcast java.util.Set
            lload 2 /* timeoutInNanos */
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
         5: .line 627
            invokeinterface org.apache.cassandra.net.BackPressureStrategy.apply:(Ljava/util/Set;JLjava/util/concurrent/TimeUnit;)V
         6: .line 632
      StackMap locals:
      StackMap stack:
            return
        end local 2 // long timeoutInNanos
        end local 1 // java.lang.Iterable hosts
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    7     0            this  Lorg/apache/cassandra/net/MessagingService;
            0    7     1           hosts  Ljava/lang/Iterable<Ljava/net/InetAddress;>;
            0    7     2  timeoutInNanos  J
    Signature: (Ljava/lang/Iterable<Ljava/net/InetAddress;>;J)V
    MethodParameters:
                Name  Flags
      hosts           
      timeoutInNanos  

  public void maybeAddLatency(org.apache.cassandra.net.IAsyncCallback, java.net.InetAddress, long);
    descriptor: (Lorg/apache/cassandra/net/IAsyncCallback;Ljava/net/InetAddress;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=4
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.IAsyncCallback cb
        start local 2 // java.net.InetAddress address
        start local 3 // long latency
         0: .line 643
            aload 1 /* cb */
            invokeinterface org.apache.cassandra.net.IAsyncCallback.isLatencyForSnitch:()Z
            ifeq 2
         1: .line 644
            aload 0 /* this */
            aload 2 /* address */
            lload 3 /* latency */
            invokevirtual org.apache.cassandra.net.MessagingService.addLatency:(Ljava/net/InetAddress;J)V
         2: .line 645
      StackMap locals:
      StackMap stack:
            return
        end local 3 // long latency
        end local 2 // java.net.InetAddress address
        end local 1 // org.apache.cassandra.net.IAsyncCallback cb
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lorg/apache/cassandra/net/MessagingService;
            0    3     1       cb  Lorg/apache/cassandra/net/IAsyncCallback;
            0    3     2  address  Ljava/net/InetAddress;
            0    3     3  latency  J
    MethodParameters:
         Name  Flags
      cb       
      address  
      latency  

  public void addLatency(java.net.InetAddress, long);
    descriptor: (Ljava/net/InetAddress;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress address
        start local 2 // long latency
         0: .line 649
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.subscribers:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 3
      StackMap locals: org.apache.cassandra.net.MessagingService java.net.InetAddress long top java.util.Iterator
      StackMap stack:
         1: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.locator.ILatencySubscriber
            astore 4 /* subscriber */
        start local 4 // org.apache.cassandra.locator.ILatencySubscriber subscriber
         2: .line 650
            aload 4 /* subscriber */
            aload 1 /* address */
            lload 2 /* latency */
            invokeinterface org.apache.cassandra.locator.ILatencySubscriber.receiveTiming:(Ljava/net/InetAddress;J)V
        end local 4 // org.apache.cassandra.locator.ILatencySubscriber subscriber
         3: .line 649
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 651
            return
        end local 2 // long latency
        end local 1 // java.net.InetAddress address
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    5     0        this  Lorg/apache/cassandra/net/MessagingService;
            0    5     1     address  Ljava/net/InetAddress;
            0    5     2     latency  J
            2    3     4  subscriber  Lorg/apache/cassandra/locator/ILatencySubscriber;
    MethodParameters:
         Name  Flags
      address  
      latency  

  public void convict(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress ep
         0: .line 658
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "Resetting pool for {}"
            aload 1 /* ep */
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
         1: .line 659
            aload 0 /* this */
            aload 1 /* ep */
            invokevirtual org.apache.cassandra.net.MessagingService.getConnectionPool:(Ljava/net/InetAddress;)Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.reset:()V
         2: .line 660
            return
        end local 1 // java.net.InetAddress ep
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/net/MessagingService;
            0    3     1    ep  Ljava/net/InetAddress;
    MethodParameters:
      Name  Flags
      ep    

  public void listen();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 664
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
            invokevirtual org.apache.cassandra.utils.ExpiringMap.reset:()V
         1: .line 665
            aload 0 /* this */
            invokestatic org.apache.cassandra.utils.FBUtilities.getLocalAddress:()Ljava/net/InetAddress;
            invokevirtual org.apache.cassandra.net.MessagingService.listen:(Ljava/net/InetAddress;)V
         2: .line 666
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.shouldListenOnBroadcastAddress:()Z
            ifeq 5
         3: .line 667
            invokestatic org.apache.cassandra.utils.FBUtilities.getLocalAddress:()Ljava/net/InetAddress;
            invokestatic org.apache.cassandra.utils.FBUtilities.getBroadcastAddress:()Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifne 5
         4: .line 669
            aload 0 /* this */
            invokestatic org.apache.cassandra.utils.FBUtilities.getBroadcastAddress:()Ljava/net/InetAddress;
            invokevirtual org.apache.cassandra.net.MessagingService.listen:(Ljava/net/InetAddress;)V
         5: .line 671
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.listenGate:Lorg/apache/cassandra/utils/concurrent/SimpleCondition;
            invokevirtual org.apache.cassandra.utils.concurrent.SimpleCondition.signalAll:()V
         6: .line 672
            return
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/apache/cassandra/net/MessagingService;

  private void listen(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=5, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress localEp
         0: .line 681
            aload 0 /* this */
            aload 1 /* localEp */
            invokevirtual org.apache.cassandra.net.MessagingService.getServerSockets:(Ljava/net/InetAddress;)Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 5
      StackMap locals: org.apache.cassandra.net.MessagingService java.net.InetAddress top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.ServerSocket
            astore 2 /* ss */
        start local 2 // java.net.ServerSocket ss
         2: .line 683
            new org.apache.cassandra.net.MessagingService$SocketThread
            dup
            aload 2 /* ss */
            new java.lang.StringBuilder
            dup
            ldc "ACCEPT-"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* localEp */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial org.apache.cassandra.net.MessagingService$SocketThread.<init>:(Ljava/net/ServerSocket;Ljava/lang/String;)V
            astore 4 /* th */
        start local 4 // org.apache.cassandra.net.MessagingService$SocketThread th
         3: .line 684
            aload 4 /* th */
            invokevirtual org.apache.cassandra.net.MessagingService$SocketThread.start:()V
         4: .line 685
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.socketThreads:Ljava/util/List;
            aload 4 /* th */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 4 // org.apache.cassandra.net.MessagingService$SocketThread th
        end local 2 // java.net.ServerSocket ss
         5: .line 681
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         6: .line 687
            return
        end local 1 // java.net.InetAddress localEp
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lorg/apache/cassandra/net/MessagingService;
            0    7     1  localEp  Ljava/net/InetAddress;
            2    5     2       ss  Ljava/net/ServerSocket;
            3    5     4       th  Lorg/apache/cassandra/net/MessagingService$SocketThread;
    Exceptions:
      throws org.apache.cassandra.exceptions.ConfigurationException
    MethodParameters:
         Name  Flags
      localEp  

  private java.util.List<java.net.ServerSocket> getServerSockets(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=10, locals=7, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress localEp
         0: .line 692
            new java.util.ArrayList
            dup
            iconst_2
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 2 /* ss */
        start local 2 // java.util.List ss
         1: .line 693
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getServerEncryptionOptions:()Lorg/apache/cassandra/config/EncryptionOptions$ServerEncryptionOptions;
            getfield org.apache.cassandra.config.EncryptionOptions$ServerEncryptionOptions.internode_encryption:Lorg/apache/cassandra/config/EncryptionOptions$ServerEncryptionOptions$InternodeEncryption;
            getstatic org.apache.cassandra.config.EncryptionOptions$ServerEncryptionOptions$InternodeEncryption.none:Lorg/apache/cassandra/config/EncryptionOptions$ServerEncryptionOptions$InternodeEncryption;
            if_acmpeq 7
         2: .line 697
            aload 2 /* ss */
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getServerEncryptionOptions:()Lorg/apache/cassandra/config/EncryptionOptions$ServerEncryptionOptions;
            aload 1 /* localEp */
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getSSLStoragePort:()I
            invokestatic org.apache.cassandra.security.SSLFactory.getServerSocket:(Lorg/apache/cassandra/config/EncryptionOptions;Ljava/net/InetAddress;I)Ljavax/net/ssl/SSLServerSocket;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         3: .line 698
            goto 6
         4: .line 699
      StackMap locals: org.apache.cassandra.net.MessagingService java.net.InetAddress java.util.List
      StackMap stack: java.io.IOException
            astore 3 /* e */
        start local 3 // java.io.IOException e
         5: .line 701
            new org.apache.cassandra.exceptions.ConfigurationException
            dup
            ldc "Unable to create ssl socket"
            aload 3 /* e */
            invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.io.IOException e
         6: .line 704
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "Starting Encrypted Messaging Service on SSL port {}"
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getSSLStoragePort:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;Ljava/lang/Object;)V
         7: .line 707
      StackMap locals:
      StackMap stack:
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getServerEncryptionOptions:()Lorg/apache/cassandra/config/EncryptionOptions$ServerEncryptionOptions;
            getfield org.apache.cassandra.config.EncryptionOptions$ServerEncryptionOptions.internode_encryption:Lorg/apache/cassandra/config/EncryptionOptions$ServerEncryptionOptions$InternodeEncryption;
            getstatic org.apache.cassandra.config.EncryptionOptions$ServerEncryptionOptions$InternodeEncryption.all:Lorg/apache/cassandra/config/EncryptionOptions$ServerEncryptionOptions$InternodeEncryption;
            if_acmpeq 41
         8: .line 709
            aconst_null
            astore 3 /* serverChannel */
        start local 3 // java.nio.channels.ServerSocketChannel serverChannel
         9: .line 712
            invokestatic java.nio.channels.ServerSocketChannel.open:()Ljava/nio/channels/ServerSocketChannel;
            astore 3 /* serverChannel */
        10: .line 713
            goto 13
        11: .line 714
      StackMap locals: org.apache.cassandra.net.MessagingService java.net.InetAddress java.util.List java.nio.channels.ServerSocketChannel
      StackMap stack: java.io.IOException
            astore 4 /* e */
        start local 4 // java.io.IOException e
        12: .line 716
            new java.lang.RuntimeException
            dup
            aload 4 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.io.IOException e
        13: .line 718
      StackMap locals:
      StackMap stack:
            aload 3 /* serverChannel */
            invokevirtual java.nio.channels.ServerSocketChannel.socket:()Ljava/net/ServerSocket;
            astore 4 /* socket */
        start local 4 // java.net.ServerSocket socket
        14: .line 721
            aload 4 /* socket */
            iconst_1
            invokevirtual java.net.ServerSocket.setReuseAddress:(Z)V
        15: .line 722
            goto 19
        16: .line 723
      StackMap locals: org.apache.cassandra.net.MessagingService java.net.InetAddress java.util.List java.nio.channels.ServerSocketChannel java.net.ServerSocket
      StackMap stack: java.net.SocketException
            astore 5 /* e */
        start local 5 // java.net.SocketException e
        17: .line 725
            aload 4 /* socket */
            invokestatic org.apache.cassandra.io.util.FileUtils.closeQuietly:(Ljava/io/Closeable;)V
        18: .line 726
            new org.apache.cassandra.exceptions.ConfigurationException
            dup
            ldc "Insufficient permissions to setReuseAddress"
            aload 5 /* e */
            invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.net.SocketException e
        19: .line 728
      StackMap locals:
      StackMap stack:
            new java.net.InetSocketAddress
            dup
            aload 1 /* localEp */
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getStoragePort:()I
            invokespecial java.net.InetSocketAddress.<init>:(Ljava/net/InetAddress;I)V
            astore 5 /* address */
        start local 5 // java.net.InetSocketAddress address
        20: .line 731
            aload 4 /* socket */
            aload 5 /* address */
            sipush 500
            invokevirtual java.net.ServerSocket.bind:(Ljava/net/SocketAddress;I)V
        21: .line 732
            goto 34
        22: .line 733
      StackMap locals: org.apache.cassandra.net.MessagingService java.net.InetAddress java.util.List java.nio.channels.ServerSocketChannel java.net.ServerSocket java.net.InetSocketAddress
      StackMap stack: java.net.BindException
            astore 6 /* e */
        start local 6 // java.net.BindException e
        23: .line 735
            aload 4 /* socket */
            invokestatic org.apache.cassandra.io.util.FileUtils.closeQuietly:(Ljava/io/Closeable;)V
        24: .line 736
            aload 6 /* e */
            invokevirtual java.net.BindException.getMessage:()Ljava/lang/String;
            ldc "in use"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 26
        25: .line 737
            new org.apache.cassandra.exceptions.ConfigurationException
            dup
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 5 /* address */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " is in use by another process.  Change listen_address:storage_port in cassandra.yaml to values that do not conflict with other services"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;)V
            athrow
        26: .line 738
      StackMap locals: java.net.BindException
      StackMap stack:
            aload 6 /* e */
            invokevirtual java.net.BindException.getMessage:()Ljava/lang/String;
            ldc "Cannot assign requested address"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 30
        27: .line 739
            new org.apache.cassandra.exceptions.ConfigurationException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unable to bind to address "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* address */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        28: .line 740
            ldc ". Set listen_address in cassandra.yaml to an interface you can bind to, e.g., your private IP address on EC2"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        29: .line 739
            invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;)V
            athrow
        30: .line 742
      StackMap locals:
      StackMap stack:
            new java.lang.RuntimeException
            dup
            aload 6 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 6 // java.net.BindException e
        31: .line 744
      StackMap locals: org.apache.cassandra.net.MessagingService java.net.InetAddress java.util.List java.nio.channels.ServerSocketChannel java.net.ServerSocket java.net.InetSocketAddress
      StackMap stack: java.io.IOException
            astore 6 /* e */
        start local 6 // java.io.IOException e
        32: .line 746
            aload 4 /* socket */
            invokestatic org.apache.cassandra.io.util.FileUtils.closeQuietly:(Ljava/io/Closeable;)V
        33: .line 747
            new java.lang.RuntimeException
            dup
            aload 6 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 6 // java.io.IOException e
        34: .line 749
      StackMap locals:
      StackMap stack:
            aload 1 /* localEp */
            invokestatic org.apache.cassandra.utils.FBUtilities.getNetworkInterface:(Ljava/net/InetAddress;)Ljava/lang/String;
            astore 6 /* nic */
        start local 6 // java.lang.String nic
        35: .line 750
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "Starting Messaging Service on {}:{}{}"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* localEp */
            aastore
            dup
            iconst_1
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getStoragePort:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_2
        36: .line 751
            aload 6 /* nic */
            ifnonnull 37
            ldc ""
            goto 38
      StackMap locals: org.apache.cassandra.net.MessagingService java.net.InetAddress java.util.List java.nio.channels.ServerSocketChannel java.net.ServerSocket java.net.InetSocketAddress java.lang.String
      StackMap stack: org.slf4j.Logger java.lang.String java.lang.Object[] java.lang.Object[] int
        37: ldc " (%s)"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 6 /* nic */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
      StackMap locals: org.apache.cassandra.net.MessagingService java.net.InetAddress java.util.List java.nio.channels.ServerSocketChannel java.net.ServerSocket java.net.InetSocketAddress java.lang.String
      StackMap stack: org.slf4j.Logger java.lang.String java.lang.Object[] java.lang.Object[] int java.lang.String
        38: aastore
        39: .line 750
            invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
        40: .line 752
            aload 2 /* ss */
            aload 4 /* socket */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 6 // java.lang.String nic
        end local 5 // java.net.InetSocketAddress address
        end local 4 // java.net.ServerSocket socket
        end local 3 // java.nio.channels.ServerSocketChannel serverChannel
        41: .line 754
      StackMap locals: org.apache.cassandra.net.MessagingService java.net.InetAddress java.util.List
      StackMap stack:
            aload 2 /* ss */
            areturn
        end local 2 // java.util.List ss
        end local 1 // java.net.InetAddress localEp
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   42     0           this  Lorg/apache/cassandra/net/MessagingService;
            0   42     1        localEp  Ljava/net/InetAddress;
            1   42     2             ss  Ljava/util/List<Ljava/net/ServerSocket;>;
            5    6     3              e  Ljava/io/IOException;
            9   41     3  serverChannel  Ljava/nio/channels/ServerSocketChannel;
           12   13     4              e  Ljava/io/IOException;
           14   41     4         socket  Ljava/net/ServerSocket;
           17   19     5              e  Ljava/net/SocketException;
           20   41     5        address  Ljava/net/InetSocketAddress;
           23   31     6              e  Ljava/net/BindException;
           32   34     6              e  Ljava/io/IOException;
           35   41     6            nic  Ljava/lang/String;
      Exception table:
        from    to  target  type
           2     3       4  Class java.io.IOException
           9    10      11  Class java.io.IOException
          14    15      16  Class java.net.SocketException
          20    21      22  Class java.net.BindException
          20    21      31  Class java.io.IOException
    Exceptions:
      throws org.apache.cassandra.exceptions.ConfigurationException
    Signature: (Ljava/net/InetAddress;)Ljava/util/List<Ljava/net/ServerSocket;>;
    MethodParameters:
         Name  Flags
      localEp  

  public void waitUntilListening();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 761
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.listenGate:Lorg/apache/cassandra/utils/concurrent/SimpleCondition;
            invokevirtual org.apache.cassandra.utils.concurrent.SimpleCondition.await:()V
         1: .line 762
            goto 4
         2: .line 763
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
            pop
         3: .line 765
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "await interrupted"
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;)V
         4: .line 767
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/apache/cassandra/net/MessagingService;
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.InterruptedException

  public boolean isListening();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 771
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.listenGate:Lorg/apache/cassandra/utils/concurrent/SimpleCondition;
            invokevirtual org.apache.cassandra.utils.concurrent.SimpleCondition.isSignaled:()Z
            ireturn
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/net/MessagingService;

  public void destroyConnectionPool(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress to
         0: .line 776
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* to */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            astore 2 /* cp */
        start local 2 // org.apache.cassandra.net.OutboundTcpConnectionPool cp
         1: .line 777
            aload 2 /* cp */
            ifnonnull 3
         2: .line 778
            return
         3: .line 779
      StackMap locals: org.apache.cassandra.net.OutboundTcpConnectionPool
      StackMap stack:
            aload 2 /* cp */
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.close:()V
         4: .line 780
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* to */
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         5: .line 781
            return
        end local 2 // org.apache.cassandra.net.OutboundTcpConnectionPool cp
        end local 1 // java.net.InetAddress to
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/apache/cassandra/net/MessagingService;
            0    6     1    to  Ljava/net/InetAddress;
            1    6     2    cp  Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
    MethodParameters:
      Name  Flags
      to    

  public org.apache.cassandra.net.OutboundTcpConnectionPool getConnectionPool(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress to
         0: .line 785
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* to */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            astore 2 /* cp */
        start local 2 // org.apache.cassandra.net.OutboundTcpConnectionPool cp
         1: .line 786
            aload 2 /* cp */
            ifnonnull 7
         2: .line 788
            new org.apache.cassandra.net.OutboundTcpConnectionPool
            dup
            aload 1 /* to */
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.backPressure:Lorg/apache/cassandra/net/BackPressureStrategy;
            aload 1 /* to */
            invokeinterface org.apache.cassandra.net.BackPressureStrategy.newState:(Ljava/net/InetAddress;)Lorg/apache/cassandra/net/BackPressureState;
            invokespecial org.apache.cassandra.net.OutboundTcpConnectionPool.<init>:(Ljava/net/InetAddress;Lorg/apache/cassandra/net/BackPressureState;)V
            astore 2 /* cp */
         3: .line 789
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* to */
            aload 2 /* cp */
            invokeinterface java.util.concurrent.ConcurrentMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            astore 3 /* existingPool */
        start local 3 // org.apache.cassandra.net.OutboundTcpConnectionPool existingPool
         4: .line 790
            aload 3 /* existingPool */
            ifnull 6
         5: .line 791
            aload 3 /* existingPool */
            astore 2 /* cp */
            goto 7
         6: .line 793
      StackMap locals: org.apache.cassandra.net.OutboundTcpConnectionPool org.apache.cassandra.net.OutboundTcpConnectionPool
      StackMap stack:
            aload 2 /* cp */
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.start:()V
        end local 3 // org.apache.cassandra.net.OutboundTcpConnectionPool existingPool
         7: .line 795
      StackMap locals:
      StackMap stack:
            aload 2 /* cp */
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.waitForStarted:()V
         8: .line 796
            aload 2 /* cp */
            areturn
        end local 2 // org.apache.cassandra.net.OutboundTcpConnectionPool cp
        end local 1 // java.net.InetAddress to
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    9     0          this  Lorg/apache/cassandra/net/MessagingService;
            0    9     1            to  Ljava/net/InetAddress;
            1    9     2            cp  Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
            4    7     3  existingPool  Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
    MethodParameters:
      Name  Flags
      to    

  public org.apache.cassandra.net.OutboundTcpConnection getConnection(java.net.InetAddress, org.apache.cassandra.net.MessageOut);
    descriptor: (Ljava/net/InetAddress;Lorg/apache/cassandra/net/MessageOut;)Lorg/apache/cassandra/net/OutboundTcpConnection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress to
        start local 2 // org.apache.cassandra.net.MessageOut msg
         0: .line 802
            aload 0 /* this */
            aload 1 /* to */
            invokevirtual org.apache.cassandra.net.MessagingService.getConnectionPool:(Ljava/net/InetAddress;)Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
            aload 2 /* msg */
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.getConnection:(Lorg/apache/cassandra/net/MessageOut;)Lorg/apache/cassandra/net/OutboundTcpConnection;
            areturn
        end local 2 // org.apache.cassandra.net.MessageOut msg
        end local 1 // java.net.InetAddress to
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/net/MessagingService;
            0    1     1    to  Ljava/net/InetAddress;
            0    1     2   msg  Lorg/apache/cassandra/net/MessageOut;
    MethodParameters:
      Name  Flags
      to    
      msg   

  public void registerVerbHandlers(org.apache.cassandra.net.MessagingService$Verb, org.apache.cassandra.net.IVerbHandler);
    descriptor: (Lorg/apache/cassandra/net/MessagingService$Verb;Lorg/apache/cassandra/net/IVerbHandler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessagingService$Verb verb
        start local 2 // org.apache.cassandra.net.IVerbHandler verbHandler
         0: .line 814
            getstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.verbHandlers:Ljava/util/Map;
            aload 1 /* verb */
            invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
            ifeq 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 815
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.verbHandlers:Ljava/util/Map;
            aload 1 /* verb */
            aload 2 /* verbHandler */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 816
            return
        end local 2 // org.apache.cassandra.net.IVerbHandler verbHandler
        end local 1 // org.apache.cassandra.net.MessagingService$Verb verb
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    3     0         this  Lorg/apache/cassandra/net/MessagingService;
            0    3     1         verb  Lorg/apache/cassandra/net/MessagingService$Verb;
            0    3     2  verbHandler  Lorg/apache/cassandra/net/IVerbHandler;
    MethodParameters:
             Name  Flags
      verb         
      verbHandler  

  public org.apache.cassandra.net.IVerbHandler getVerbHandler(org.apache.cassandra.net.MessagingService$Verb);
    descriptor: (Lorg/apache/cassandra/net/MessagingService$Verb;)Lorg/apache/cassandra/net/IVerbHandler;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessagingService$Verb type
         0: .line 827
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.verbHandlers:Ljava/util/Map;
            aload 1 /* type */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.IVerbHandler
            areturn
        end local 1 // org.apache.cassandra.net.MessagingService$Verb type
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/net/MessagingService;
            0    1     1  type  Lorg/apache/cassandra/net/MessagingService$Verb;
    MethodParameters:
      Name  Flags
      type  

  public int addCallback(org.apache.cassandra.net.IAsyncCallback, org.apache.cassandra.net.MessageOut, java.net.InetAddress, long, boolean);
    descriptor: (Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;JZ)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=9, args_size=6
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.IAsyncCallback cb
        start local 2 // org.apache.cassandra.net.MessageOut message
        start local 3 // java.net.InetAddress to
        start local 4 // long timeout
        start local 6 // boolean failureCallback
         0: .line 832
            getstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
            ifne 1
            aload 2 /* message */
            getfield org.apache.cassandra.net.MessageOut.verb:Lorg/apache/cassandra/net/MessagingService$Verb;
            getstatic org.apache.cassandra.net.MessagingService$Verb.MUTATION:Lorg/apache/cassandra/net/MessagingService$Verb;
            if_acmpne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 833
      StackMap locals:
      StackMap stack:
            invokestatic org.apache.cassandra.net.MessagingService.nextId:()I
            istore 7 /* messageId */
        start local 7 // int messageId
         2: .line 834
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
            iload 7 /* messageId */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            new org.apache.cassandra.net.CallbackInfo
            dup
            aload 3 /* to */
            aload 1 /* cb */
            getstatic org.apache.cassandra.net.MessagingService.callbackDeserializers:Ljava/util/EnumMap;
            aload 2 /* message */
            getfield org.apache.cassandra.net.MessageOut.verb:Lorg/apache/cassandra/net/MessagingService$Verb;
            invokevirtual java.util.EnumMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.io.IVersionedSerializer
            iload 6 /* failureCallback */
            invokespecial org.apache.cassandra.net.CallbackInfo.<init>:(Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/io/IVersionedSerializer;Z)V
            lload 4 /* timeout */
            invokevirtual org.apache.cassandra.utils.ExpiringMap.put:(Ljava/lang/Object;Ljava/lang/Object;J)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.CallbackInfo
            astore 8 /* previous */
        start local 8 // org.apache.cassandra.net.CallbackInfo previous
         3: .line 835
            getstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
            ifne 4
            aload 8 /* previous */
            ifnull 4
            new java.lang.AssertionError
            dup
            ldc "Callback already exists for id %d! (%s)"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            iload 7 /* messageId */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_1
            aload 8 /* previous */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         4: .line 836
      StackMap locals: int org.apache.cassandra.net.CallbackInfo
      StackMap stack:
            iload 7 /* messageId */
            ireturn
        end local 8 // org.apache.cassandra.net.CallbackInfo previous
        end local 7 // int messageId
        end local 6 // boolean failureCallback
        end local 4 // long timeout
        end local 3 // java.net.InetAddress to
        end local 2 // org.apache.cassandra.net.MessageOut message
        end local 1 // org.apache.cassandra.net.IAsyncCallback cb
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    5     0             this  Lorg/apache/cassandra/net/MessagingService;
            0    5     1               cb  Lorg/apache/cassandra/net/IAsyncCallback;
            0    5     2          message  Lorg/apache/cassandra/net/MessageOut;
            0    5     3               to  Ljava/net/InetAddress;
            0    5     4          timeout  J
            0    5     6  failureCallback  Z
            2    5     7        messageId  I
            3    5     8         previous  Lorg/apache/cassandra/net/CallbackInfo;
    MethodParameters:
                 Name  Flags
      cb               
      message          
      to               
      timeout          
      failureCallback  

  public int addCallback(org.apache.cassandra.net.IAsyncCallback, org.apache.cassandra.net.MessageOut<?>, java.net.InetAddress, long, org.apache.cassandra.db.ConsistencyLevel, );
    descriptor: (Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;JLorg/apache/cassandra/db/ConsistencyLevel;Z)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=10, locals=10, args_size=7
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.IAsyncCallback cb
        start local 2 // org.apache.cassandra.net.MessageOut message
        start local 3 // java.net.InetAddress to
        start local 4 // long timeout
        start local 6 // org.apache.cassandra.db.ConsistencyLevel consistencyLevel
        start local 7 // boolean allowHints
         0: .line 846
            getstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
            ifne 3
            aload 2 /* message */
            getfield org.apache.cassandra.net.MessageOut.verb:Lorg/apache/cassandra/net/MessagingService$Verb;
            getstatic org.apache.cassandra.net.MessagingService$Verb.MUTATION:Lorg/apache/cassandra/net/MessagingService$Verb;
            if_acmpeq 3
         1: .line 847
            aload 2 /* message */
            getfield org.apache.cassandra.net.MessageOut.verb:Lorg/apache/cassandra/net/MessagingService$Verb;
            getstatic org.apache.cassandra.net.MessagingService$Verb.COUNTER_MUTATION:Lorg/apache/cassandra/net/MessagingService$Verb;
            if_acmpeq 3
         2: .line 848
            aload 2 /* message */
            getfield org.apache.cassandra.net.MessageOut.verb:Lorg/apache/cassandra/net/MessagingService$Verb;
            getstatic org.apache.cassandra.net.MessagingService$Verb.PAXOS_COMMIT:Lorg/apache/cassandra/net/MessagingService$Verb;
            if_acmpeq 3
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         3: .line 849
      StackMap locals:
      StackMap stack:
            invokestatic org.apache.cassandra.net.MessagingService.nextId:()I
            istore 8 /* messageId */
        start local 8 // int messageId
         4: .line 851
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
            iload 8 /* messageId */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
         5: .line 852
            new org.apache.cassandra.net.WriteCallbackInfo
            dup
            aload 3 /* to */
         6: .line 853
            aload 1 /* cb */
         7: .line 854
            aload 2 /* message */
         8: .line 855
            getstatic org.apache.cassandra.net.MessagingService.callbackDeserializers:Ljava/util/EnumMap;
            aload 2 /* message */
            getfield org.apache.cassandra.net.MessageOut.verb:Lorg/apache/cassandra/net/MessagingService$Verb;
            invokevirtual java.util.EnumMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.io.IVersionedSerializer
         9: .line 856
            aload 6 /* consistencyLevel */
        10: .line 857
            iload 7 /* allowHints */
        11: .line 852
            invokespecial org.apache.cassandra.net.WriteCallbackInfo.<init>:(Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/net/MessageOut;Lorg/apache/cassandra/io/IVersionedSerializer;Lorg/apache/cassandra/db/ConsistencyLevel;Z)V
        12: .line 858
            lload 4 /* timeout */
        13: .line 851
            invokevirtual org.apache.cassandra.utils.ExpiringMap.put:(Ljava/lang/Object;Ljava/lang/Object;J)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.CallbackInfo
            astore 9 /* previous */
        start local 9 // org.apache.cassandra.net.CallbackInfo previous
        14: .line 859
            getstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
            ifne 15
            aload 9 /* previous */
            ifnull 15
            new java.lang.AssertionError
            dup
            ldc "Callback already exists for id %d! (%s)"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            iload 8 /* messageId */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_1
            aload 9 /* previous */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        15: .line 860
      StackMap locals: int org.apache.cassandra.net.CallbackInfo
      StackMap stack:
            iload 8 /* messageId */
            ireturn
        end local 9 // org.apache.cassandra.net.CallbackInfo previous
        end local 8 // int messageId
        end local 7 // boolean allowHints
        end local 6 // org.apache.cassandra.db.ConsistencyLevel consistencyLevel
        end local 4 // long timeout
        end local 3 // java.net.InetAddress to
        end local 2 // org.apache.cassandra.net.MessageOut message
        end local 1 // org.apache.cassandra.net.IAsyncCallback cb
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   16     0              this  Lorg/apache/cassandra/net/MessagingService;
            0   16     1                cb  Lorg/apache/cassandra/net/IAsyncCallback;
            0   16     2           message  Lorg/apache/cassandra/net/MessageOut<*>;
            0   16     3                to  Ljava/net/InetAddress;
            0   16     4           timeout  J
            0   16     6  consistencyLevel  Lorg/apache/cassandra/db/ConsistencyLevel;
            0   16     7        allowHints  Z
            4   16     8         messageId  I
           14   16     9          previous  Lorg/apache/cassandra/net/CallbackInfo;
    Signature: (Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/net/MessageOut<*>;Ljava/net/InetAddress;JLorg/apache/cassandra/db/ConsistencyLevel;Z)I
    MethodParameters:
                  Name  Flags
      cb                
      message           
      to                
      timeout           
      consistencyLevel  
      allowHints        

  private static int nextId();
    descriptor: ()I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 867
            getstatic org.apache.cassandra.net.MessagingService.idGen:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.incrementAndGet:()I
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public int sendRR(org.apache.cassandra.net.MessageOut, java.net.InetAddress, org.apache.cassandra.net.IAsyncCallback);
    descriptor: (Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=4
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessageOut message
        start local 2 // java.net.InetAddress to
        start local 3 // org.apache.cassandra.net.IAsyncCallback cb
         0: .line 872
            aload 0 /* this */
            aload 1 /* message */
            aload 2 /* to */
            aload 3 /* cb */
            aload 1 /* message */
            invokevirtual org.apache.cassandra.net.MessageOut.getTimeout:()J
            iconst_0
            invokevirtual org.apache.cassandra.net.MessagingService.sendRR:(Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;JZ)I
            ireturn
        end local 3 // org.apache.cassandra.net.IAsyncCallback cb
        end local 2 // java.net.InetAddress to
        end local 1 // org.apache.cassandra.net.MessageOut message
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0     this  Lorg/apache/cassandra/net/MessagingService;
            0    1     1  message  Lorg/apache/cassandra/net/MessageOut;
            0    1     2       to  Ljava/net/InetAddress;
            0    1     3       cb  Lorg/apache/cassandra/net/IAsyncCallback;
    MethodParameters:
         Name  Flags
      message  
      to       
      cb       

  public int sendRRWithFailure(org.apache.cassandra.net.MessageOut, java.net.InetAddress, org.apache.cassandra.net.IAsyncCallbackWithFailure);
    descriptor: (Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallbackWithFailure;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=4
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessageOut message
        start local 2 // java.net.InetAddress to
        start local 3 // org.apache.cassandra.net.IAsyncCallbackWithFailure cb
         0: .line 877
            aload 0 /* this */
            aload 1 /* message */
            aload 2 /* to */
            aload 3 /* cb */
            aload 1 /* message */
            invokevirtual org.apache.cassandra.net.MessageOut.getTimeout:()J
            iconst_1
            invokevirtual org.apache.cassandra.net.MessagingService.sendRR:(Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;JZ)I
            ireturn
        end local 3 // org.apache.cassandra.net.IAsyncCallbackWithFailure cb
        end local 2 // java.net.InetAddress to
        end local 1 // org.apache.cassandra.net.MessageOut message
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0     this  Lorg/apache/cassandra/net/MessagingService;
            0    1     1  message  Lorg/apache/cassandra/net/MessageOut;
            0    1     2       to  Ljava/net/InetAddress;
            0    1     3       cb  Lorg/apache/cassandra/net/IAsyncCallbackWithFailure;
    MethodParameters:
         Name  Flags
      message  
      to       
      cb       

  public int sendRR(org.apache.cassandra.net.MessageOut, java.net.InetAddress, org.apache.cassandra.net.IAsyncCallback, long, boolean);
    descriptor: (Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;JZ)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=8, args_size=6
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessageOut message
        start local 2 // java.net.InetAddress to
        start local 3 // org.apache.cassandra.net.IAsyncCallback cb
        start local 4 // long timeout
        start local 6 // boolean failureCallback
         0: .line 893
            aload 0 /* this */
            aload 3 /* cb */
            aload 1 /* message */
            aload 2 /* to */
            lload 4 /* timeout */
            iload 6 /* failureCallback */
            invokevirtual org.apache.cassandra.net.MessagingService.addCallback:(Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;JZ)I
            istore 7 /* id */
        start local 7 // int id
         1: .line 894
            aload 0 /* this */
            aload 2 /* to */
            aload 3 /* cb */
            aload 1 /* message */
            invokevirtual org.apache.cassandra.net.MessagingService.updateBackPressureOnSend:(Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/net/MessageOut;)V
         2: .line 895
            aload 0 /* this */
            iload 6 /* failureCallback */
            ifeq 3
            aload 1 /* message */
            ldc "CAL_BAC"
            getstatic org.apache.cassandra.net.MessagingService.ONE_BYTE:[B
            invokevirtual org.apache.cassandra.net.MessageOut.withParameter:(Ljava/lang/String;[B)Lorg/apache/cassandra/net/MessageOut;
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService org.apache.cassandra.net.MessageOut java.net.InetAddress org.apache.cassandra.net.IAsyncCallback long int int
      StackMap stack: org.apache.cassandra.net.MessagingService
         3: aload 1 /* message */
      StackMap locals: org.apache.cassandra.net.MessagingService org.apache.cassandra.net.MessageOut java.net.InetAddress org.apache.cassandra.net.IAsyncCallback long int int
      StackMap stack: org.apache.cassandra.net.MessagingService org.apache.cassandra.net.MessageOut
         4: iload 7 /* id */
            aload 2 /* to */
            invokevirtual org.apache.cassandra.net.MessagingService.sendOneWay:(Lorg/apache/cassandra/net/MessageOut;ILjava/net/InetAddress;)V
         5: .line 896
            iload 7 /* id */
            ireturn
        end local 7 // int id
        end local 6 // boolean failureCallback
        end local 4 // long timeout
        end local 3 // org.apache.cassandra.net.IAsyncCallback cb
        end local 2 // java.net.InetAddress to
        end local 1 // org.apache.cassandra.net.MessageOut message
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    6     0             this  Lorg/apache/cassandra/net/MessagingService;
            0    6     1          message  Lorg/apache/cassandra/net/MessageOut;
            0    6     2               to  Ljava/net/InetAddress;
            0    6     3               cb  Lorg/apache/cassandra/net/IAsyncCallback;
            0    6     4          timeout  J
            0    6     6  failureCallback  Z
            1    6     7               id  I
    MethodParameters:
                 Name  Flags
      message          
      to               
      cb               
      timeout          
      failureCallback  

  public int sendRR(org.apache.cassandra.net.MessageOut<?>, java.net.InetAddress, org.apache.cassandra.service.AbstractWriteResponseHandler<?>, );
    descriptor: (Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;Lorg/apache/cassandra/service/AbstractWriteResponseHandler;Z)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=6, args_size=5
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessageOut message
        start local 2 // java.net.InetAddress to
        start local 3 // org.apache.cassandra.service.AbstractWriteResponseHandler handler
        start local 4 // boolean allowHints
         0: .line 916
            aload 0 /* this */
            aload 3 /* handler */
            aload 1 /* message */
            aload 2 /* to */
            aload 1 /* message */
            invokevirtual org.apache.cassandra.net.MessageOut.getTimeout:()J
            aload 3 /* handler */
            getfield org.apache.cassandra.service.AbstractWriteResponseHandler.consistencyLevel:Lorg/apache/cassandra/db/ConsistencyLevel;
            iload 4 /* allowHints */
            invokevirtual org.apache.cassandra.net.MessagingService.addCallback:(Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;JLorg/apache/cassandra/db/ConsistencyLevel;Z)I
            istore 5 /* id */
        start local 5 // int id
         1: .line 917
            aload 0 /* this */
            aload 2 /* to */
            aload 3 /* handler */
            aload 1 /* message */
            invokevirtual org.apache.cassandra.net.MessagingService.updateBackPressureOnSend:(Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;Lorg/apache/cassandra/net/MessageOut;)V
         2: .line 918
            aload 0 /* this */
            aload 1 /* message */
            ldc "CAL_BAC"
            getstatic org.apache.cassandra.net.MessagingService.ONE_BYTE:[B
            invokevirtual org.apache.cassandra.net.MessageOut.withParameter:(Ljava/lang/String;[B)Lorg/apache/cassandra/net/MessageOut;
            iload 5 /* id */
            aload 2 /* to */
            invokevirtual org.apache.cassandra.net.MessagingService.sendOneWay:(Lorg/apache/cassandra/net/MessageOut;ILjava/net/InetAddress;)V
         3: .line 919
            iload 5 /* id */
            ireturn
        end local 5 // int id
        end local 4 // boolean allowHints
        end local 3 // org.apache.cassandra.service.AbstractWriteResponseHandler handler
        end local 2 // java.net.InetAddress to
        end local 1 // org.apache.cassandra.net.MessageOut message
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        this  Lorg/apache/cassandra/net/MessagingService;
            0    4     1     message  Lorg/apache/cassandra/net/MessageOut<*>;
            0    4     2          to  Ljava/net/InetAddress;
            0    4     3     handler  Lorg/apache/cassandra/service/AbstractWriteResponseHandler<*>;
            0    4     4  allowHints  Z
            1    4     5          id  I
    Signature: (Lorg/apache/cassandra/net/MessageOut<*>;Ljava/net/InetAddress;Lorg/apache/cassandra/service/AbstractWriteResponseHandler<*>;Z)I
    MethodParameters:
            Name  Flags
      message     
      to          
      handler     
      allowHints  

  public void sendOneWay(org.apache.cassandra.net.MessageOut, java.net.InetAddress);
    descriptor: (Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessageOut message
        start local 2 // java.net.InetAddress to
         0: .line 924
            aload 0 /* this */
            aload 1 /* message */
            invokestatic org.apache.cassandra.net.MessagingService.nextId:()I
            aload 2 /* to */
            invokevirtual org.apache.cassandra.net.MessagingService.sendOneWay:(Lorg/apache/cassandra/net/MessageOut;ILjava/net/InetAddress;)V
         1: .line 925
            return
        end local 2 // java.net.InetAddress to
        end local 1 // org.apache.cassandra.net.MessageOut message
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/apache/cassandra/net/MessagingService;
            0    2     1  message  Lorg/apache/cassandra/net/MessageOut;
            0    2     2       to  Ljava/net/InetAddress;
    MethodParameters:
         Name  Flags
      message  
      to       

  public void sendReply(org.apache.cassandra.net.MessageOut, int, java.net.InetAddress);
    descriptor: (Lorg/apache/cassandra/net/MessageOut;ILjava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessageOut message
        start local 2 // int id
        start local 3 // java.net.InetAddress to
         0: .line 929
            aload 0 /* this */
            aload 1 /* message */
            iload 2 /* id */
            aload 3 /* to */
            invokevirtual org.apache.cassandra.net.MessagingService.sendOneWay:(Lorg/apache/cassandra/net/MessageOut;ILjava/net/InetAddress;)V
         1: .line 930
            return
        end local 3 // java.net.InetAddress to
        end local 2 // int id
        end local 1 // org.apache.cassandra.net.MessageOut message
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/apache/cassandra/net/MessagingService;
            0    2     1  message  Lorg/apache/cassandra/net/MessageOut;
            0    2     2       id  I
            0    2     3       to  Ljava/net/InetAddress;
    MethodParameters:
         Name  Flags
      message  
      id       
      to       

  public void sendOneWay(org.apache.cassandra.net.MessageOut, int, java.net.InetAddress);
    descriptor: (Lorg/apache/cassandra/net/MessageOut;ILjava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=6, args_size=4
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessageOut message
        start local 2 // int id
        start local 3 // java.net.InetAddress to
         0: .line 941
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            invokeinterface org.slf4j.Logger.isTraceEnabled:()Z
            ifeq 2
         1: .line 942
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "{} sending {} to {}@{}"
            iconst_4
            anewarray java.lang.Object
            dup
            iconst_0
            invokestatic org.apache.cassandra.utils.FBUtilities.getBroadcastAddress:()Ljava/net/InetAddress;
            aastore
            dup
            iconst_1
            aload 1 /* message */
            getfield org.apache.cassandra.net.MessageOut.verb:Lorg/apache/cassandra/net/MessagingService$Verb;
            aastore
            dup
            iconst_2
            iload 2 /* id */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_3
            aload 3 /* to */
            aastore
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;[Ljava/lang/Object;)V
         2: .line 944
      StackMap locals:
      StackMap stack:
            aload 3 /* to */
            invokestatic org.apache.cassandra.utils.FBUtilities.getBroadcastAddress:()Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifeq 4
         3: .line 945
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "Message-to-self {} going over MessagingService"
            aload 1 /* message */
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
         4: .line 948
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.messageSinks:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5
            goto 8
      StackMap locals: org.apache.cassandra.net.MessagingService org.apache.cassandra.net.MessageOut int java.net.InetAddress top java.util.Iterator
      StackMap stack:
         5: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.IMessageSink
            astore 4 /* ms */
        start local 4 // org.apache.cassandra.net.IMessageSink ms
         6: .line 949
            aload 4 /* ms */
            aload 1 /* message */
            iload 2 /* id */
            aload 3 /* to */
            invokeinterface org.apache.cassandra.net.IMessageSink.allowOutgoingMessage:(Lorg/apache/cassandra/net/MessageOut;ILjava/net/InetAddress;)Z
            ifne 8
         7: .line 950
            return
        end local 4 // org.apache.cassandra.net.IMessageSink ms
         8: .line 948
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         9: .line 953
            aload 0 /* this */
            aload 3 /* to */
            aload 1 /* message */
            invokevirtual org.apache.cassandra.net.MessagingService.getConnection:(Ljava/net/InetAddress;Lorg/apache/cassandra/net/MessageOut;)Lorg/apache/cassandra/net/OutboundTcpConnection;
            astore 4 /* connection */
        start local 4 // org.apache.cassandra.net.OutboundTcpConnection connection
        10: .line 956
            aload 4 /* connection */
            aload 1 /* message */
            iload 2 /* id */
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.enqueue:(Lorg/apache/cassandra/net/MessageOut;I)V
        11: .line 957
            return
        end local 4 // org.apache.cassandra.net.OutboundTcpConnection connection
        end local 3 // java.net.InetAddress to
        end local 2 // int id
        end local 1 // org.apache.cassandra.net.MessageOut message
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   12     0        this  Lorg/apache/cassandra/net/MessagingService;
            0   12     1     message  Lorg/apache/cassandra/net/MessageOut;
            0   12     2          id  I
            0   12     3          to  Ljava/net/InetAddress;
            6    8     4          ms  Lorg/apache/cassandra/net/IMessageSink;
           10   12     4  connection  Lorg/apache/cassandra/net/OutboundTcpConnection;
    MethodParameters:
         Name  Flags
      message  
      id       
      to       

  public <T> org.apache.cassandra.net.AsyncOneResponse<T> sendRR(org.apache.cassandra.net.MessageOut, java.net.InetAddress);
    descriptor: (Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;)Lorg/apache/cassandra/net/AsyncOneResponse;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessageOut message
        start local 2 // java.net.InetAddress to
         0: .line 961
            new org.apache.cassandra.net.AsyncOneResponse
            dup
            invokespecial org.apache.cassandra.net.AsyncOneResponse.<init>:()V
            astore 3 /* iar */
        start local 3 // org.apache.cassandra.net.AsyncOneResponse iar
         1: .line 962
            aload 0 /* this */
            aload 1 /* message */
            aload 2 /* to */
            aload 3 /* iar */
            invokevirtual org.apache.cassandra.net.MessagingService.sendRR:(Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;)I
            pop
         2: .line 963
            aload 3 /* iar */
            areturn
        end local 3 // org.apache.cassandra.net.AsyncOneResponse iar
        end local 2 // java.net.InetAddress to
        end local 1 // org.apache.cassandra.net.MessageOut message
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lorg/apache/cassandra/net/MessagingService;
            0    3     1  message  Lorg/apache/cassandra/net/MessageOut;
            0    3     2       to  Ljava/net/InetAddress;
            1    3     3      iar  Lorg/apache/cassandra/net/AsyncOneResponse<TT;>;
    Signature: <T:Ljava/lang/Object;>(Lorg/apache/cassandra/net/MessageOut;Ljava/net/InetAddress;)Lorg/apache/cassandra/net/AsyncOneResponse<TT;>;
    MethodParameters:
         Name  Flags
      message  
      to       

  public void register(org.apache.cassandra.locator.ILatencySubscriber);
    descriptor: (Lorg/apache/cassandra/locator/ILatencySubscriber;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.locator.ILatencySubscriber subcriber
         0: .line 968
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.subscribers:Ljava/util/List;
            aload 1 /* subcriber */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         1: .line 969
            return
        end local 1 // org.apache.cassandra.locator.ILatencySubscriber subcriber
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/apache/cassandra/net/MessagingService;
            0    2     1  subcriber  Lorg/apache/cassandra/locator/ILatencySubscriber;
    MethodParameters:
           Name  Flags
      subcriber  

  public void clearCallbacksUnsafe();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 973
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
            invokevirtual org.apache.cassandra.utils.ExpiringMap.reset:()V
         1: .line 974
            return
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/net/MessagingService;

  public void shutdown();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 981
            aload 0 /* this */
            iconst_1
            invokevirtual org.apache.cassandra.net.MessagingService.shutdown:(Z)V
         1: .line 982
            return
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/net/MessagingService;

  public void shutdown(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // boolean gracefully
         0: .line 985
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "Waiting for messaging service to quiesce"
            invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;)V
         1: .line 987
            getstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
            ifne 2
            getstatic org.apache.cassandra.concurrent.Stage.MUTATION:Lorg/apache/cassandra/concurrent/Stage;
            invokestatic org.apache.cassandra.concurrent.StageManager.getStage:(Lorg/apache/cassandra/concurrent/Stage;)Lorg/apache/cassandra/concurrent/LocalAwareExecutorService;
            invokeinterface org.apache.cassandra.concurrent.LocalAwareExecutorService.isShutdown:()Z
            ifeq 2
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 990
      StackMap locals:
      StackMap stack:
            iload 1 /* gracefully */
            ifne 4
         3: .line 991
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
            invokevirtual org.apache.cassandra.utils.ExpiringMap.reset:()V
         4: .line 993
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
            invokevirtual org.apache.cassandra.utils.ExpiringMap.shutdownBlocking:()Z
            ifne 6
         5: .line 994
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "Failed to wait for messaging service callbacks shutdown"
            invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;)V
         6: .line 999
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.cassandra.net.MessagingService.clearMessageSinks:()V
         7: .line 1000
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.socketThreads:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 13
      StackMap locals: org.apache.cassandra.net.MessagingService int top java.util.Iterator
      StackMap stack:
         8: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.MessagingService$SocketThread
            astore 2 /* th */
        start local 2 // org.apache.cassandra.net.MessagingService$SocketThread th
         9: .line 1004
            aload 2 /* th */
            invokevirtual org.apache.cassandra.net.MessagingService$SocketThread.close:()V
        10: .line 1005
            goto 13
        11: .line 1006
      StackMap locals: org.apache.cassandra.net.MessagingService int org.apache.cassandra.net.MessagingService$SocketThread java.util.Iterator
      StackMap stack: java.io.IOException
            astore 4 /* e */
        start local 4 // java.io.IOException e
        12: .line 1009
            aload 4 /* e */
            invokestatic org.apache.cassandra.net.MessagingService.handleIOExceptionOnClose:(Ljava/io/IOException;)V
        end local 4 // java.io.IOException e
        end local 2 // org.apache.cassandra.net.MessagingService$SocketThread th
        13: .line 1000
      StackMap locals: org.apache.cassandra.net.MessagingService int top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 8
        14: .line 1012
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.values:()Ljava/util/Collection;
            invokedynamic accept()Ljava/util/function/Consumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)V
                  org/apache/cassandra/net/OutboundTcpConnectionPool.close()V (5)
                  (Lorg/apache/cassandra/net/OutboundTcpConnectionPool;)V
            invokeinterface java.util.Collection.forEach:(Ljava/util/function/Consumer;)V
        15: .line 1013
            goto 18
        16: .line 1014
      StackMap locals: org.apache.cassandra.net.MessagingService int
      StackMap stack: java.io.IOException
            astore 2 /* e */
        start local 2 // java.io.IOException e
        17: .line 1016
            new java.io.IOError
            dup
            aload 2 /* e */
            invokespecial java.io.IOError.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.io.IOException e
        18: .line 1018
      StackMap locals:
      StackMap stack:
            return
        end local 1 // boolean gracefully
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   19     0        this  Lorg/apache/cassandra/net/MessagingService;
            0   19     1  gracefully  Z
            9   13     2          th  Lorg/apache/cassandra/net/MessagingService$SocketThread;
           12   13     4           e  Ljava/io/IOException;
           17   18     2           e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           9    10      11  Class java.io.IOException
           6    15      16  Class java.io.IOException
    MethodParameters:
            Name  Flags
      gracefully  

  public void receive(org.apache.cassandra.net.MessageIn, int);
    descriptor: (Lorg/apache/cassandra/net/MessageIn;I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessageIn message
        start local 2 // int id
         0: .line 1022
            getstatic org.apache.cassandra.tracing.Tracing.instance:Lorg/apache/cassandra/tracing/Tracing;
            aload 1 /* message */
            invokevirtual org.apache.cassandra.tracing.Tracing.initializeFromMessage:(Lorg/apache/cassandra/net/MessageIn;)Lorg/apache/cassandra/tracing/TraceState;
            astore 3 /* state */
        start local 3 // org.apache.cassandra.tracing.TraceState state
         1: .line 1023
            aload 3 /* state */
            ifnull 3
         2: .line 1024
            aload 3 /* state */
            ldc "{} message received from {}"
            aload 1 /* message */
            getfield org.apache.cassandra.net.MessageIn.verb:Lorg/apache/cassandra/net/MessagingService$Verb;
            aload 1 /* message */
            getfield org.apache.cassandra.net.MessageIn.from:Ljava/net/InetAddress;
            invokevirtual org.apache.cassandra.tracing.TraceState.trace:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         3: .line 1027
      StackMap locals: org.apache.cassandra.tracing.TraceState
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.messageSinks:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5
            goto 7
      StackMap locals: org.apache.cassandra.net.MessagingService org.apache.cassandra.net.MessageIn int org.apache.cassandra.tracing.TraceState top java.util.Iterator
      StackMap stack:
         4: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.IMessageSink
            astore 4 /* ms */
        start local 4 // org.apache.cassandra.net.IMessageSink ms
         5: .line 1028
            aload 4 /* ms */
            aload 1 /* message */
            iload 2 /* id */
            invokeinterface org.apache.cassandra.net.IMessageSink.allowIncomingMessage:(Lorg/apache/cassandra/net/MessageIn;I)Z
            ifne 7
         6: .line 1029
            return
        end local 4 // org.apache.cassandra.net.IMessageSink ms
         7: .line 1027
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         8: .line 1031
            new org.apache.cassandra.net.MessageDeliveryTask
            dup
            aload 1 /* message */
            iload 2 /* id */
            invokespecial org.apache.cassandra.net.MessageDeliveryTask.<init>:(Lorg/apache/cassandra/net/MessageIn;I)V
            astore 4 /* runnable */
        start local 4 // java.lang.Runnable runnable
         9: .line 1032
            aload 1 /* message */
            invokevirtual org.apache.cassandra.net.MessageIn.getMessageType:()Lorg/apache/cassandra/concurrent/Stage;
            invokestatic org.apache.cassandra.concurrent.StageManager.getStage:(Lorg/apache/cassandra/concurrent/Stage;)Lorg/apache/cassandra/concurrent/LocalAwareExecutorService;
            astore 5 /* stage */
        start local 5 // org.apache.cassandra.concurrent.LocalAwareExecutorService stage
        10: .line 1033
            getstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
            ifne 11
            aload 5 /* stage */
            ifnonnull 11
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "No stage for message type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* message */
            getfield org.apache.cassandra.net.MessageIn.verb:Lorg/apache/cassandra/net/MessagingService$Verb;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        11: .line 1035
      StackMap locals: org.apache.cassandra.net.MessagingService org.apache.cassandra.net.MessageIn int org.apache.cassandra.tracing.TraceState java.lang.Runnable org.apache.cassandra.concurrent.LocalAwareExecutorService
      StackMap stack:
            aload 5 /* stage */
            aload 4 /* runnable */
            aload 3 /* state */
            invokestatic org.apache.cassandra.concurrent.ExecutorLocals.create:(Lorg/apache/cassandra/tracing/TraceState;)Lorg/apache/cassandra/concurrent/ExecutorLocals;
            invokeinterface org.apache.cassandra.concurrent.LocalAwareExecutorService.execute:(Ljava/lang/Runnable;Lorg/apache/cassandra/concurrent/ExecutorLocals;)V
        12: .line 1036
            return
        end local 5 // org.apache.cassandra.concurrent.LocalAwareExecutorService stage
        end local 4 // java.lang.Runnable runnable
        end local 3 // org.apache.cassandra.tracing.TraceState state
        end local 2 // int id
        end local 1 // org.apache.cassandra.net.MessageIn message
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   13     0      this  Lorg/apache/cassandra/net/MessagingService;
            0   13     1   message  Lorg/apache/cassandra/net/MessageIn;
            0   13     2        id  I
            1   13     3     state  Lorg/apache/cassandra/tracing/TraceState;
            5    7     4        ms  Lorg/apache/cassandra/net/IMessageSink;
            9   13     4  runnable  Ljava/lang/Runnable;
           10   13     5     stage  Lorg/apache/cassandra/concurrent/LocalAwareExecutorService;
    MethodParameters:
         Name  Flags
      message  
      id       

  public void setCallbackForTests(int, org.apache.cassandra.net.CallbackInfo);
    descriptor: (ILorg/apache/cassandra/net/CallbackInfo;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // int messageId
        start local 2 // org.apache.cassandra.net.CallbackInfo callback
         0: .line 1040
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
            iload 1 /* messageId */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aload 2 /* callback */
            invokevirtual org.apache.cassandra.utils.ExpiringMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 1041
            return
        end local 2 // org.apache.cassandra.net.CallbackInfo callback
        end local 1 // int messageId
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/apache/cassandra/net/MessagingService;
            0    2     1  messageId  I
            0    2     2   callback  Lorg/apache/cassandra/net/CallbackInfo;
    MethodParameters:
           Name  Flags
      messageId  
      callback   

  public org.apache.cassandra.net.CallbackInfo getRegisteredCallback(int);
    descriptor: (I)Lorg/apache/cassandra/net/CallbackInfo;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // int messageId
         0: .line 1045
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
            iload 1 /* messageId */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.apache.cassandra.utils.ExpiringMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.CallbackInfo
            areturn
        end local 1 // int messageId
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lorg/apache/cassandra/net/MessagingService;
            0    1     1  messageId  I
    MethodParameters:
           Name  Flags
      messageId  

  public org.apache.cassandra.net.CallbackInfo removeRegisteredCallback(int);
    descriptor: (I)Lorg/apache/cassandra/net/CallbackInfo;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // int messageId
         0: .line 1050
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
            iload 1 /* messageId */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.apache.cassandra.utils.ExpiringMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.CallbackInfo
            areturn
        end local 1 // int messageId
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lorg/apache/cassandra/net/MessagingService;
            0    1     1  messageId  I
    MethodParameters:
           Name  Flags
      messageId  

  public long getRegisteredCallbackAge(int);
    descriptor: (I)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // int messageId
         0: .line 1058
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.callbacks:Lorg/apache/cassandra/utils/ExpiringMap;
            iload 1 /* messageId */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.apache.cassandra.utils.ExpiringMap.getAge:(Ljava/lang/Object;)J
            lreturn
        end local 1 // int messageId
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lorg/apache/cassandra/net/MessagingService;
            0    1     1  messageId  I
    MethodParameters:
           Name  Flags
      messageId  

  public static void validateMagic(int);
    descriptor: (I)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // int magic
         0: .line 1063
            iload 0 /* magic */
            ldc -900387334
            if_icmpeq 2
         1: .line 1064
            new java.io.IOException
            dup
            ldc "invalid protocol header"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 1065
      StackMap locals:
      StackMap stack:
            return
        end local 0 // int magic
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0  magic  I
    Exceptions:
      throws java.io.IOException
    MethodParameters:
       Name  Flags
      magic  

  public static int getBits(int, int, int);
    descriptor: (III)I
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // int packed
        start local 1 // int start
        start local 2 // int count
         0: .line 1069
            iload 0 /* packed */
            iload 1 /* start */
            iconst_1
            iadd
            iload 2 /* count */
            isub
            iushr
            iconst_m1
            iload 2 /* count */
            ishl
            iconst_m1
            ixor
            iand
            ireturn
        end local 2 // int count
        end local 1 // int start
        end local 0 // int packed
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0  packed  I
            0    1     1   start  I
            0    1     2   count  I
    MethodParameters:
        Name  Flags
      packed  
      start   
      count   

  public boolean areAllNodesAtLeast22();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1074
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.allNodesAtLeast22:Z
            ireturn
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/net/MessagingService;

  public boolean areAllNodesAtLeast30();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1079
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.allNodesAtLeast30:Z
            ireturn
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/net/MessagingService;

  public int setVersion(java.net.InetAddress, int);
    descriptor: (Ljava/net/InetAddress;I)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress endpoint
        start local 2 // int version
         0: .line 1087
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "Setting version {} for {}"
            iload 2 /* version */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aload 1 /* endpoint */
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         1: .line 1089
            iload 2 /* version */
            bipush 9
            if_icmpge 3
         2: .line 1090
            aload 0 /* this */
            iconst_0
            putfield org.apache.cassandra.net.MessagingService.allNodesAtLeast22:Z
         3: .line 1091
      StackMap locals:
      StackMap stack:
            iload 2 /* version */
            bipush 10
            if_icmpge 5
         4: .line 1092
            aload 0 /* this */
            iconst_0
            putfield org.apache.cassandra.net.MessagingService.allNodesAtLeast30:Z
         5: .line 1094
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.versions:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* endpoint */
            iload 2 /* version */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 3 /* v */
        start local 3 // java.lang.Integer v
         6: .line 1097
            aload 3 /* v */
            ifnull 8
            aload 3 /* v */
            invokevirtual java.lang.Integer.intValue:()I
            bipush 10
            if_icmpge 8
            iload 2 /* version */
            bipush 9
            if_icmplt 8
         7: .line 1098
            aload 0 /* this */
            invokevirtual org.apache.cassandra.net.MessagingService.refreshAllNodeMinVersions:()V
         8: .line 1100
      StackMap locals: java.lang.Integer
      StackMap stack:
            aload 3 /* v */
            ifnonnull 9
            iload 2 /* version */
            goto 10
      StackMap locals:
      StackMap stack:
         9: aload 3 /* v */
            invokevirtual java.lang.Integer.intValue:()I
      StackMap locals:
      StackMap stack: int
        10: ireturn
        end local 3 // java.lang.Integer v
        end local 2 // int version
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   11     0      this  Lorg/apache/cassandra/net/MessagingService;
            0   11     1  endpoint  Ljava/net/InetAddress;
            0   11     2   version  I
            6   11     3         v  Ljava/lang/Integer;
    MethodParameters:
          Name  Flags
      endpoint  
      version   

  public void resetVersion(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress endpoint
         0: .line 1105
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "Resetting version for {}"
            aload 1 /* endpoint */
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
         1: .line 1106
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.versions:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* endpoint */
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 2 /* removed */
        start local 2 // java.lang.Integer removed
         2: .line 1107
            aload 2 /* removed */
            ifnull 4
            aload 2 /* removed */
            invokevirtual java.lang.Integer.intValue:()I
            getstatic org.apache.cassandra.net.MessagingService.current_version:I
            invokestatic java.lang.Math.min:(II)I
            bipush 10
            if_icmpgt 4
         3: .line 1108
            aload 0 /* this */
            invokevirtual org.apache.cassandra.net.MessagingService.refreshAllNodeMinVersions:()V
         4: .line 1109
      StackMap locals: java.lang.Integer
      StackMap stack:
            return
        end local 2 // java.lang.Integer removed
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lorg/apache/cassandra/net/MessagingService;
            0    5     1  endpoint  Ljava/net/InetAddress;
            2    5     2   removed  Ljava/lang/Integer;
    MethodParameters:
          Name  Flags
      endpoint  

  private void refreshAllNodeMinVersions();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1113
            iconst_0
            istore 1 /* anyNodeLowerThan30 */
        start local 1 // boolean anyNodeLowerThan30
         1: .line 1114
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.versions:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 9
      StackMap locals: org.apache.cassandra.net.MessagingService int top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 2 /* version */
        start local 2 // java.lang.Integer version
         3: .line 1116
            aload 2 /* version */
            invokevirtual java.lang.Integer.intValue:()I
            bipush 10
            if_icmpge 6
         4: .line 1118
            iconst_1
            istore 1 /* anyNodeLowerThan30 */
         5: .line 1119
            aload 0 /* this */
            iconst_0
            putfield org.apache.cassandra.net.MessagingService.allNodesAtLeast30:Z
         6: .line 1122
      StackMap locals: org.apache.cassandra.net.MessagingService int java.lang.Integer java.util.Iterator
      StackMap stack:
            aload 2 /* version */
            invokevirtual java.lang.Integer.intValue:()I
            bipush 9
            if_icmpge 9
         7: .line 1124
            aload 0 /* this */
            iconst_0
            putfield org.apache.cassandra.net.MessagingService.allNodesAtLeast22:Z
         8: .line 1125
            return
        end local 2 // java.lang.Integer version
         9: .line 1114
      StackMap locals: org.apache.cassandra.net.MessagingService int top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        10: .line 1128
            aload 0 /* this */
            iconst_1
            putfield org.apache.cassandra.net.MessagingService.allNodesAtLeast22:Z
        11: .line 1129
            aload 0 /* this */
            iload 1 /* anyNodeLowerThan30 */
            ifeq 12
            iconst_0
            goto 13
      StackMap locals: org.apache.cassandra.net.MessagingService int
      StackMap stack: org.apache.cassandra.net.MessagingService
        12: iconst_1
      StackMap locals: org.apache.cassandra.net.MessagingService int
      StackMap stack: org.apache.cassandra.net.MessagingService int
        13: putfield org.apache.cassandra.net.MessagingService.allNodesAtLeast30:Z
        14: .line 1130
            return
        end local 1 // boolean anyNodeLowerThan30
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   15     0                this  Lorg/apache/cassandra/net/MessagingService;
            1   15     1  anyNodeLowerThan30  Z
            3    9     2             version  Ljava/lang/Integer;

  public int getVersion(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress endpoint
         0: .line 1138
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.versions:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* endpoint */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 2 /* v */
        start local 2 // java.lang.Integer v
         1: .line 1139
            aload 2 /* v */
            ifnonnull 4
         2: .line 1142
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            ldc "Assuming current protocol version for {}"
            aload 1 /* endpoint */
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
         3: .line 1143
            getstatic org.apache.cassandra.net.MessagingService.current_version:I
            ireturn
         4: .line 1146
      StackMap locals: java.lang.Integer
      StackMap stack:
            aload 2 /* v */
            invokevirtual java.lang.Integer.intValue:()I
            getstatic org.apache.cassandra.net.MessagingService.current_version:I
            invokestatic java.lang.Math.min:(II)I
            ireturn
        end local 2 // java.lang.Integer v
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lorg/apache/cassandra/net/MessagingService;
            0    5     1  endpoint  Ljava/net/InetAddress;
            1    5     2         v  Ljava/lang/Integer;
    MethodParameters:
          Name  Flags
      endpoint  

  public int getVersion(java.lang.String);
    descriptor: (Ljava/lang/String;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.lang.String endpoint
         0: .line 1151
            aload 0 /* this */
            aload 1 /* endpoint */
            invokestatic java.net.InetAddress.getByName:(Ljava/lang/String;)Ljava/net/InetAddress;
            invokevirtual org.apache.cassandra.net.MessagingService.getVersion:(Ljava/net/InetAddress;)I
            ireturn
        end local 1 // java.lang.String endpoint
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lorg/apache/cassandra/net/MessagingService;
            0    1     1  endpoint  Ljava/lang/String;
    Exceptions:
      throws java.net.UnknownHostException
    MethodParameters:
          Name  Flags
      endpoint  

  public int getRawVersion(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress endpoint
         0: .line 1159
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.versions:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* endpoint */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 2 /* v */
        start local 2 // java.lang.Integer v
         1: .line 1160
            aload 2 /* v */
            ifnonnull 3
         2: .line 1161
            new java.lang.IllegalStateException
            dup
            ldc "getRawVersion() was called without checking knowsVersion() result first"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 1162
      StackMap locals: java.lang.Integer
      StackMap stack:
            aload 2 /* v */
            invokevirtual java.lang.Integer.intValue:()I
            ireturn
        end local 2 // java.lang.Integer v
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0      this  Lorg/apache/cassandra/net/MessagingService;
            0    4     1  endpoint  Ljava/net/InetAddress;
            1    4     2         v  Ljava/lang/Integer;
    MethodParameters:
          Name  Flags
      endpoint  

  public boolean knowsVersion(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress endpoint
         0: .line 1167
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.versions:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* endpoint */
            invokeinterface java.util.concurrent.ConcurrentMap.containsKey:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lorg/apache/cassandra/net/MessagingService;
            0    1     1  endpoint  Ljava/net/InetAddress;
    MethodParameters:
          Name  Flags
      endpoint  

  public void incrementDroppedMutations(java.util.Optional<org.apache.cassandra.db.IMutation>, );
    descriptor: (Ljava/util/Optional;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.util.Optional mutationOpt
        start local 2 // long timeTaken
         0: .line 1172
            aload 1 /* mutationOpt */
            invokevirtual java.util.Optional.isPresent:()Z
            ifeq 2
         1: .line 1174
            aload 0 /* this */
            aload 1 /* mutationOpt */
            invokevirtual java.util.Optional.get:()Ljava/lang/Object;
            checkcast org.apache.cassandra.db.IMutation
            invokevirtual org.apache.cassandra.net.MessagingService.updateDroppedMutationCount:(Lorg/apache/cassandra/db/IMutation;)V
         2: .line 1176
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic org.apache.cassandra.net.MessagingService$Verb.MUTATION:Lorg/apache/cassandra/net/MessagingService$Verb;
            lload 2 /* timeTaken */
            invokevirtual org.apache.cassandra.net.MessagingService.incrementDroppedMessages:(Lorg/apache/cassandra/net/MessagingService$Verb;J)V
         3: .line 1177
            return
        end local 2 // long timeTaken
        end local 1 // java.util.Optional mutationOpt
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0         this  Lorg/apache/cassandra/net/MessagingService;
            0    4     1  mutationOpt  Ljava/util/Optional<Lorg/apache/cassandra/db/IMutation;>;
            0    4     2    timeTaken  J
    Signature: (Ljava/util/Optional<Lorg/apache/cassandra/db/IMutation;>;J)V
    MethodParameters:
             Name  Flags
      mutationOpt  
      timeTaken    

  public void incrementDroppedMessages(org.apache.cassandra.net.MessagingService$Verb);
    descriptor: (Lorg/apache/cassandra/net/MessagingService$Verb;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessagingService$Verb verb
         0: .line 1181
            aload 0 /* this */
            aload 1 /* verb */
            iconst_0
            invokevirtual org.apache.cassandra.net.MessagingService.incrementDroppedMessages:(Lorg/apache/cassandra/net/MessagingService$Verb;Z)V
         1: .line 1182
            return
        end local 1 // org.apache.cassandra.net.MessagingService$Verb verb
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/net/MessagingService;
            0    2     1  verb  Lorg/apache/cassandra/net/MessagingService$Verb;
    MethodParameters:
      Name  Flags
      verb  

  public void incrementDroppedMessages(org.apache.cassandra.net.MessagingService$Verb, long);
    descriptor: (Lorg/apache/cassandra/net/MessagingService$Verb;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessagingService$Verb verb
        start local 2 // long timeTaken
         0: .line 1186
            aload 0 /* this */
            aload 1 /* verb */
            lload 2 /* timeTaken */
            iconst_0
            invokevirtual org.apache.cassandra.net.MessagingService.incrementDroppedMessages:(Lorg/apache/cassandra/net/MessagingService$Verb;JZ)V
         1: .line 1187
            return
        end local 2 // long timeTaken
        end local 1 // org.apache.cassandra.net.MessagingService$Verb verb
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/apache/cassandra/net/MessagingService;
            0    2     1       verb  Lorg/apache/cassandra/net/MessagingService$Verb;
            0    2     2  timeTaken  J
    MethodParameters:
           Name  Flags
      verb       
      timeTaken  

  public void incrementDroppedMessages(org.apache.cassandra.net.MessageIn, long);
    descriptor: (Lorg/apache/cassandra/net/MessageIn;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessageIn message
        start local 2 // long timeTaken
         0: .line 1191
            aload 1 /* message */
            getfield org.apache.cassandra.net.MessageIn.payload:Ljava/lang/Object;
            instanceof org.apache.cassandra.db.IMutation
            ifeq 2
         1: .line 1193
            aload 0 /* this */
            aload 1 /* message */
            getfield org.apache.cassandra.net.MessageIn.payload:Ljava/lang/Object;
            checkcast org.apache.cassandra.db.IMutation
            invokevirtual org.apache.cassandra.net.MessagingService.updateDroppedMutationCount:(Lorg/apache/cassandra/db/IMutation;)V
         2: .line 1195
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* message */
            getfield org.apache.cassandra.net.MessageIn.verb:Lorg/apache/cassandra/net/MessagingService$Verb;
            lload 2 /* timeTaken */
            aload 1 /* message */
            invokevirtual org.apache.cassandra.net.MessageIn.isCrossNode:()Z
            invokevirtual org.apache.cassandra.net.MessagingService.incrementDroppedMessages:(Lorg/apache/cassandra/net/MessagingService$Verb;JZ)V
         3: .line 1196
            return
        end local 2 // long timeTaken
        end local 1 // org.apache.cassandra.net.MessageIn message
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0       this  Lorg/apache/cassandra/net/MessagingService;
            0    4     1    message  Lorg/apache/cassandra/net/MessageIn;
            0    4     2  timeTaken  J
    MethodParameters:
           Name  Flags
      message    
      timeTaken  

  public void incrementDroppedMessages(org.apache.cassandra.net.MessagingService$Verb, long, boolean);
    descriptor: (Lorg/apache/cassandra/net/MessagingService$Verb;JZ)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessagingService$Verb verb
        start local 2 // long timeTaken
        start local 4 // boolean isCrossNode
         0: .line 1200
            getstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
            ifne 1
            getstatic org.apache.cassandra.net.MessagingService.DROPPABLE_VERBS:Ljava/util/EnumSet;
            aload 1 /* verb */
            invokevirtual java.util.EnumSet.contains:(Ljava/lang/Object;)Z
            ifne 1
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "Verb "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* verb */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " should not legally be dropped"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 1201
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.droppedMessagesMap:Ljava/util/Map;
            aload 1 /* verb */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.MessagingService$DroppedMessages
            lload 2 /* timeTaken */
            iload 4 /* isCrossNode */
            invokevirtual org.apache.cassandra.net.MessagingService.incrementDroppedMessages:(Lorg/apache/cassandra/net/MessagingService$DroppedMessages;JZ)V
         2: .line 1202
            return
        end local 4 // boolean isCrossNode
        end local 2 // long timeTaken
        end local 1 // org.apache.cassandra.net.MessagingService$Verb verb
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    3     0         this  Lorg/apache/cassandra/net/MessagingService;
            0    3     1         verb  Lorg/apache/cassandra/net/MessagingService$Verb;
            0    3     2    timeTaken  J
            0    3     4  isCrossNode  Z
    MethodParameters:
             Name  Flags
      verb         
      timeTaken    
      isCrossNode  

  public void incrementDroppedMessages(org.apache.cassandra.net.MessagingService$Verb, boolean);
    descriptor: (Lorg/apache/cassandra/net/MessagingService$Verb;Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessagingService$Verb verb
        start local 2 // boolean isCrossNode
         0: .line 1206
            getstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
            ifne 1
            getstatic org.apache.cassandra.net.MessagingService.DROPPABLE_VERBS:Ljava/util/EnumSet;
            aload 1 /* verb */
            invokevirtual java.util.EnumSet.contains:(Ljava/lang/Object;)Z
            ifne 1
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "Verb "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* verb */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " should not legally be dropped"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 1207
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.droppedMessagesMap:Ljava/util/Map;
            aload 1 /* verb */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.MessagingService$DroppedMessages
            iload 2 /* isCrossNode */
            invokevirtual org.apache.cassandra.net.MessagingService.incrementDroppedMessages:(Lorg/apache/cassandra/net/MessagingService$DroppedMessages;Z)V
         2: .line 1208
            return
        end local 2 // boolean isCrossNode
        end local 1 // org.apache.cassandra.net.MessagingService$Verb verb
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    3     0         this  Lorg/apache/cassandra/net/MessagingService;
            0    3     1         verb  Lorg/apache/cassandra/net/MessagingService$Verb;
            0    3     2  isCrossNode  Z
    MethodParameters:
             Name  Flags
      verb         
      isCrossNode  

  private void updateDroppedMutationCount(org.apache.cassandra.db.IMutation);
    descriptor: (Lorg/apache/cassandra/db/IMutation;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.db.IMutation mutation
         0: .line 1212
            getstatic org.apache.cassandra.net.MessagingService.$assertionsDisabled:Z
            ifne 1
            aload 1 /* mutation */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            ldc "Mutation should not be null when updating dropped mutations count"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 1214
      StackMap locals:
      StackMap stack:
            aload 1 /* mutation */
            invokeinterface org.apache.cassandra.db.IMutation.getColumnFamilyIds:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 6
      StackMap locals: org.apache.cassandra.net.MessagingService org.apache.cassandra.db.IMutation top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.UUID
            astore 2 /* columnFamilyId */
        start local 2 // java.util.UUID columnFamilyId
         3: .line 1216
            aload 1 /* mutation */
            invokeinterface org.apache.cassandra.db.IMutation.getKeyspaceName:()Ljava/lang/String;
            invokestatic org.apache.cassandra.db.Keyspace.open:(Ljava/lang/String;)Lorg/apache/cassandra/db/Keyspace;
            aload 2 /* columnFamilyId */
            invokevirtual org.apache.cassandra.db.Keyspace.getColumnFamilyStore:(Ljava/util/UUID;)Lorg/apache/cassandra/db/ColumnFamilyStore;
            astore 4 /* cfs */
        start local 4 // org.apache.cassandra.db.ColumnFamilyStore cfs
         4: .line 1217
            aload 4 /* cfs */
            ifnull 6
         5: .line 1219
            aload 4 /* cfs */
            getfield org.apache.cassandra.db.ColumnFamilyStore.metric:Lorg/apache/cassandra/metrics/TableMetrics;
            getfield org.apache.cassandra.metrics.TableMetrics.droppedMutations:Lcom/codahale/metrics/Counter;
            invokevirtual com.codahale.metrics.Counter.inc:()V
        end local 4 // org.apache.cassandra.db.ColumnFamilyStore cfs
        end local 2 // java.util.UUID columnFamilyId
         6: .line 1214
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         7: .line 1222
            return
        end local 1 // org.apache.cassandra.db.IMutation mutation
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    8     0            this  Lorg/apache/cassandra/net/MessagingService;
            0    8     1        mutation  Lorg/apache/cassandra/db/IMutation;
            3    6     2  columnFamilyId  Ljava/util/UUID;
            4    6     4             cfs  Lorg/apache/cassandra/db/ColumnFamilyStore;
    MethodParameters:
          Name  Flags
      mutation  

  private void incrementDroppedMessages(org.apache.cassandra.net.MessagingService$DroppedMessages, long, boolean);
    descriptor: (Lorg/apache/cassandra/net/MessagingService$DroppedMessages;JZ)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=5, args_size=4
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessagingService$DroppedMessages droppedMessages
        start local 2 // long timeTaken
        start local 4 // boolean isCrossNode
         0: .line 1226
            iload 4 /* isCrossNode */
            ifeq 2
         1: .line 1227
            aload 1 /* droppedMessages */
            getfield org.apache.cassandra.net.MessagingService$DroppedMessages.metrics:Lorg/apache/cassandra/metrics/DroppedMessageMetrics;
            getfield org.apache.cassandra.metrics.DroppedMessageMetrics.crossNodeDroppedLatency:Lcom/codahale/metrics/Timer;
            lload 2 /* timeTaken */
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual com.codahale.metrics.Timer.update:(JLjava/util/concurrent/TimeUnit;)V
            goto 3
         2: .line 1229
      StackMap locals:
      StackMap stack:
            aload 1 /* droppedMessages */
            getfield org.apache.cassandra.net.MessagingService$DroppedMessages.metrics:Lorg/apache/cassandra/metrics/DroppedMessageMetrics;
            getfield org.apache.cassandra.metrics.DroppedMessageMetrics.internalDroppedLatency:Lcom/codahale/metrics/Timer;
            lload 2 /* timeTaken */
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual com.codahale.metrics.Timer.update:(JLjava/util/concurrent/TimeUnit;)V
         3: .line 1230
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* droppedMessages */
            iload 4 /* isCrossNode */
            invokevirtual org.apache.cassandra.net.MessagingService.incrementDroppedMessages:(Lorg/apache/cassandra/net/MessagingService$DroppedMessages;Z)V
         4: .line 1231
            return
        end local 4 // boolean isCrossNode
        end local 2 // long timeTaken
        end local 1 // org.apache.cassandra.net.MessagingService$DroppedMessages droppedMessages
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    5     0             this  Lorg/apache/cassandra/net/MessagingService;
            0    5     1  droppedMessages  Lorg/apache/cassandra/net/MessagingService$DroppedMessages;
            0    5     2        timeTaken  J
            0    5     4      isCrossNode  Z
    MethodParameters:
                 Name  Flags
      droppedMessages  
      timeTaken        
      isCrossNode      

  private void incrementDroppedMessages(org.apache.cassandra.net.MessagingService$DroppedMessages, boolean);
    descriptor: (Lorg/apache/cassandra/net/MessagingService$DroppedMessages;Z)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=3, args_size=3
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // org.apache.cassandra.net.MessagingService$DroppedMessages droppedMessages
        start local 2 // boolean isCrossNode
         0: .line 1235
            aload 1 /* droppedMessages */
            getfield org.apache.cassandra.net.MessagingService$DroppedMessages.metrics:Lorg/apache/cassandra/metrics/DroppedMessageMetrics;
            getfield org.apache.cassandra.metrics.DroppedMessageMetrics.dropped:Lcom/codahale/metrics/Meter;
            invokevirtual com.codahale.metrics.Meter.mark:()V
         1: .line 1236
            iload 2 /* isCrossNode */
            ifeq 3
         2: .line 1237
            aload 1 /* droppedMessages */
            getfield org.apache.cassandra.net.MessagingService$DroppedMessages.droppedCrossNode:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.incrementAndGet:()I
            pop
            goto 4
         3: .line 1239
      StackMap locals:
      StackMap stack:
            aload 1 /* droppedMessages */
            getfield org.apache.cassandra.net.MessagingService$DroppedMessages.droppedInternal:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.incrementAndGet:()I
            pop
         4: .line 1240
      StackMap locals:
      StackMap stack:
            return
        end local 2 // boolean isCrossNode
        end local 1 // org.apache.cassandra.net.MessagingService$DroppedMessages droppedMessages
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    5     0             this  Lorg/apache/cassandra/net/MessagingService;
            0    5     1  droppedMessages  Lorg/apache/cassandra/net/MessagingService$DroppedMessages;
            0    5     2      isCrossNode  Z
    MethodParameters:
                 Name  Flags
      droppedMessages  
      isCrossNode      

  private void logDroppedMessages();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1244
            aload 0 /* this */
            invokevirtual org.apache.cassandra.net.MessagingService.getDroppedMessagesLogs:()Ljava/util/List;
            astore 1 /* logs */
        start local 1 // java.util.List logs
         1: .line 1245
            aload 1 /* logs */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 2 /* log */
        start local 2 // java.lang.String log
         3: .line 1246
            getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
            aload 2 /* log */
            invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;)V
        end local 2 // java.lang.String log
         4: .line 1245
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1248
            aload 1 /* logs */
            invokeinterface java.util.List.size:()I
            ifle 7
         6: .line 1249
            invokestatic org.apache.cassandra.utils.StatusLogger.log:()V
         7: .line 1250
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.List
      StackMap stack:
            return
        end local 1 // java.util.List logs
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lorg/apache/cassandra/net/MessagingService;
            1    8     1  logs  Ljava/util/List<Ljava/lang/String;>;
            3    4     2   log  Ljava/lang/String;

  java.util.List<java.lang.String> getDroppedMessagesLogs();
    descriptor: ()Ljava/util/List;
    flags: (0x0000) 
    Code:
      stack=8, locals=8, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1255
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* ret */
        start local 1 // java.util.List ret
         1: .line 1256
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.droppedMessagesMap:Ljava/util/Map;
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 16
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1258
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.MessagingService$Verb
            astore 4 /* verb */
        start local 4 // org.apache.cassandra.net.MessagingService$Verb verb
         4: .line 1259
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.MessagingService$DroppedMessages
            astore 5 /* droppedMessages */
        start local 5 // org.apache.cassandra.net.MessagingService$DroppedMessages droppedMessages
         5: .line 1261
            aload 5 /* droppedMessages */
            getfield org.apache.cassandra.net.MessagingService$DroppedMessages.droppedInternal:Ljava/util/concurrent/atomic/AtomicInteger;
            iconst_0
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndSet:(I)I
            istore 6 /* droppedInternal */
        start local 6 // int droppedInternal
         6: .line 1262
            aload 5 /* droppedMessages */
            getfield org.apache.cassandra.net.MessagingService$DroppedMessages.droppedCrossNode:Ljava/util/concurrent/atomic/AtomicInteger;
            iconst_0
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndSet:(I)I
            istore 7 /* droppedCrossNode */
        start local 7 // int droppedCrossNode
         7: .line 1263
            iload 6 /* droppedInternal */
            ifgt 8
            iload 7 /* droppedCrossNode */
            ifle 16
         8: .line 1265
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.List java.util.Map$Entry java.util.Iterator org.apache.cassandra.net.MessagingService$Verb org.apache.cassandra.net.MessagingService$DroppedMessages int int
      StackMap stack:
            aload 1 /* ret */
            ldc "%s messages were dropped in last %d ms: %d internal and %d cross node. Mean internal dropped latency: %d ms and Mean cross-node dropped latency: %d ms"
            bipush 6
            anewarray java.lang.Object
            dup
            iconst_0
         9: .line 1267
            aload 4 /* verb */
            aastore
            dup
            iconst_1
        10: .line 1268
            sipush 5000
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_2
        11: .line 1269
            iload 6 /* droppedInternal */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_3
        12: .line 1270
            iload 7 /* droppedCrossNode */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_4
        13: .line 1271
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            aload 5 /* droppedMessages */
            getfield org.apache.cassandra.net.MessagingService$DroppedMessages.metrics:Lorg/apache/cassandra/metrics/DroppedMessageMetrics;
            getfield org.apache.cassandra.metrics.DroppedMessageMetrics.internalDroppedLatency:Lcom/codahale/metrics/Timer;
            invokevirtual com.codahale.metrics.Timer.getSnapshot:()Lcom/codahale/metrics/Snapshot;
            invokevirtual com.codahale.metrics.Snapshot.getMean:()D
            d2l
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_5
        14: .line 1272
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            aload 5 /* droppedMessages */
            getfield org.apache.cassandra.net.MessagingService$DroppedMessages.metrics:Lorg/apache/cassandra/metrics/DroppedMessageMetrics;
            getfield org.apache.cassandra.metrics.DroppedMessageMetrics.crossNodeDroppedLatency:Lcom/codahale/metrics/Timer;
            invokevirtual com.codahale.metrics.Timer.getSnapshot:()Lcom/codahale/metrics/Snapshot;
            invokevirtual com.codahale.metrics.Snapshot.getMean:()D
            d2l
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
        15: .line 1265
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 7 // int droppedCrossNode
        end local 6 // int droppedInternal
        end local 5 // org.apache.cassandra.net.MessagingService$DroppedMessages droppedMessages
        end local 4 // org.apache.cassandra.net.MessagingService$Verb verb
        end local 2 // java.util.Map$Entry entry
        16: .line 1256
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.List top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        17: .line 1275
            aload 1 /* ret */
            areturn
        end local 1 // java.util.List ret
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   18     0              this  Lorg/apache/cassandra/net/MessagingService;
            1   18     1               ret  Ljava/util/List<Ljava/lang/String;>;
            3   16     2             entry  Ljava/util/Map$Entry<Lorg/apache/cassandra/net/MessagingService$Verb;Lorg/apache/cassandra/net/MessagingService$DroppedMessages;>;
            4   16     4              verb  Lorg/apache/cassandra/net/MessagingService$Verb;
            5   16     5   droppedMessages  Lorg/apache/cassandra/net/MessagingService$DroppedMessages;
            6   16     6   droppedInternal  I
            7   16     7  droppedCrossNode  I
    Signature: ()Ljava/util/List<Ljava/lang/String;>;
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()
    RuntimeInvisibleTypeAnnotations: 
      METHOD_RETURN
        com.google.common.annotations.VisibleForTesting()

  private static void handleIOExceptionOnClose(java.io.IOException);
    descriptor: (Ljava/io/IOException;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // java.io.IOException e
         0: .line 1380
            ldc "Mac OS X"
            ldc "os.name"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 7
         1: .line 1382
            aload 0 /* e */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            dup
            astore 1
            invokevirtual java.lang.String.hashCode:()I
            lookupswitch { // 4
          -1081702824: 2
           -369062560: 3
            641576986: 4
            899112255: 5
              default: 7
          }
      StackMap locals: java.lang.String
      StackMap stack:
         2: aload 1
            ldc "Bad file descriptor"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 6
            goto 7
      StackMap locals:
      StackMap stack:
         3: aload 1
            ldc "Unknown error: 316"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 6
            goto 7
      StackMap locals:
      StackMap stack:
         4: aload 1
            ldc "No such file or directory"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 6
            goto 7
      StackMap locals:
      StackMap stack:
         5: aload 1
            ldc "Thread signal failed"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 6
            goto 7
         6: .line 1388
      StackMap locals:
      StackMap stack:
            return
         7: .line 1392
      StackMap locals:
      StackMap stack:
            aload 0 /* e */
            athrow
        end local 0 // java.io.IOException e
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0     e  Ljava/io/IOException;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      e     

  public java.util.Map<java.lang.String, java.lang.Integer> getLargeMessagePendingTasks();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1397
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* pendingTasks */
        start local 1 // java.util.Map pendingTasks
         1: .line 1398
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1399
            aload 1 /* pendingTasks */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            getfield org.apache.cassandra.net.OutboundTcpConnectionPool.largeMessages:Lorg/apache/cassandra/net/OutboundTcpConnection;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.getPendingMessages:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1398
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1400
            aload 1 /* pendingTasks */
            areturn
        end local 1 // java.util.Map pendingTasks
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    6     0          this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1  pendingTasks  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Integer;>;
            3    4     2         entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Integer;>;

  public int getLargeMessagePendingTasks(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress address
         0: .line 1405
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* address */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            astore 2 /* connection */
        start local 2 // org.apache.cassandra.net.OutboundTcpConnectionPool connection
         1: .line 1406
            aload 2 /* connection */
            ifnonnull 2
            iconst_0
            goto 3
      StackMap locals: org.apache.cassandra.net.OutboundTcpConnectionPool
      StackMap stack:
         2: aload 2 /* connection */
            getfield org.apache.cassandra.net.OutboundTcpConnectionPool.largeMessages:Lorg/apache/cassandra/net/OutboundTcpConnection;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.getPendingMessages:()I
      StackMap locals:
      StackMap stack: int
         3: ireturn
        end local 2 // org.apache.cassandra.net.OutboundTcpConnectionPool connection
        end local 1 // java.net.InetAddress address
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        this  Lorg/apache/cassandra/net/MessagingService;
            0    4     1     address  Ljava/net/InetAddress;
            1    4     2  connection  Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
    MethodParameters:
         Name  Flags
      address  

  public java.util.Map<java.lang.String, java.lang.Long> getLargeMessageCompletedTasks();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1411
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* completedTasks */
        start local 1 // java.util.Map completedTasks
         1: .line 1412
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1413
            aload 1 /* completedTasks */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            getfield org.apache.cassandra.net.OutboundTcpConnectionPool.largeMessages:Lorg/apache/cassandra/net/OutboundTcpConnection;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.getCompletedMesssages:()J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1412
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1414
            aload 1 /* completedTasks */
            areturn
        end local 1 // java.util.Map completedTasks
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    6     0            this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1  completedTasks  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
            3    4     2           entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  public java.util.Map<java.lang.String, java.lang.Long> getLargeMessageDroppedTasks();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1419
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* droppedTasks */
        start local 1 // java.util.Map droppedTasks
         1: .line 1420
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1421
            aload 1 /* droppedTasks */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            getfield org.apache.cassandra.net.OutboundTcpConnectionPool.largeMessages:Lorg/apache/cassandra/net/OutboundTcpConnection;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.getDroppedMessages:()J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1420
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1422
            aload 1 /* droppedTasks */
            areturn
        end local 1 // java.util.Map droppedTasks
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    6     0          this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1  droppedTasks  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
            3    4     2         entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  public java.util.Map<java.lang.String, java.lang.Integer> getSmallMessagePendingTasks();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1427
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* pendingTasks */
        start local 1 // java.util.Map pendingTasks
         1: .line 1428
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1429
            aload 1 /* pendingTasks */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            getfield org.apache.cassandra.net.OutboundTcpConnectionPool.smallMessages:Lorg/apache/cassandra/net/OutboundTcpConnection;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.getPendingMessages:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1428
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1430
            aload 1 /* pendingTasks */
            areturn
        end local 1 // java.util.Map pendingTasks
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    6     0          this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1  pendingTasks  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Integer;>;
            3    4     2         entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Integer;>;

  public java.util.Map<java.lang.String, java.lang.Long> getSmallMessageCompletedTasks();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1435
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* completedTasks */
        start local 1 // java.util.Map completedTasks
         1: .line 1436
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1437
            aload 1 /* completedTasks */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            getfield org.apache.cassandra.net.OutboundTcpConnectionPool.smallMessages:Lorg/apache/cassandra/net/OutboundTcpConnection;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.getCompletedMesssages:()J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1436
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1438
            aload 1 /* completedTasks */
            areturn
        end local 1 // java.util.Map completedTasks
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    6     0            this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1  completedTasks  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
            3    4     2           entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  public java.util.Map<java.lang.String, java.lang.Long> getSmallMessageDroppedTasks();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1443
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* droppedTasks */
        start local 1 // java.util.Map droppedTasks
         1: .line 1444
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1445
            aload 1 /* droppedTasks */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            getfield org.apache.cassandra.net.OutboundTcpConnectionPool.smallMessages:Lorg/apache/cassandra/net/OutboundTcpConnection;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.getDroppedMessages:()J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1444
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1446
            aload 1 /* droppedTasks */
            areturn
        end local 1 // java.util.Map droppedTasks
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    6     0          this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1  droppedTasks  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
            3    4     2         entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  public java.util.Map<java.lang.String, java.lang.Integer> getGossipMessagePendingTasks();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1451
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* pendingTasks */
        start local 1 // java.util.Map pendingTasks
         1: .line 1452
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1453
            aload 1 /* pendingTasks */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            getfield org.apache.cassandra.net.OutboundTcpConnectionPool.gossipMessages:Lorg/apache/cassandra/net/OutboundTcpConnection;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.getPendingMessages:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1452
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1454
            aload 1 /* pendingTasks */
            areturn
        end local 1 // java.util.Map pendingTasks
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    6     0          this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1  pendingTasks  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Integer;>;
            3    4     2         entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Integer;>;

  public java.util.Map<java.lang.String, java.lang.Long> getGossipMessageCompletedTasks();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1459
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* completedTasks */
        start local 1 // java.util.Map completedTasks
         1: .line 1460
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1461
            aload 1 /* completedTasks */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            getfield org.apache.cassandra.net.OutboundTcpConnectionPool.gossipMessages:Lorg/apache/cassandra/net/OutboundTcpConnection;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.getCompletedMesssages:()J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1460
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1462
            aload 1 /* completedTasks */
            areturn
        end local 1 // java.util.Map completedTasks
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    6     0            this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1  completedTasks  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
            3    4     2           entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  public java.util.Map<java.lang.String, java.lang.Long> getGossipMessageDroppedTasks();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1467
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* droppedTasks */
        start local 1 // java.util.Map droppedTasks
         1: .line 1468
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1469
            aload 1 /* droppedTasks */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            getfield org.apache.cassandra.net.OutboundTcpConnectionPool.gossipMessages:Lorg/apache/cassandra/net/OutboundTcpConnection;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnection.getDroppedMessages:()J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1468
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1470
            aload 1 /* droppedTasks */
            areturn
        end local 1 // java.util.Map droppedTasks
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    6     0          this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1  droppedTasks  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
            3    4     2         entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  public java.util.Map<java.lang.String, java.lang.Integer> getDroppedMessages();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1475
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.droppedMessagesMap:Ljava/util/Map;
            invokeinterface java.util.Map.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* map */
        start local 1 // java.util.Map map
         1: .line 1476
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.droppedMessagesMap:Ljava/util/Map;
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1477
            aload 1 /* map */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.MessagingService$Verb
            invokevirtual org.apache.cassandra.net.MessagingService$Verb.toString:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.MessagingService$DroppedMessages
            getfield org.apache.cassandra.net.MessagingService$DroppedMessages.metrics:Lorg/apache/cassandra/metrics/DroppedMessageMetrics;
            getfield org.apache.cassandra.metrics.DroppedMessageMetrics.dropped:Lcom/codahale/metrics/Meter;
            invokevirtual com.codahale.metrics.Meter.getCount:()J
            l2i
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1476
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1478
            aload 1 /* map */
            areturn
        end local 1 // java.util.Map map
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    6     0   this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1    map  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Integer;>;
            3    4     2  entry  Ljava/util/Map$Entry<Lorg/apache/cassandra/net/MessagingService$Verb;Lorg/apache/cassandra/net/MessagingService$DroppedMessages;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Integer;>;

  public long getTotalTimeouts();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1484
            getstatic org.apache.cassandra.metrics.ConnectionMetrics.totalTimeouts:Lcom/codahale/metrics/Meter;
            invokevirtual com.codahale.metrics.Meter.getCount:()J
            lreturn
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/net/MessagingService;

  public java.util.Map<java.lang.String, java.lang.Long> getTimeoutsPerHost();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1489
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* result */
        start local 1 // java.util.Map result
         1: .line 1490
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 6
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1492
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            astore 4 /* ip */
        start local 4 // java.lang.String ip
         4: .line 1493
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.getTimeouts:()J
            lstore 5 /* recent */
        start local 5 // long recent
         5: .line 1494
            aload 1 /* result */
            aload 4 /* ip */
            lload 5 /* recent */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 5 // long recent
        end local 4 // java.lang.String ip
        end local 2 // java.util.Map$Entry entry
         6: .line 1490
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         7: .line 1496
            aload 1 /* result */
            areturn
        end local 1 // java.util.Map result
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lorg/apache/cassandra/net/MessagingService;
            1    8     1  result  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
            3    6     2   entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
            4    6     4      ip  Ljava/lang/String;
            5    6     5  recent  J
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  public java.util.Map<java.lang.String, java.lang.Double> getBackPressurePerHost();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1501
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* map */
        start local 1 // java.util.Map map
         1: .line 1502
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.connectionManagers:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.net.MessagingService java.util.Map top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         3: .line 1503
            aload 1 /* map */
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.net.InetAddress
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast org.apache.cassandra.net.OutboundTcpConnectionPool
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.getBackPressureState:()Lorg/apache/cassandra/net/BackPressureState;
            invokeinterface org.apache.cassandra.net.BackPressureState.getBackPressureRateLimit:()D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.Map$Entry entry
         4: .line 1502
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 1505
            aload 1 /* map */
            areturn
        end local 1 // java.util.Map map
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    6     0   this  Lorg/apache/cassandra/net/MessagingService;
            1    6     1    map  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Double;>;
            3    4     2  entry  Ljava/util/Map$Entry<Ljava/net/InetAddress;Lorg/apache/cassandra/net/OutboundTcpConnectionPool;>;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Ljava/lang/Double;>;

  public void setBackPressureEnabled(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // boolean enabled
         0: .line 1511
            iload 1 /* enabled */
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.setBackPressureEnabled:(Z)V
         1: .line 1512
            return
        end local 1 // boolean enabled
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/apache/cassandra/net/MessagingService;
            0    2     1  enabled  Z
    MethodParameters:
         Name  Flags
      enabled  

  public boolean isBackPressureEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1517
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.backPressureEnabled:()Z
            ireturn
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/net/MessagingService;

  public static org.apache.cassandra.dht.IPartitioner globalPartitioner();
    descriptor: ()Lorg/apache/cassandra/dht/IPartitioner;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 1522
            getstatic org.apache.cassandra.service.StorageService.instance:Lorg/apache/cassandra/service/StorageService;
            invokevirtual org.apache.cassandra.service.StorageService.getTokenMetadata:()Lorg/apache/cassandra/locator/TokenMetadata;
            getfield org.apache.cassandra.locator.TokenMetadata.partitioner:Lorg/apache/cassandra/dht/IPartitioner;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static void validatePartitioner(java.util.Collection<? extends org.apache.cassandra.dht.AbstractBounds<?>>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // java.util.Collection allBounds
         0: .line 1527
            aload 0 /* allBounds */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2
            goto 3
      StackMap locals: java.util.Collection top java.util.Iterator
      StackMap stack:
         1: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.AbstractBounds
            astore 1 /* bounds */
        start local 1 // org.apache.cassandra.dht.AbstractBounds bounds
         2: .line 1528
            aload 1 /* bounds */
            invokestatic org.apache.cassandra.net.MessagingService.validatePartitioner:(Lorg/apache/cassandra/dht/AbstractBounds;)V
        end local 1 // org.apache.cassandra.dht.AbstractBounds bounds
         3: .line 1527
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 1529
            return
        end local 0 // java.util.Collection allBounds
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    5     0  allBounds  Ljava/util/Collection<+Lorg/apache/cassandra/dht/AbstractBounds<*>;>;
            2    3     1     bounds  Lorg/apache/cassandra/dht/AbstractBounds<*>;
    Signature: (Ljava/util/Collection<+Lorg/apache/cassandra/dht/AbstractBounds<*>;>;)V
    MethodParameters:
           Name  Flags
      allBounds  

  public static void validatePartitioner(org.apache.cassandra.dht.AbstractBounds<?>);
    descriptor: (Lorg/apache/cassandra/dht/AbstractBounds;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=7, locals=1, args_size=1
        start local 0 // org.apache.cassandra.dht.AbstractBounds bounds
         0: .line 1533
            invokestatic org.apache.cassandra.net.MessagingService.globalPartitioner:()Lorg/apache/cassandra/dht/IPartitioner;
            aload 0 /* bounds */
            getfield org.apache.cassandra.dht.AbstractBounds.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.RingPosition
            invokeinterface org.apache.cassandra.dht.RingPosition.getPartitioner:()Lorg/apache/cassandra/dht/IPartitioner;
            if_acmpeq 5
         1: .line 1534
            new java.lang.AssertionError
            dup
            ldc "Partitioner in bounds serialization. Expected %s, was %s."
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
         2: .line 1535
            invokestatic org.apache.cassandra.net.MessagingService.globalPartitioner:()Lorg/apache/cassandra/dht/IPartitioner;
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            aastore
            dup
            iconst_1
         3: .line 1536
            aload 0 /* bounds */
            getfield org.apache.cassandra.dht.AbstractBounds.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.dht.RingPosition
            invokeinterface org.apache.cassandra.dht.RingPosition.getPartitioner:()Lorg/apache/cassandra/dht/IPartitioner;
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            aastore
         4: .line 1534
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         5: .line 1537
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.cassandra.dht.AbstractBounds bounds
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0  bounds  Lorg/apache/cassandra/dht/AbstractBounds<*>;
    Signature: (Lorg/apache/cassandra/dht/AbstractBounds<*>;)V
    MethodParameters:
        Name  Flags
      bounds  

  public java.util.List<org.apache.cassandra.net.MessagingService$SocketThread> getSocketThreads();
    descriptor: ()Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.net.MessagingService this
         0: .line 1542
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService.socketThreads:Ljava/util/List;
            areturn
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/net/MessagingService;
    Signature: ()Ljava/util/List<Lorg/apache/cassandra/net/MessagingService$SocketThread;>;
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()
    RuntimeInvisibleTypeAnnotations: 
      METHOD_RETURN
        com.google.common.annotations.VisibleForTesting()

  private static org.apache.cassandra.metrics.CassandraMetricsRegistry$MetricName lambda$0(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)Lorg/apache/cassandra/metrics/CassandraMetricsRegistry$MetricName;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=5, locals=2, args_size=2
        start local 1 // java.lang.String metricName
         0: .line 461
            new org.apache.cassandra.metrics.CassandraMetricsRegistry$MetricName
            dup
            ldc "DroppedMessages"
            aload 1 /* metricName */
            aload 0
            invokespecial org.apache.cassandra.metrics.CassandraMetricsRegistry$MetricName.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
            areturn
        end local 1 // java.lang.String metricName
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     1  metricName  Ljava/lang/String;

  private static boolean lambda$1(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Z
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.net.InetAddress h
         0: .line 628
            aload 0 /* h */
            invokestatic org.apache.cassandra.utils.FBUtilities.getBroadcastAddress:()Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifeq 1
            iconst_0
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_1
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 0 // java.net.InetAddress h
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0     h  Ljava/net/InetAddress;

  private org.apache.cassandra.net.BackPressureState lambda$2(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Lorg/apache/cassandra/net/BackPressureState;
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService this
        start local 1 // java.net.InetAddress h
         0: .line 629
            aload 0 /* this */
            aload 1 /* h */
            invokevirtual org.apache.cassandra.net.MessagingService.getConnectionPool:(Ljava/net/InetAddress;)Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.getBackPressureState:()Lorg/apache/cassandra/net/BackPressureState;
            areturn
        end local 1 // java.net.InetAddress h
        end local 0 // org.apache.cassandra.net.MessagingService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/net/MessagingService;
            0    1     1     h  Ljava/net/InetAddress;
}
SourceFile: "MessagingService.java"
NestMembers:
  org.apache.cassandra.net.MessagingService$1  org.apache.cassandra.net.MessagingService$2  org.apache.cassandra.net.MessagingService$3  org.apache.cassandra.net.MessagingService$4  org.apache.cassandra.net.MessagingService$5  org.apache.cassandra.net.MessagingService$5$1  org.apache.cassandra.net.MessagingService$CallbackDeterminedSerializer  org.apache.cassandra.net.MessagingService$DroppedMessages  org.apache.cassandra.net.MessagingService$MSHandle  org.apache.cassandra.net.MessagingService$MSTestHandle  org.apache.cassandra.net.MessagingService$SocketThread  org.apache.cassandra.net.MessagingService$Verb  org.apache.cassandra.net.MessagingService$Verb$1  org.apache.cassandra.net.MessagingService$Verb$10  org.apache.cassandra.net.MessagingService$Verb$11  org.apache.cassandra.net.MessagingService$Verb$12  org.apache.cassandra.net.MessagingService$Verb$13  org.apache.cassandra.net.MessagingService$Verb$2  org.apache.cassandra.net.MessagingService$Verb$3  org.apache.cassandra.net.MessagingService$Verb$4  org.apache.cassandra.net.MessagingService$Verb$5  org.apache.cassandra.net.MessagingService$Verb$6  org.apache.cassandra.net.MessagingService$Verb$7  org.apache.cassandra.net.MessagingService$Verb$8  org.apache.cassandra.net.MessagingService$Verb$9
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  public abstract Entry = java.util.Map$Entry of java.util.Map
  public ServerEncryptionOptions = org.apache.cassandra.config.EncryptionOptions$ServerEncryptionOptions of org.apache.cassandra.config.EncryptionOptions
  public final InternodeEncryption = org.apache.cassandra.config.EncryptionOptions$ServerEncryptionOptions$InternodeEncryption of org.apache.cassandra.config.EncryptionOptions$ServerEncryptionOptions
  public MetricName = org.apache.cassandra.metrics.CassandraMetricsRegistry$MetricName of org.apache.cassandra.metrics.CassandraMetricsRegistry
  org.apache.cassandra.net.MessagingService$1
  org.apache.cassandra.net.MessagingService$2
  org.apache.cassandra.net.MessagingService$3
  org.apache.cassandra.net.MessagingService$4
  org.apache.cassandra.net.MessagingService$5
  CallbackDeterminedSerializer = org.apache.cassandra.net.MessagingService$CallbackDeterminedSerializer of org.apache.cassandra.net.MessagingService
  private final DroppedMessages = org.apache.cassandra.net.MessagingService$DroppedMessages of org.apache.cassandra.net.MessagingService
  private MSHandle = org.apache.cassandra.net.MessagingService$MSHandle of org.apache.cassandra.net.MessagingService
  private MSTestHandle = org.apache.cassandra.net.MessagingService$MSTestHandle of org.apache.cassandra.net.MessagingService
  public SocketThread = org.apache.cassandra.net.MessagingService$SocketThread of org.apache.cassandra.net.MessagingService
  public Verb = org.apache.cassandra.net.MessagingService$Verb of org.apache.cassandra.net.MessagingService
  public CacheableObject = org.apache.cassandra.utils.ExpiringMap$CacheableObject of org.apache.cassandra.utils.ExpiringMap