|
@@ -1,104 +1,112 @@
|
|
| 1 |
-
|
| 2 |
0000000000000000: 01 pushq %rbp
|
| 3 |
0000000000000001: 02 pushq %r15
|
| 4 |
0000000000000003: 02 pushq %r14
|
| 5 |
0000000000000005: 02 pushq %r13
|
| 6 |
0000000000000007: 02 pushq %r12
|
| 7 |
0000000000000009: 01 pushq %rbx
|
| 8 |
000000000000000a: 04 subq $40, %rsp
|
| 9 |
000000000000000e: 03 movq %rsi, %r13
|
| 10 |
0000000000000011: 03 movq %rdi, %rbx
|
| 11 |
0000000000000014: 05 callq 0x4028a0 <_ZNSt3__16chrono12steady_clock3nowEv@plt>
|
| 12 |
0000000000000019: 03 movq %rax, %rbp
|
| 13 |
000000000000001c: 07 addq $-10000, %rbp
|
| 14 |
0000000000000023: 06 movl $4294967294, %r14d
|
| 15 |
0000000000000029: 04 cmpq (%r13), %rbp
|
| 16 |
-
000000000000002d: 06 jge
|
| 17 |
0000000000000033: 10 movabsq $1237940039285380275, %r14
|
| 18 |
000000000000003d: 03 movq %rsp, %r15
|
| 19 |
0000000000000040: 05 leaq 16(%rsp), %r12
|
| 20 |
0000000000000045: 10 nopw %cs:(%rax,%rax)
|
| 21 |
000000000000004f: 01 nop
|
| 22 |
-
0000000000000050:
|
| 23 |
-
|
| 24 |
-
|
| 25 |
-
|
| 26 |
-
|
| 27 |
-
|
| 28 |
-
|
| 29 |
-
|
| 30 |
-
000000000000006d:
|
| 31 |
-
|
| 32 |
-
|
| 33 |
-
0000000000000077:
|
| 34 |
-
|
| 35 |
-
|
| 36 |
-
|
| 37 |
-
|
| 38 |
-
|
| 39 |
-
|
| 40 |
-
|
| 41 |
-
|
| 42 |
-
|
| 43 |
-
|
| 44 |
-
|
| 45 |
-
|
| 46 |
-
|
| 47 |
-
|
| 48 |
-
|
| 49 |
-
|
| 50 |
-
|
| 51 |
-
|
| 52 |
-
|
| 53 |
-
|
| 54 |
-
|
| 55 |
-
00000000000000cb:
|
| 56 |
-
|
| 57 |
-
|
| 58 |
-
|
| 59 |
-
|
| 60 |
-
|
| 61 |
-
|
| 62 |
-
|
| 63 |
-
|
| 64 |
-
|
| 65 |
-
|
| 66 |
-
|
| 67 |
-
|
| 68 |
-
|
| 69 |
-
|
| 70 |
-
|
| 71 |
-
|
| 72 |
-
|
| 73 |
-
|
| 74 |
-
|
| 75 |
-
0000000000000120:
|
| 76 |
-
|
| 77 |
-
0000000000000128:
|
| 78 |
-
|
| 79 |
-
|
| 80 |
-
|
| 81 |
-
|
| 82 |
-
|
| 83 |
-
|
| 84 |
-
|
| 85 |
-
|
| 86 |
-
|
| 87 |
-
|
| 88 |
-
|
| 89 |
-
|
| 90 |
-
|
| 91 |
-
|
| 92 |
-
|
| 93 |
-
|
| 94 |
-
|
| 95 |
-
|
| 96 |
-
|
| 97 |
-
|
| 98 |
-
|
| 99 |
-
|
| 100 |
-
|
| 101 |
-
|
| 102 |
-
|
| 103 |
-
|
| 104 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
00000000004078b0 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)>:
|
| 2 |
0000000000000000: 01 pushq %rbp
|
| 3 |
0000000000000001: 02 pushq %r15
|
| 4 |
0000000000000003: 02 pushq %r14
|
| 5 |
0000000000000005: 02 pushq %r13
|
| 6 |
0000000000000007: 02 pushq %r12
|
| 7 |
0000000000000009: 01 pushq %rbx
|
| 8 |
000000000000000a: 04 subq $40, %rsp
|
| 9 |
000000000000000e: 03 movq %rsi, %r13
|
| 10 |
0000000000000011: 03 movq %rdi, %rbx
|
| 11 |
0000000000000014: 05 callq 0x4028a0 <_ZNSt3__16chrono12steady_clock3nowEv@plt>
|
| 12 |
0000000000000019: 03 movq %rax, %rbp
|
| 13 |
000000000000001c: 07 addq $-10000, %rbp
|
| 14 |
0000000000000023: 06 movl $4294967294, %r14d
|
| 15 |
0000000000000029: 04 cmpq (%r13), %rbp
|
| 16 |
+
000000000000002d: 06 jge 0x407a3a <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18a>
|
| 17 |
0000000000000033: 10 movabsq $1237940039285380275, %r14
|
| 18 |
000000000000003d: 03 movq %rsp, %r15
|
| 19 |
0000000000000040: 05 leaq 16(%rsp), %r12
|
| 20 |
0000000000000045: 10 nopw %cs:(%rax,%rax)
|
| 21 |
000000000000004f: 01 nop
|
| 22 |
+
0000000000000050: 03 movl 96(%rbx), %eax
|
| 23 |
+
0000000000000053: 02 testl %eax, %eax
|
| 24 |
+
0000000000000055: 02 je 0x407920 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x70>
|
| 25 |
+
0000000000000057: 03 cmpl $1, %eax
|
| 26 |
+
000000000000005a: 02 jne 0x407930 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x80>
|
| 27 |
+
000000000000005c: 05 callq 0x422240 <BloombergLP::bsls::SystemTime::nowMonotonicClock()>
|
| 28 |
+
0000000000000061: 02 jmp 0x407925 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x75>
|
| 29 |
+
0000000000000063: 10 nopw %cs:(%rax,%rax)
|
| 30 |
+
000000000000006d: 03 nopl (%rax)
|
| 31 |
+
0000000000000070: 05 callq 0x4222d0 <BloombergLP::bsls::SystemTime::nowRealtimeClock()>
|
| 32 |
+
0000000000000075: 02 jmp 0x407934 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x84>
|
| 33 |
+
0000000000000077: 09 nopw (%rax,%rax)
|
| 34 |
+
0000000000000080: 02 xorl %edx, %edx
|
| 35 |
+
0000000000000082: 02 xorl %eax, %eax
|
| 36 |
+
0000000000000084: 04 movq %rax, (%rsp)
|
| 37 |
+
0000000000000088: 04 movl %edx, 8(%rsp)
|
| 38 |
+
000000000000008c: 04 movq (%r13), %rcx
|
| 39 |
+
0000000000000090: 03 subq %rbp, %rcx
|
| 40 |
+
0000000000000093: 03 movq %rcx, %rax
|
| 41 |
+
0000000000000096: 03 imulq %r14
|
| 42 |
+
0000000000000099: 03 movq %rdx, %rax
|
| 43 |
+
000000000000009c: 04 shrq $63, %rax
|
| 44 |
+
00000000000000a0: 04 sarq $26, %rdx
|
| 45 |
+
00000000000000a4: 03 addq %rax, %rdx
|
| 46 |
+
00000000000000a7: 06 imull $3294967296, %edx, %eax
|
| 47 |
+
00000000000000ad: 02 addl %eax, %ecx
|
| 48 |
+
00000000000000af: 03 movq %r15, %rdi
|
| 49 |
+
00000000000000b2: 03 movq %rdx, %rsi
|
| 50 |
+
00000000000000b5: 02 movl %ecx, %edx
|
| 51 |
+
00000000000000b7: 05 callq 0x4223f0 <BloombergLP::bsls::TimeInterval::addInterval(long long, int)>
|
| 52 |
+
00000000000000bc: 03 movups (%rax), %xmm0
|
| 53 |
+
00000000000000bf: 05 movaps %xmm0, 16(%rsp)
|
| 54 |
+
00000000000000c4: 07 movq $-268435456, %rax
|
| 55 |
+
00000000000000cb: 01 lock
|
| 56 |
+
00000000000000cc: 04 xaddq %rax, (%rbx)
|
| 57 |
+
00000000000000d0: 05 testl $16777216, %eax
|
| 58 |
+
00000000000000d5: 02 jne 0x4079d8 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x128>
|
| 59 |
+
00000000000000d7: 07 leaq -268435456(%rax), %rdx
|
| 60 |
+
00000000000000de: 03 movq %rdx, %rcx
|
| 61 |
+
00000000000000e1: 04 sarq $28, %rcx
|
| 62 |
+
00000000000000e5: 05 andl $16777215, %eax
|
| 63 |
+
00000000000000ea: 03 cmpq %rax, %rcx
|
| 64 |
+
00000000000000ed: 06 jge 0x407a32 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x182>
|
| 65 |
+
00000000000000f3: 03 movq %rbx, %rdi
|
| 66 |
+
00000000000000f6: 03 movq %r12, %rsi
|
| 67 |
+
00000000000000f9: 05 callq 0x406df0 <BloombergLP::bslmt::FastPostSemaphoreImpl<BloombergLP::bsls::AtomicOperations, BloombergLP::bslmt::Mutex, BloombergLP::bslmt::Condition, BloombergLP::bslmt::ThreadUtil>::timedWaitSlowPath(BloombergLP::bsls::TimeInterval const&, long long)>
|
| 68 |
+
00000000000000fe: 03 cmpl $-2, %eax
|
| 69 |
+
0000000000000101: 06 jne 0x407a37 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x187>
|
| 70 |
+
0000000000000107: 05 callq 0x4028a0 <_ZNSt3__16chrono12steady_clock3nowEv@plt>
|
| 71 |
+
000000000000010c: 03 movq %rax, %rbp
|
| 72 |
+
000000000000010f: 07 addq $-10000, %rbp
|
| 73 |
+
0000000000000116: 04 cmpq (%r13), %rbp
|
| 74 |
+
000000000000011a: 06 jl 0x407900 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x50>
|
| 75 |
+
0000000000000120: 06 movl $4294967294, %r14d
|
| 76 |
+
0000000000000126: 02 jmp 0x407a3a <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18a>
|
| 77 |
+
0000000000000128: 05 movl $268435456, %eax
|
| 78 |
+
000000000000012d: 01 lock
|
| 79 |
+
000000000000012e: 04 xaddq %rax, (%rbx)
|
| 80 |
+
0000000000000132: 06 movl $4294967295, %r14d
|
| 81 |
+
0000000000000138: 05 testl $16777215, %eax
|
| 82 |
+
000000000000013d: 02 je 0x407a3a <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18a>
|
| 83 |
+
000000000000013f: 02 movl %eax, %ecx
|
| 84 |
+
0000000000000141: 06 andl $16777216, %ecx
|
| 85 |
+
0000000000000147: 03 testq %rcx, %rcx
|
| 86 |
+
000000000000014a: 02 jne 0x407a3a <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18a>
|
| 87 |
+
000000000000014c: 06 addq $268435456, %rax
|
| 88 |
+
0000000000000152: 06 andq $-268435456, %rax
|
| 89 |
+
0000000000000158: 06 cmpq $268435456, %rax
|
| 90 |
+
000000000000015e: 02 jne 0x407a3a <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18a>
|
| 91 |
+
0000000000000160: 04 leaq 8(%rbx), %rbp
|
| 92 |
+
0000000000000164: 03 movq %rbp, %rdi
|
| 93 |
+
0000000000000167: 05 callq 0x402970 <pthread_mutex_lock@plt>
|
| 94 |
+
000000000000016c: 03 movq %rbp, %rdi
|
| 95 |
+
000000000000016f: 05 callq 0x4029e0 <pthread_mutex_unlock@plt>
|
| 96 |
+
0000000000000174: 04 addq $48, %rbx
|
| 97 |
+
0000000000000178: 03 movq %rbx, %rdi
|
| 98 |
+
000000000000017b: 05 callq 0x4026b0 <pthread_cond_signal@plt>
|
| 99 |
+
0000000000000180: 02 jmp 0x407a3a <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18a>
|
| 100 |
+
0000000000000182: 03 xorl %r14d, %r14d
|
| 101 |
+
0000000000000185: 02 jmp 0x407a3a <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<AnotherClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18a>
|
| 102 |
+
0000000000000187: 03 movl %eax, %r14d
|
| 103 |
+
000000000000018a: 03 movl %r14d, %eax
|
| 104 |
+
000000000000018d: 04 addq $40, %rsp
|
| 105 |
+
0000000000000191: 01 popq %rbx
|
| 106 |
+
0000000000000192: 02 popq %r12
|
| 107 |
+
0000000000000194: 02 popq %r13
|
| 108 |
+
0000000000000196: 02 popq %r14
|
| 109 |
+
0000000000000198: 02 popq %r15
|
| 110 |
+
000000000000019a: 01 popq %rbp
|
| 111 |
+
000000000000019b: 01 retq
|
| 112 |
+
000000000000019c: 04 nopl (%rax)
|