File ffcall/vacall/vacall-x86_64.s artifact 37dd72f336 part of check-in bbf0503430


	.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)"