|
@@ -1,106 +1,115 @@
|
|
| 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, %rbp
|
| 10 |
0000000000000011: 03 movq %rdi, %rbx
|
| 11 |
0000000000000014: 05 callq 0x4028a0 <_ZNSt3__16chrono12steady_clock3nowEv@plt>
|
| 12 |
0000000000000019: 03 movq %rax, %r14
|
| 13 |
000000000000001c: 04 shrq $63, %r14
|
| 14 |
0000000000000020: 03 addq %rax, %r14
|
| 15 |
0000000000000023: 03 sarq %r14
|
| 16 |
0000000000000026: 06 movl $4294967294, %r15d
|
| 17 |
000000000000002c: 04 cmpq (%rbp), %r14
|
| 18 |
-
0000000000000030: 06 jge
|
| 19 |
0000000000000036: 10 movabsq $1237940039285380275, %r13
|
| 20 |
0000000000000040: 03 movq %rsp, %r15
|
| 21 |
0000000000000043: 05 leaq 16(%rsp), %r12
|
| 22 |
0000000000000048: 08 nopl (%rax,%rax)
|
| 23 |
-
0000000000000050:
|
| 24 |
-
|
| 25 |
-
|
| 26 |
-
|
| 27 |
-
|
| 28 |
-
|
| 29 |
-
|
| 30 |
-
|
| 31 |
-
000000000000006d:
|
| 32 |
-
|
| 33 |
-
|
| 34 |
-
0000000000000077:
|
| 35 |
-
|
| 36 |
-
|
| 37 |
-
|
| 38 |
-
|
| 39 |
-
|
| 40 |
-
|
| 41 |
-
|
| 42 |
-
|
| 43 |
-
|
| 44 |
-
|
| 45 |
-
|
| 46 |
-
|
| 47 |
-
|
| 48 |
-
|
| 49 |
-
|
| 50 |
-
|
| 51 |
-
|
| 52 |
-
|
| 53 |
-
|
| 54 |
-
|
| 55 |
-
|
| 56 |
-
00000000000000cb:
|
| 57 |
-
|
| 58 |
-
|
| 59 |
-
|
| 60 |
-
|
| 61 |
-
|
| 62 |
-
|
| 63 |
-
|
| 64 |
-
|
| 65 |
-
|
| 66 |
-
|
| 67 |
-
|
| 68 |
-
|
| 69 |
-
00000000000000fe:
|
| 70 |
-
|
| 71 |
-
|
| 72 |
-
000000000000010c:
|
| 73 |
-
|
| 74 |
-
|
| 75 |
-
0000000000000116:
|
| 76 |
-
|
| 77 |
-
|
| 78 |
-
0000000000000123:
|
| 79 |
-
|
| 80 |
-
000000000000012b:
|
| 81 |
-
|
| 82 |
-
|
| 83 |
-
|
| 84 |
-
|
| 85 |
-
|
| 86 |
-
|
| 87 |
-
|
| 88 |
-
|
| 89 |
-
|
| 90 |
-
|
| 91 |
-
|
| 92 |
-
|
| 93 |
-
|
| 94 |
-
|
| 95 |
-
|
| 96 |
-
|
| 97 |
-
|
| 98 |
-
|
| 99 |
-
|
| 100 |
-
|
| 101 |
-
|
| 102 |
-
|
| 103 |
-
|
| 104 |
-
|
| 105 |
-
|
| 106 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
0000000000407710 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, 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, %rbp
|
| 10 |
0000000000000011: 03 movq %rdi, %rbx
|
| 11 |
0000000000000014: 05 callq 0x4028a0 <_ZNSt3__16chrono12steady_clock3nowEv@plt>
|
| 12 |
0000000000000019: 03 movq %rax, %r14
|
| 13 |
000000000000001c: 04 shrq $63, %r14
|
| 14 |
0000000000000020: 03 addq %rax, %r14
|
| 15 |
0000000000000023: 03 sarq %r14
|
| 16 |
0000000000000026: 06 movl $4294967294, %r15d
|
| 17 |
000000000000002c: 04 cmpq (%rbp), %r14
|
| 18 |
+
0000000000000030: 06 jge 0x40789d <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18d>
|
| 19 |
0000000000000036: 10 movabsq $1237940039285380275, %r13
|
| 20 |
0000000000000040: 03 movq %rsp, %r15
|
| 21 |
0000000000000043: 05 leaq 16(%rsp), %r12
|
| 22 |
0000000000000048: 08 nopl (%rax,%rax)
|
| 23 |
+
0000000000000050: 03 movl 96(%rbx), %eax
|
| 24 |
+
0000000000000053: 02 testl %eax, %eax
|
| 25 |
+
0000000000000055: 02 je 0x407780 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x70>
|
| 26 |
+
0000000000000057: 03 cmpl $1, %eax
|
| 27 |
+
000000000000005a: 02 jne 0x407790 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x80>
|
| 28 |
+
000000000000005c: 05 callq 0x422240 <BloombergLP::bsls::SystemTime::nowMonotonicClock()>
|
| 29 |
+
0000000000000061: 02 jmp 0x407785 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x75>
|
| 30 |
+
0000000000000063: 10 nopw %cs:(%rax,%rax)
|
| 31 |
+
000000000000006d: 03 nopl (%rax)
|
| 32 |
+
0000000000000070: 05 callq 0x4222d0 <BloombergLP::bsls::SystemTime::nowRealtimeClock()>
|
| 33 |
+
0000000000000075: 02 jmp 0x407794 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x84>
|
| 34 |
+
0000000000000077: 09 nopw (%rax,%rax)
|
| 35 |
+
0000000000000080: 02 xorl %edx, %edx
|
| 36 |
+
0000000000000082: 02 xorl %eax, %eax
|
| 37 |
+
0000000000000084: 04 movq %rax, (%rsp)
|
| 38 |
+
0000000000000088: 04 movl %edx, 8(%rsp)
|
| 39 |
+
000000000000008c: 04 movq (%rbp), %rcx
|
| 40 |
+
0000000000000090: 03 subq %r14, %rcx
|
| 41 |
+
0000000000000093: 03 movq %rcx, %rax
|
| 42 |
+
0000000000000096: 03 imulq %r13
|
| 43 |
+
0000000000000099: 03 movq %rdx, %rax
|
| 44 |
+
000000000000009c: 04 shrq $63, %rax
|
| 45 |
+
00000000000000a0: 04 sarq $26, %rdx
|
| 46 |
+
00000000000000a4: 03 addq %rax, %rdx
|
| 47 |
+
00000000000000a7: 06 imull $3294967296, %edx, %eax
|
| 48 |
+
00000000000000ad: 02 addl %eax, %ecx
|
| 49 |
+
00000000000000af: 03 movq %r15, %rdi
|
| 50 |
+
00000000000000b2: 03 movq %rdx, %rsi
|
| 51 |
+
00000000000000b5: 02 movl %ecx, %edx
|
| 52 |
+
00000000000000b7: 05 callq 0x4223f0 <BloombergLP::bsls::TimeInterval::addInterval(long long, int)>
|
| 53 |
+
00000000000000bc: 03 movups (%rax), %xmm0
|
| 54 |
+
00000000000000bf: 05 movaps %xmm0, 16(%rsp)
|
| 55 |
+
00000000000000c4: 07 movq $-268435456, %rax
|
| 56 |
+
00000000000000cb: 01 lock
|
| 57 |
+
00000000000000cc: 04 xaddq %rax, (%rbx)
|
| 58 |
+
00000000000000d0: 05 testl $16777216, %eax
|
| 59 |
+
00000000000000d5: 02 jne 0x40783b <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x12b>
|
| 60 |
+
00000000000000d7: 07 leaq -268435456(%rax), %rdx
|
| 61 |
+
00000000000000de: 03 movq %rdx, %rcx
|
| 62 |
+
00000000000000e1: 04 sarq $28, %rcx
|
| 63 |
+
00000000000000e5: 05 andl $16777215, %eax
|
| 64 |
+
00000000000000ea: 03 cmpq %rax, %rcx
|
| 65 |
+
00000000000000ed: 06 jge 0x407895 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x185>
|
| 66 |
+
00000000000000f3: 03 movq %rbx, %rdi
|
| 67 |
+
00000000000000f6: 03 movq %r12, %rsi
|
| 68 |
+
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)>
|
| 69 |
+
00000000000000fe: 03 cmpl $-2, %eax
|
| 70 |
+
0000000000000101: 06 jne 0x40789a <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18a>
|
| 71 |
+
0000000000000107: 05 callq 0x4028a0 <_ZNSt3__16chrono12steady_clock3nowEv@plt>
|
| 72 |
+
000000000000010c: 03 movq %rax, %r14
|
| 73 |
+
000000000000010f: 04 shrq $63, %r14
|
| 74 |
+
0000000000000113: 03 addq %rax, %r14
|
| 75 |
+
0000000000000116: 03 sarq %r14
|
| 76 |
+
0000000000000119: 04 cmpq (%rbp), %r14
|
| 77 |
+
000000000000011d: 06 jl 0x407760 <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x50>
|
| 78 |
+
0000000000000123: 06 movl $4294967294, %r15d
|
| 79 |
+
0000000000000129: 02 jmp 0x40789d <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18d>
|
| 80 |
+
000000000000012b: 05 movl $268435456, %eax
|
| 81 |
+
0000000000000130: 01 lock
|
| 82 |
+
0000000000000131: 04 xaddq %rax, (%rbx)
|
| 83 |
+
0000000000000135: 06 movl $4294967295, %r15d
|
| 84 |
+
000000000000013b: 05 testl $16777215, %eax
|
| 85 |
+
0000000000000140: 02 je 0x40789d <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18d>
|
| 86 |
+
0000000000000142: 02 movl %eax, %ecx
|
| 87 |
+
0000000000000144: 06 andl $16777216, %ecx
|
| 88 |
+
000000000000014a: 03 testq %rcx, %rcx
|
| 89 |
+
000000000000014d: 02 jne 0x40789d <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18d>
|
| 90 |
+
000000000000014f: 06 addq $268435456, %rax
|
| 91 |
+
0000000000000155: 06 andq $-268435456, %rax
|
| 92 |
+
000000000000015b: 06 cmpq $268435456, %rax
|
| 93 |
+
0000000000000161: 02 jne 0x40789d <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18d>
|
| 94 |
+
0000000000000163: 04 leaq 8(%rbx), %rbp
|
| 95 |
+
0000000000000167: 03 movq %rbp, %rdi
|
| 96 |
+
000000000000016a: 05 callq 0x402970 <pthread_mutex_lock@plt>
|
| 97 |
+
000000000000016f: 03 movq %rbp, %rdi
|
| 98 |
+
0000000000000172: 05 callq 0x4029e0 <pthread_mutex_unlock@plt>
|
| 99 |
+
0000000000000177: 04 addq $48, %rbx
|
| 100 |
+
000000000000017b: 03 movq %rbx, %rdi
|
| 101 |
+
000000000000017e: 05 callq 0x4026b0 <pthread_cond_signal@plt>
|
| 102 |
+
0000000000000183: 02 jmp 0x40789d <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18d>
|
| 103 |
+
0000000000000185: 03 xorl %r15d, %r15d
|
| 104 |
+
0000000000000188: 02 jmp 0x40789d <int BloombergLP::bslmt::ChronoUtil::timedWait<BloombergLP::bslmt::FastPostSemaphore, HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > >(BloombergLP::bslmt::FastPostSemaphore*, std::__1::chrono::time_point<HalfClock, std::__1::chrono::duration<long long, std::__1::ratio<1l, 1000000000l> > > const&)+0x18d>
|
| 105 |
+
000000000000018a: 03 movl %eax, %r15d
|
| 106 |
+
000000000000018d: 03 movl %r15d, %eax
|
| 107 |
+
0000000000000190: 04 addq $40, %rsp
|
| 108 |
+
0000000000000194: 01 popq %rbx
|
| 109 |
+
0000000000000195: 02 popq %r12
|
| 110 |
+
0000000000000197: 02 popq %r13
|
| 111 |
+
0000000000000199: 02 popq %r14
|
| 112 |
+
000000000000019b: 02 popq %r15
|
| 113 |
+
000000000000019d: 01 popq %rbp
|
| 114 |
+
000000000000019e: 01 retq
|
| 115 |
+
000000000000019f: 01 nop
|