| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583 | /** Math library** Copyright (C) 2016 Intel Corporation. All rights reserved.** Redistribution and use in source and binary forms, with or without* modification, are permitted provided that the following conditions* are met:**   * Redistributions of source code must retain the above copyright*     notice, this list of conditions and the following disclaimer.*   * Redistributions in binary form must reproduce the above copyright*     notice, this list of conditions and the following disclaimer in*     the documentation and/or other materials provided with the*     distribution.*   * Neither the name of Intel Corporation nor the names of its*     contributors may be used to endorse or promote products derived*     from this software without specific prior written permission.** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.*** Author Name <jingwei.zhang@intel.com>*   History:*   03-14-2016 Initial version. numerics svn rev. 12864*/	.file "erf.c"	.text..TXTST0:# -- Begin  erf	.text       .align    16,0x90	.globl erferf:# parameter 1: 8 + %ebp..B1.1:..L1:        pushl     %ebp        movl      %esp, %ebp        andl      $-16, %esp        pushl     %esi        pushl     %edi        subl      $24, %esp..B1.2:        fnstcw    14(%esp)..B1.3:        movl      12(%ebp), %ecx        movl      %ecx, %eax        andl      $-2147483648, %eax        andl      $2147483647, %ecx        orl       $1065353216, %eax        movl      %eax, 16(%esp)        cmpl      $1075298304, %ecx        flds      16(%esp)        movl      8(%ebp), %esi        fstpt     (%esp)        call      ..L2..L2:        popl      %edx        lea       _GLOBAL_OFFSET_TABLE_+[. - ..L2](%edx), %edx        jge       ..B1.11..B1.4:        movzwl    14(%esp), %esi        movl      %esi, %eax        andl      $768, %eax        cmpl      $768, %eax        je        ..B1.15..B1.5:        orl       $-64768, %esi        movw      %si, 12(%esp)..B1.6:        fldcw     12(%esp)..B1.7:        movl      $1, %eax..B1.8:        fldl      8(%ebp)        lea       -1074331648(%ecx), %esi        shrl      $20, %ecx        fabs              fldt      (%esp)        addl      $-1021, %ecx        cmpl      $458751, %esi        ja        ..L3        movl      $5, %ecx..L3:        testl     %ecx, %ecx        jg        ..L4        movl      $0, %ecx..L4:        movl      %ecx, %edi        lea       (%ecx,%ecx,2), %esi        shll      $4, %edi        shll      $7, %ecx        shll      $4, %esi        testl     %eax, %eax        fxch      %st(1)        fmull     erfRRTable@GOTOFF(%edi,%edx)        fldl      120+_dbA@GOTOFF(%edx,%ecx)        fldt      36+_ldbA@GOTOFF(%edx,%esi)        fldt      24+_ldbA@GOTOFF(%edx,%esi)        fldt      12+_ldbA@GOTOFF(%edx,%esi)        fldt      _ldbA@GOTOFF(%edx,%esi)        fxch      %st(5)        faddl     8+erfRRTable@GOTOFF(%edx,%edi)        fmul      %st, %st(4)        fxch      %st(4)        faddl     112+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     104+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     96+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     88+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     80+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     72+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     64+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     56+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     48+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     40+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     32+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     24+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     16+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     8+_dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddl     _dbA@GOTOFF(%edx,%ecx)        fmul      %st(4), %st        faddp     %st, %st(3)        fxch      %st(2)        fmul      %st(3), %st        faddp     %st, %st(1)        fmul      %st(2), %st        faddp     %st, %st(1)        fmulp     %st, %st(1)        faddp     %st, %st(1)        fmulp     %st, %st(1)        fstpt     (%esp)        je        ..B1.10..B1.9:        fldcw     14(%esp)..B1.10:        fldt      (%esp)        addl      $24, %esp        popl      %edi        popl      %esi        movl      %ebp, %esp        popl      %ebp        ret       ..B1.11:        cmpl      $2146435072, %ecx        jl        ..B1.14..B1.12:        je        ..B1.16..B1.13:        fldl      8(%ebp)        fadd      %st(0), %st        addl      $24, %esp        popl      %edi        popl      %esi        movl      %ebp, %esp        popl      %ebp        ret       ..B1.14:        fldl      768+_dbA@GOTOFF(%edx)        fldl      776+_dbA@GOTOFF(%edx)        fldt      (%esp)        fmul      %st, %st(2)        fmulp     %st, %st(1)        faddp     %st, %st(1)        addl      $24, %esp        popl      %edi        popl      %esi        movl      %ebp, %esp        popl      %ebp        ret       ..B1.15:        xorl      %eax, %eax        jmp       ..B1.8..B1.16:        testl     %esi, %esi        jne       ..B1.13..B1.17:        fldt      (%esp)        addl      $24, %esp        popl      %edi        popl      %esi        movl      %ebp, %esp        popl      %ebp        ret               .align    16,0x90	.type	erf,@function	.size	erf,.-erf	.data# -- End  erf	.section .rodata, "a"	.align 16	.align 16erfRRTable:	.long	0x00000000,0x3ff00000	.long	0x00000000,0x00000000	.long	0x00000000,0x40000000	.long	0x00000000,0xbff80000	.long	0x00000000,0x3ff00000	.long	0x00000000,0xbff80000	.long	0x00000000,0x3fe00000	.long	0x00000000,0xbff80000	.long	0x00000000,0x3fd00000	.long	0x00000000,0xbff80000	.long	0x00000000,0x3ff00000	.long	0x00000000,0xc00d0000	.type	erfRRTable,@object	.size	erfRRTable,96	.align 16_dbA:	.long	0	.long	0	.long	436480805	.long	1069343474	.long	0	.long	0	.long	824702180	.long	3214639822	.long	0	.long	0	.long	3500778474	.long	1064658364	.long	0	.long	0	.long	596585212	.long	3209429723	.long	0	.long	0	.long	1470240973	.long	1059035690	.long	0	.long	0	.long	718843426	.long	3203353528	.long	0	.long	0	.long	2710426178	.long	1052473157	.long	0	.long	0	.long	3010232270	.long	3196296923	.long	3936437656	.long	1065568693	.long	2299323409	.long	3210429089	.long	2523607943	.long	3208348791	.long	2965083678	.long	1059250351	.long	798914934	.long	1055054643	.long	3446493953	.long	3202367749	.long	3957742900	.long	1049125428	.long	3166330044	.long	1049915994	.long	2437497479	.long	3193689582	.long	3701813711	.long	3192118067	.long	4254294173	.long	1041707319	.long	3041595886	.long	1039011503	.long	177055818	.long	3184215269	.long	4076941640	.long	3180389574	.long	3283211378	.long	1031330936	.long	2299430385	.long	1025878376	.long	1560943562	.long	3215381929	.long	649600356	.long	3213783607	.long	1925487767	.long	1066650173	.long	2787104668	.long	3212012915	.long	3819886810	.long	3210959588	.long	3292869653	.long	1062994816	.long	595535285	.long	3206044511	.long	2833470226	.long	3207638255	.long	3150087827	.long	1058299310	.long	4226975388	.long	1056101349	.long	3511121228	.long	3203239297	.long	4191453678	.long	1050931364	.long	2398545468	.long	1052356106	.long	1036696996	.long	3197521914	.long	406902450	.long	3195737434	.long	932124879	.long	1046963798	.long	2984826674	.long	3213958277	.long	1416337143	.long	1067493301	.long	1528223327	.long	3215470371	.long	2077734896	.long	1068079284	.long	500891590	.long	3215043166	.long	1614001607	.long	1065167414	.long	397732724	.long	1066426356	.long	245285475	.long	3214320360	.long	2942435727	.long	1065970365	.long	2515085614	.long	1062242098	.long	2059023426	.long	3212710123	.long	3590542062	.long	1064841017	.long	1069940521	.long	1062119991	.long	329470371	.long	1062390329	.long	2904189456	.long	1064709094	.long	1072026573	.long	1063487818	.long	2999885720	.long	3188887951	.long	3321998034	.long	3194165661	.long	778559078	.long	3198831619	.long	4123899724	.long	3202964980	.long	708728771	.long	3206666523	.long	2191638927	.long	3209872513	.long	2647513773	.long	3212706538	.long	349076715	.long	3215092788	.long	3464000864	.long	3217125251	.long	2469419808	.long	3218694220	.long	396951367	.long	3219923315	.long	545534675	.long	3220654754	.long	3101724493	.long	3220952863	.long	496398401	.long	3220607311	.long	1221104108	.long	3219519496	.long	4256169036	.long	3217191486	.long	2904280702	.long	3204470624	.long	1218817182	.long	1057276414	.long	54035796	.long	3204757890	.long	4162943463	.long	1056998848	.long	3226000836	.long	3203731619	.long	1250945068	.long	1055200853	.long	1745105165	.long	3201249698	.long	1720233031	.long	1051395895	.long	2751609749	.long	1047829350	.long	3766093227	.long	3196386836	.long	2511730864	.long	1047725585	.long	1042659329	.long	3192914318	.long	2981264223	.long	3189366070	.long	673045009	.long	1042560833	.long	421746295	.long	3188353310	.long	3454229363	.long	3184015574	.long	4294967295	.long	1072693247	.long	0	.long	1017102336	.type	_dbA,@object	.size	_dbA,784	.align 16_ldbA:	.word	0	.word	0	.word	0	.word	0	.word	0	.word	0	.word	26765	.word	5339	.word	47746	.word	36974	.word	16383	.word	0	.word	0	.word	0	.word	0	.word	0	.word	0	.word	0	.word	13107	.word	7119	.word	41816	.word	49299	.word	49149	.word	0	.word	64355	.word	59506	.word	19372	.word	46606	.word	16382	.word	0	.word	9448	.word	50838	.word	8555	.word	42135	.word	16381	.word	0	.word	14173	.word	43489	.word	45601	.word	63202	.word	49147	.word	0	.word	56288	.word	45938	.word	11407	.word	56180	.word	16374	.word	0	.word	64911	.word	39894	.word	43704	.word	63314	.word	16382	.word	0	.word	18164	.word	49445	.word	47413	.word	62353	.word	16379	.word	0	.word	62471	.word	20699	.word	19176	.word	46765	.word	49148	.word	0	.word	45860	.word	23381	.word	351	.word	36373	.word	16380	.word	0	.word	52190	.word	2479	.word	36194	.word	65534	.word	16382	.word	0	.word	53234	.word	6547	.word	29917	.word	37380	.word	16371	.word	0	.word	61321	.word	42597	.word	44875	.word	56070	.word	49141	.word	0	.word	35023	.word	36587	.word	42382	.word	52955	.word	16375	.word	0	.word	65130	.word	65535	.word	65535	.word	65535	.word	16382	.word	0	.word	49987	.word	10941	.word	20175	.word	44229	.word	16331	.word	0	.word	45301	.word	36641	.word	152	.word	62959	.word	49108	.word	0	.word	7729	.word	55572	.word	4515	.word	43787	.word	49115	.word	0	.word	12218	.word	25069	.word	64268	.word	65535	.word	16382	.word	0	.word	39514	.word	2562	.word	14458	.word	38069	.word	16364	.word	0	.word	36514	.word	39186	.word	15150	.word	34500	.word	49134	.word	0	.word	9125	.word	14475	.word	36819	.word	40101	.word	16367	.word	0	.type	_ldbA,@object	.size	_ldbA,288	.data	.section .note.GNU-stack, ""# End
 |