⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 t1k7i_15.s

📁 最新的FFT程序
💻 S
字号:
/* * Copyright (c) 2003, 2006 Matteo Frigo * Copyright (c) 2003, 2006 Massachusetts Institute of Technology * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * *//* This file was automatically generated --- DO NOT EDIT *//* Generated on Fri Jan 27 20:13:22 EST 2006 */#include "config.h"/* cheap-mode: VECTGRADE_FULL succeeded. (207 steps) *//* Generated by: ../../../genfft-k7/gen_twiddle -no-randomized-cse -n 15 -sign 1 -name t1k7i_15 *//* * Generator Id's :  * $Id: algsimp.ml,v 1.4 2006-01-05 03:04:27 stevenj Exp $ * $Id: fft.ml,v 1.4 2006-01-05 03:04:27 stevenj Exp $ * $Id: gen_twiddle.ml,v 1.14 2005-12-24 21:08:49 athena Exp $ *//* The following asm code is Copyright (c) 2000-2001 Stefan Kral */.section .rodata	.balign 64KP500000000KP500000000: .float +0.500000000000000000000000000000000000000000000, +0.500000000000000000000000000000000000000000000KP866025403KP866025403: .float +0.866025403784438646763723170752936183471402627, +0.866025403784438646763723170752936183471402627KN866025403KN866025403: .float -0.866025403784438646763723170752936183471402627, -0.866025403784438646763723170752936183471402627KP951056516KP587785252: .float +0.951056516295153572116439333379382143405698634, +0.587785252292473129168705954639072768597652438KP587785252KP951056516: .float +0.587785252292473129168705954639072768597652438, +0.951056516295153572116439333379382143405698634KP250000000KP250000000: .float +0.250000000000000000000000000000000000000000000, +0.250000000000000000000000000000000000000000000KP559016994KP559016994: .float +0.559016994374947424102293417182819058860154590, +0.559016994374947424102293417182819058860154590chs_lo: .long 0x80000000, 0x00000000.text.text	.balign 64t1k7i_15:	subl $212, %esp	femms 	movl %ebx, 208(%esp)	movl 228(%esp), %edx	movl 236(%esp), %ebx	movl %esi, 204(%esp)	movl %edi, 200(%esp)	movl 220(%esp), %ecx	movl %ebp, 196(%esp)	movl 224(%esp), %eax	movl 232(%esp), %esi	leal (,%edx,4), %edx	leal (,%ebx,4), %ebx	.p2align 4,,7.L0:	/* promise simd cell size = 8 */ 	leal (%edx,%edx,4), %edi	movq 72(%eax), %mm0	movq 32(%eax), %mm3	leal (%edx,%edx,8), %ebp	movq (%ecx,%edi,2), %mm1	movq (%ecx,%edi), %mm4	leal (%edx,%edx,2), %edi	movq (%ecx,%ebp), %mm6	leal (%edi,%edx,8), %ebp	pswapd %mm1, %mm2	pswapd %mm4, %mm5	pfmul %mm0, %mm1	pswapd %mm6, %mm7	pfmul %mm0, %mm2	movq 64(%eax), %mm0	pfmul %mm3, %mm5	pfmul %mm3, %mm4	pfmul %mm0, %mm6	pfacc %mm5, %mm2	movq (%ecx,%edi,2), %mm5	pfmul %mm0, %mm7	pfnacc %mm1, %mm4	movq 40(%eax), %mm1	pswapd %mm5, %mm0	movq %mm4, %mm3	pfmul %mm1, %mm5	pfacc %mm2, %mm4	pfmul %mm1, %mm0	movq (%ecx,%edi), %mm1	pfnacc %mm3, %mm2	movq 16(%eax), %mm3	pfnacc %mm6, %mm5	movq %mm4, 16(%esp)	pfmul KP500000000KP500000000, %mm4	pswapd %mm1, %mm6	pfacc %mm7, %mm0	movq 88(%eax), %mm7	pfmul %mm3, %mm1	pfmul %mm3, %mm6	pfmul KP866025403KP866025403, %mm2	movq %mm0, 32(%esp)	movq %mm4, 8(%esp)	movq (%ecx,%edi,4), %mm3	movq 24(%eax), %mm4	pswapd %mm3, %mm0	pfmul %mm7, %mm3	pfmul %mm7, %mm0	movq %mm2, 0(%esp)	movq (%ecx,%edx,4), %mm7	pfnacc %mm3, %mm1	movq 80(%eax), %mm3	pfacc %mm0, %mm6	pswapd %mm7, %mm2	movq (%ecx,%ebp), %mm0	leal (%edi,%edx,4), %ebp	pfmul %mm4, %mm7	pfmul %mm4, %mm2	movq %mm1, 40(%esp)	movq %mm6, 24(%esp)	movq 104(%eax), %mm4	movq (%ecx,%ebp,2), %mm6	pswapd %mm0, %mm1	pfmul %mm3, %mm0	pfmul %mm3, %mm1	pswapd %mm6, %mm3	pfmul %mm4, %mm6	pfmul %mm4, %mm3	movq (%eax), %mm4	pfnacc %mm7, %mm6	movq (%ecx,%edx), %mm7	pfacc %mm2, %mm3	pswapd %mm7, %mm2	pfmul %mm4, %mm7	pfmul %mm4, %mm2	movq %mm3, 56(%esp)	movq 48(%eax), %mm3	pfnacc %mm7, %mm0	movq (%ecx,%ebp), %mm7	leal (%edx,%edi,4), %ebp	leal (%edx,%edx,2), %edi	pfacc %mm2, %mm1	movq %mm0, %mm4	pfnacc %mm6, %mm0	pswapd %mm7, %mm2	pfmul %mm3, %mm7	pfacc %mm6, %mm4	movq %mm1, 64(%esp)	movq (%ecx,%edx,8), %mm6	movq 56(%eax), %mm1	pfmul %mm3, %mm2	pfmul KP866025403KP866025403, %mm0	pswapd %mm6, %mm3	movq %mm4, 72(%esp)	movq 8(%eax), %mm4	pfmul %mm1, %mm6	pfmul %mm1, %mm3	movq %mm0, 48(%esp)	movq (%ecx,%edx,2), %mm1	pswapd %mm1, %mm0	pfmul %mm4, %mm1	pfmul %mm4, %mm0	movq 96(%eax), %mm4	addl $112, %eax	pfnacc %mm7, %mm1	movq (%ecx,%ebp), %mm7	leal (%edx,%edx,8), %ebp	pfacc %mm2, %mm0	pswapd %mm7, %mm2	pfmul %mm4, %mm7	pfmul %mm4, %mm2	movq 72(%esp), %mm4	pfnacc %mm7, %mm6	movq %mm5, %mm7	pfacc %mm2, %mm3	pfadd %mm4, %mm5	pfmul KP500000000KP500000000, %mm4	movq %mm6, %mm2	pfnacc %mm1, %mm6	pfacc %mm1, %mm2	movq 40(%esp), %mm1	pfmul KP866025403KP866025403, %mm6	pfsub %mm4, %mm7	movq %mm1, %mm4	pfadd %mm2, %mm1	pfmul KP500000000KP500000000, %mm2	pfsub %mm2, %mm4	movq %mm1, %mm2	pfacc %mm5, %mm1	pfnacc %mm5, %mm2	movq %mm1, 80(%esp)	movq %mm2, 88(%esp)	movq 64(%esp), %mm5	movq 56(%esp), %mm1	movq %mm5, %mm2	pfnacc %mm1, %mm5	pfacc %mm1, %mm2	movq %mm7, %mm1	pfmul KN866025403KN866025403, %mm5	pfadd %mm5, %mm1	pfsub %mm5, %mm7	movq %mm3, %mm5	pfnacc %mm0, %mm3	pfacc %mm0, %mm5	movq %mm2, %mm0	movq %mm1, 112(%esp)	movq %mm4, %mm1	movq %mm7, 96(%esp)	pfmul KP500000000KP500000000, %mm0	pfmul KN866025403KN866025403, %mm3	movq 32(%esp), %mm7	pfsub %mm3, %mm4	pfadd %mm3, %mm1	movq %mm7, %mm3	pfadd %mm2, %mm7	movq %mm5, %mm2	pfsub %mm0, %mm3	movq 24(%esp), %mm0	pfmul KP500000000KP500000000, %mm2	movq %mm4, 104(%esp)	movq %mm0, %mm4	pfadd %mm5, %mm0	pfsub %mm2, %mm4	movq %mm0, %mm5	pfnacc %mm7, %mm0	pfacc %mm7, %mm5	movq 48(%esp), %mm7	movq %mm4, %mm2	pfsub %mm6, %mm4	pfadd %mm6, %mm2	movq %mm3, %mm6	pfsub %mm7, %mm3	movq %mm4, 128(%esp)	movq 88(%esp), %mm4	pfadd %mm7, %mm6	pswapd %mm0, %mm7	pfmul KP951056516KP587785252, %mm0	movq %mm2, 144(%esp)	movq %mm3, 120(%esp)	movq 80(%esp), %mm3	movq %mm4, %mm2	pfmul KP951056516KP587785252, %mm7	movq %mm6, 136(%esp)	pfmul KP587785252KP951056516, %mm4	pfmul KP951056516KP587785252, %mm2	movq %mm3, %mm6	pfacc %mm5, %mm3	pfnacc %mm5, %mm6	movq (%ecx), %mm5	/* simd data load/store barrier */ 	pfnacc %mm4, %mm7	movq %mm3, %mm4	pfacc %mm2, %mm0	movq %mm5, %mm2	pfmul KP250000000KP250000000, %mm4	pfsub 8(%esp), %mm5	pfmul KP559016994KP559016994, %mm6	pfadd 16(%esp), %mm2	pxor chs_lo, %mm0	movq %mm5, 152(%esp)	movq %mm2, %mm5	pfsub %mm4, %mm2	pfadd %mm3, %mm5	movq %mm2, %mm4	pfadd %mm6, %mm2	pfsub %mm6, %mm4	movq 112(%esp), %mm6	movq %mm5, (%ecx)	movq %mm1, %mm5	movq %mm2, %mm3	pfsub %mm0, %mm2	pfadd %mm0, %mm3	movq %mm4, %mm0	pfsub %mm7, %mm4	pfadd %mm7, %mm0	movq 144(%esp), %mm7	movq %mm2, (%ecx,%ebp)	pfnacc %mm6, %mm1	movq %mm3, (%ecx,%edi,2)	movq 136(%esp), %mm3	pfacc %mm6, %mm5	movq %mm4, (%ecx,%edi)	movq %mm7, %mm6	movq %mm0, (%ecx,%edi,4)	movq 104(%esp), %mm0	movq %mm1, %mm2	pfmul KP587785252KP951056516, %mm1	leal (%edx,%edx,4), %edi	pfnacc %mm3, %mm7	pfmul KP951056516KP587785252, %mm2	pfacc %mm3, %mm6	movq 96(%esp), %mm3	leal (%edx,%edi,2), %ebp	pswapd %mm7, %mm4	pfmul KP951056516KP587785252, %mm7	pfmul KP951056516KP587785252, %mm4	pfacc %mm2, %mm7	movq %mm0, %mm2	pfacc %mm3, %mm0	pfnacc %mm1, %mm4	pfnacc %mm3, %mm2	movq 128(%esp), %mm3	pxor chs_lo, %mm7	movq %mm4, 168(%esp)	movq 120(%esp), %mm4	movq %mm2, %mm1	pfmul KP951056516KP587785252, %mm2	movq %mm7, 160(%esp)	movq %mm3, %mm7	pfmul KP587785252KP951056516, %mm1	pfnacc %mm4, %mm3	pfacc %mm4, %mm7	pswapd %mm3, %mm4	pfmul KP951056516KP587785252, %mm3	pfmul KP951056516KP587785252, %mm4	pfacc %mm2, %mm3	movq 152(%esp), %mm2	pfnacc %mm1, %mm4	movq 0(%esp), %mm1	pxor chs_lo, %mm3	movq %mm3, 176(%esp)	movq %mm2, %mm3	pfsub %mm1, %mm2	pfadd %mm1, %mm3	movq %mm0, %mm1	pfacc %mm7, %mm0	pfnacc %mm7, %mm1	movq %mm5, %mm7	pfnacc %mm6, %mm5	pfacc %mm6, %mm7	pfmul KP559016994KP559016994, %mm1	pfmul KP559016994KP559016994, %mm5	movq %mm7, %mm6	pfmul KP250000000KP250000000, %mm6	movq %mm5, 184(%esp)	movq %mm3, %mm5	pfadd %mm7, %mm3	movq %mm2, %mm7	pfadd %mm0, %mm2	pfmul KP250000000KP250000000, %mm0	pfsub %mm6, %mm5	movq %mm3, (%ecx,%edi,2)	movq 176(%esp), %mm3	movq %mm2, (%ecx,%edi)	pfsub %mm0, %mm7	movq %mm7, %mm6	pfadd %mm1, %mm7	pfsub %mm1, %mm6	movq 184(%esp), %mm1	movq %mm7, %mm2	pfsub %mm3, %mm7	pfadd %mm3, %mm2	movq %mm1, %mm3	movq %mm6, %mm0	pfsub %mm4, %mm6	pfsubr %mm5, %mm3	pfadd %mm5, %mm1	movq 160(%esp), %mm5	movq %mm2, (%ecx,%ebp)	movq 168(%esp), %mm2	pfadd %mm4, %mm0	movq %mm6, (%ecx,%edx,8)	leal (%edi,%edx,2), %ebp	movq %mm3, %mm6	movq %mm1, %mm4	pfsub %mm5, %mm1	movq %mm7, (%ecx,%ebp,2)	pfadd %mm2, %mm6	movq %mm0, (%ecx,%edx,2)	pfsub %mm2, %mm3	pfadd %mm5, %mm4	movq %mm1, (%ecx,%edx,4)	movq %mm6, (%ecx,%ebp)	leal (%edi,%edx,8), %ebp	movq %mm4, (%ecx,%edx)	movq %mm3, (%ecx,%ebp)	addl %ebx, %ecx	decl %esi	jnz .L0	femms 	movl 208(%esp), %ebx	movl 204(%esp), %esi	movl 200(%esp), %edi	movl 196(%esp), %ebp	addl $212, %esp	ret .section .rodatanam:	.string "t1k7i_15"	.align 4twinstr:	.byte 4	.byte 0	.value 15	.byte 3	.byte 1	.value 0	.align 4desc:	.long 15	.long nam	.long twinstr	.long fftwf_kdft_ct_k7_pgenus	.double 92	.double 56	.double 0	.double 0	.long 0	.long 0	.long 0.text	.align 4.globl fftwf_codelet_t1k7i_15fftwf_codelet_t1k7i_15:	subl $12,%esp	movl 16(%esp),%eax	addl $-4,%esp	pushl $desc	pushl $t1k7i_15	pushl %eax	call fftwf_kdft_dit_register	addl $16,%esp	addl $12,%esp	ret

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -