.file "vacall-x86_64.c"
.text
.p2align 4,,15
.globl __vacall
.type __vacall,@function
__vacall:
.LFB1:
pushq %r12
.LCFI0:
subq $192, %rsp
.LCFI1:
leaq 136(%rsp), %r11
leaq 208(%rsp), %r10
movq %rdi, 136(%rsp)
movq %r11, 128(%rsp)
movq %r10, 8(%rsp)
movq %rsi, 144(%rsp)
leaq 64(%rsp), %r11
movq %rdx, 152(%rsp)
movq %rcx, 160(%rsp)
movq %r8, 168(%rsp)
movq %r9, 176(%rsp)
movsd %xmm0, 64(%rsp)
movsd %xmm1, 72(%rsp)
movsd %xmm2, 80(%rsp)
movsd %xmm3, 88(%rsp)
movsd %xmm4, 96(%rsp)
movsd %xmm5, 104(%rsp)
movsd %xmm6, 112(%rsp)
movsd %xmm7, 120(%rsp)
movl $0, (%rsp)
movq $0, 16(%rsp)
movl $0, 24(%rsp)
movq %r11, 56(%rsp)
movq %rsp, %rdi
call *vacall_function(%rip)
movl 24(%rsp), %r10d
testl %r10d, %r10d
je .L1
cmpl $1, %r10d
je .L53
cmpl $2, %r10d
je .L53
cmpl $3, %r10d
je .L54
cmpl $4, %r10d
je .L55
cmpl $5, %r10d
je .L56
cmpl $6, %r10d
je .L57
cmpl $7, %r10d
je .L58
cmpl $8, %r10d
je .L52
cmpl $9, %r10d
je .L52
cmpl $10, %r10d
je .L52
cmpl $11, %r10d
je .L52
cmpl $12, %r10d
je .L59
cmpl $13, %r10d
je .L60
cmpl $14, %r10d
je .L52
cmpl $15, %r10d
je .L61
.p2align 4,,7
.L1:
addq $192, %rsp
popq %r12
ret
.L61:
movl (%rsp), %r10d
testl $1, %r10d
je .L33
movq 16(%rsp), %rax
jmp .L1
.L33:
andl $1024, %r10d
je .L1
movq 32(%rsp), %r11
leaq -1(%r11), %r10
cmpq $15, %r10
ja .L1
movq 16(%rsp), %r12
cmpq $1, %r11
movzbq (%r12), %rax
jbe .L37
movzbq 1(%r12), %r10
salq $8, %r10
orq %r10, %rax
.L37:
cmpq $2, %r11
jbe .L38
movzbq 2(%r12), %r10
salq $16, %r10
orq %r10, %rax
.L38:
cmpq $3, %r11
jbe .L39
movzbq 3(%r12), %r10
salq $24, %r10
orq %r10, %rax
.L39:
cmpq $4, %r11
jbe .L40
movzbq 4(%r12), %r10
salq $32, %r10
orq %r10, %rax
.L40:
cmpq $5, %r11
jbe .L41
movzbq 5(%r12), %r10
salq $40, %r10
orq %r10, %rax
.L41:
cmpq $6, %r11
jbe .L42
movzbq 6(%r12), %r10
salq $48, %r10
orq %r10, %rax
.L42:
cmpq $7, %r11
jbe .L43
movzbq 7(%r12), %r10
salq $56, %r10
orq %r10, %rax
.L43:
cmpq $8, %r11
jbe .L1
cmpq $9, %r11
movzbq 8(%r12), %rdx
jbe .L45
movzbq 9(%r12), %r10
salq $8, %r10
orq %r10, %rdx
.L45:
cmpq $10, %r11
jbe .L46
movzbq 10(%r12), %r10
salq $16, %r10
orq %r10, %rdx
.L46:
cmpq $11, %r11
jbe .L47
movzbq 11(%r12), %r10
salq $24, %r10
orq %r10, %rdx
.L47:
cmpq $12, %r11
jbe .L48
movzbq 12(%r12), %r10
salq $32, %r10
orq %r10, %rdx
.L48:
cmpq $13, %r11
jbe .L49
movzbq 13(%r12), %r10
salq $40, %r10
orq %r10, %rdx
.L49:
cmpq $14, %r11
jbe .L50
movzbq 14(%r12), %r10
salq $48, %r10
orq %r10, %rdx
.L50:
cmpq $15, %r11
jbe .L1
movzbq 15(%r12), %r10
salq $56, %r10
orq %r10, %rdx
jmp .L1
.p2align 4,,7
.L52:
movq 40(%rsp), %rax
jmp .L1
.L60:
movlpd 40(%rsp), %xmm0
jmp .L1
.L59:
movss 40(%rsp), %xmm0
jmp .L1
.L58:
mov 40(%rsp), %eax
jmp .L1
.L57:
movslq 40(%rsp),%rax
jmp .L1
.L56:
movzwq 40(%rsp), %rax
jmp .L1
.L55:
movswq 40(%rsp),%rax
jmp .L1
.L54:
movzbq 40(%rsp), %rax
jmp .L1
.p2align 4,,7
.L53:
movsbq 40(%rsp),%rax
jmp .L1
.LFE1:
.Lfe1:
.size __vacall,.Lfe1-__vacall
.section .eh_frame,"aw",@progbits
.Lframe1:
.long .LECIE1-.LSCIE1
.LSCIE1:
.long 0x0
.byte 0x1
.string ""
.uleb128 0x1
.sleb128 -8
.byte 0x10
.byte 0xc
.uleb128 0x7
.uleb128 0x8
.byte 0x90
.uleb128 0x1
.align 8
.LECIE1:
.LSFDE1:
.long .LEFDE1-.LASFDE1
.LASFDE1:
.long .LASFDE1-.Lframe1
.quad .LFB1
.quad .LFE1-.LFB1
.byte 0x4
.long .LCFI0-.LFB1
.byte 0xe
.uleb128 0x10
.byte 0x4
.long .LCFI1-.LCFI0
.byte 0xe
.uleb128 0xd0
.byte 0x8c
.uleb128 0x2
.align 8
.LEFDE1:
.ident "GCC: (GNU) 3.2.2 (SuSE Linux)"