; assembly | /* r2dec pseudo code output */ | /* bdlc_compactedarray.t/none @ 0x4332c0 */ | #include | ; (fcn) method.void_BloombergLP::bslalg::ArrayPrimitives_Imp::copyConstruct_BloombergLP::bdlc::CompactedArray_CountedValue_bsl::basic_string_char__std::__1::char_traits_char___bsl::allocator_char_______BloombergLP::bdlc::CompactedArray_CountedValue_bsl::basic_st () | int64_t method_void_BloombergLP::bslalg::ArrayPrimitives_Imp::copyConstruct_BloombergLP::bdlc::CompactedArray_CountedValue_bsl::basic_string_char_std::_1::char_traits_char_bsl::allocator_char_BloombergLP::bdlc::CompactedArray_CountedValue_bsl::basic_st (int64_t arg4, int64_t arg3, uint32_t arg2, uint32_t arg1) { | rcx = arg4; | rdx = arg3; | rsi = arg2; | rdi = arg1; | /* void BloombergLP::bslalg::ArrayPrimitives_Imp::copyConstruct, bsl::allocator > >, BloombergLP::bdlc::CompactedArray_CountedValue, bsl::allocator > > const*, bsl::allocator, bsl::allocator > > > >(BloombergLP::bdlc::CompactedArray_CountedValue, bsl::allocator > >*, BloombergLP::bdlc::CompactedArray_CountedValue, bsl::allocator > > const*, BloombergLP::bdlc::CompactedArray_CountedValue, bsl::allocator > > const*, bsl::allocator, bsl::allocator > > >, BloombergLP::bslmf::MetaInt<0>*) */ 0x004332c0 push rbp | 0x004332c1 push r15 | 0x004332c3 push r14 | 0x004332c5 push r13 | 0x004332c7 push r12 | 0x004332c9 push rbx | 0x004332ca push rax | 0x004332cb cmp rsi, rdx | | if (rsi == rdx) { 0x004332ce je 0x4333c8 | goto label_3; | } 0x004332d4 mov r14, rcx | r14 = rcx; 0x004332d7 mov r15, rdx | r15 = rdx; 0x004332da mov r12, rsi | r12 = rsi; 0x004332dd mov r13, rdi | r13 = rdi; 0x004332e0 sub r15, rsi | r15 -= rsi; 0x004332e3 xor ebx, ebx | ebx = 0; 0x004332e5 jmp 0x433300 | goto label_4; | label_1: 0x004332e7 mov rsi, qword [r12 + rbx] | | label_2: 0x004332eb mov rdi, rax | 0x004332ee call 0x403ea0 | memcpy (rax, *((r12 + rbx)), rdx); | do { | label_0: 0x004332f3 add rbx, 0x38 | rbx += 0x38; 0x004332f7 cmp r15, rbx | | if (r15 == rbx) { 0x004332fa je 0x4333c8 | goto label_3; | } | label_4: 0x00433300 mov rax, qword [r14] | rax = *(r14); 0x00433303 mov rcx, qword [r12 + rbx + 0x30] | rcx = *((r12 + rbx + 0x30)); 0x00433308 mov qword [r13 + rbx + 0x30], rcx | *((r13 + rbx + 0x30)) = rcx; 0x0043330d test rax, rax | | if (rax == 0) { 0x00433310 jne 0x433330 | 0x00433312 mov rax, qword [rip + 0x2566a7] | rax = BloombergLP::bslma::Default::s_defaultAllocator; 0x00433319 test rax, rax | | if (rax != 0) { 0x0043331c jne 0x433330 | goto label_5; | } 0x0043331e call 0x43d890 | rax = BloombergLP::bslma::Default::determineAndReturnDefaultAllocator() (); 0x00433323 nop word cs:[rax + rax] | 0x0043332d nop dword [rax] | | } | label_5: 0x00433330 lea rbp, [r13 + rbx] | rbp = r13 + rbx; 0x00433335 mov rcx, qword [r12 + rbx + 0x20] | rcx = *((r12 + rbx + 0x20)); 0x0043333a mov qword [rbp + 0x20], rcx | *((rbp + 0x20)) = rcx; 0x0043333e movups xmm0, xmmword [r12 + rbx] | __asm ("movups xmm0, xmmword [r12 + rbx]"); 0x00433343 movups xmm1, xmmword [r12 + rbx + 0x10] | __asm ("movups xmm1, xmmword [r12 + rbx + 0x10]"); 0x00433349 movups xmmword [rbp + 0x10], xmm1 | __asm ("movups xmmword [rbp + 0x10], xmm1"); 0x0043334d movups xmmword [rbp], xmm0 | __asm ("movups xmmword [rbp], xmm0"); 0x00433351 mov qword [r13 + rbx + 0x28], rax | *((r13 + rbx + 0x28)) = rax; 0x00433356 cmp qword [r13 + rbx + 0x20], 0x17 | 0x0043335c je 0x4332f3 | | } while (*((r13 + rbx + 0x20)) == 0x17); 0x0043335e mov rcx, qword [r12 + rbx + 0x18] | rcx = *((r12 + rbx + 0x18)); 0x00433363 cmp rcx, 0x17 | 0x00433367 mov esi, 0x17 | esi = 0x17; | if (rcx > 0x17) { 0x0043336c cmova rsi, rcx | rsi = rcx; | } 0x00433370 mov qword [r13 + rbx], 0 | *((r13 + rbx)) = 0; 0x00433379 mov qword [r13 + rbx + 0x18], rcx | *((r13 + rbx + 0x18)) = rcx; 0x0043337e mov qword [r13 + rbx + 0x20], rsi | *((r13 + rbx + 0x20)) = rsi; 0x00433383 cmp rcx, 0x18 | | if (rcx >= 0x18) { 0x00433387 jb 0x4333a2 | 0x00433389 inc rsi | rsi++; 0x0043338c mov rcx, qword [rax] | rcx = *(rax); 0x0043338f mov rdi, rax | rdi = rax; 0x00433392 call qword [rcx + 0x10] | rax = uint64_t (*rcx + 0x10)() (); 0x00433395 mov qword [r13 + rbx], rax | *((r13 + rbx)) = rax; 0x0043339a cmp qword [r13 + rbx + 0x20], 0x17 | | if (*((r13 + rbx + 0x20)) != 0x17) { 0x004333a0 jne 0x4333a5 | goto label_6; | } | } 0x004333a2 mov rax, rbp | rax = rbp; | label_6: 0x004333a5 mov rdx, qword [r13 + rbx + 0x18] | rdx = *((r13 + rbx + 0x18)); 0x004333aa inc rdx | rdx++; | if (rdx == 0) { 0x004333ad je 0x4332f3 | goto label_0; | } 0x004333b3 cmp qword [r12 + rbx + 0x20], 0x17 | | if (*((r12 + rbx + 0x20)) != 0x17) { 0x004333b9 jne 0x4332e7 | goto label_1; | } 0x004333bf lea rsi, [r12 + rbx] | rsi = r12 + rbx; 0x004333c3 jmp 0x4332eb | goto label_2; | label_3: 0x004333c8 add rsp, 8 | 0x004333cc pop rbx | 0x004333cd pop r12 | 0x004333cf pop r13 | 0x004333d1 pop r14 | 0x004333d3 pop r15 | 0x004333d5 pop rbp | 0x004333d6 ret | return rax; | }